diff options
author | marcel <marcel@FreeBSD.org> | 2002-10-17 05:41:10 +0000 |
---|---|---|
committer | marcel <marcel@FreeBSD.org> | 2002-10-17 05:41:10 +0000 |
commit | 5825c5cfa4a9546d39f67d7d05ad41259529fa6d (patch) | |
tree | d04a409cd2d4fb4d6c7b35790aa4b3f4aba512d9 /sbin/mca | |
parent | ea23c70af419695da4d796436216263da9fd0804 (diff) | |
download | FreeBSD-src-5825c5cfa4a9546d39f67d7d05ad41259529fa6d.zip FreeBSD-src-5825c5cfa4a9546d39f67d7d05ad41259529fa6d.tar.gz |
Do not emit values as var=value while everything else looks like
XML. Emit the values as <var>value</var> for consistency.
Diffstat (limited to 'sbin/mca')
-rw-r--r-- | sbin/mca/mca.c | 137 |
1 files changed, 81 insertions, 56 deletions
diff --git a/sbin/mca/mca.c b/sbin/mca/mca.c index 18f8938..cd88ad4 100644 --- a/sbin/mca/mca.c +++ b/sbin/mca/mca.c @@ -44,6 +44,7 @@ __FBSDID("$FreeBSD$"); #include <err.h> #include <errno.h> #include <fcntl.h> +#include <stdarg.h> #include <stdio.h> #include <stdlib.h> #include <string.h> @@ -89,26 +90,43 @@ uuid(struct uuid *id) return (buffer); } +static int +show_value(int indent, const char *var, const char *fmt, ...) +{ + va_list ap; + int len; + + len = indent; + while (indent--) + putchar(' '); + len += printf("<%s>", var); + va_start(ap, fmt); + len += vprintf(fmt, ap); + len += printf("</%s>\n", var); + return (len); +} + static size_t show_header(struct mca_record_header *rh) { printf(" <header>\n"); - printf(" seqnr=%lld\n", (long long)rh->rh_seqnr); - printf(" revision=%d.%d\n", BCD(rh->rh_major), BCD(rh->rh_minor)); - printf(" severity=%s\n", severity(rh->rh_error)); - printf(" length=%lld\n", (long long)rh->rh_length); - printf(" date=%d%02d/%02d/%02d\n", + show_value(4, "seqnr", "%lld", (long long)rh->rh_seqnr); + show_value(4, "revision", "%d.%d", BCD(rh->rh_major), + BCD(rh->rh_minor)); + show_value(4, "severity", "%s", severity(rh->rh_error)); + show_value(4, "length", "%lld", (long long)rh->rh_length); + show_value(4, "date", "%d%02d/%02d/%02d", BCD(rh->rh_time[MCA_RH_TIME_CENT]), BCD(rh->rh_time[MCA_RH_TIME_YEAR]), BCD(rh->rh_time[MCA_RH_TIME_MON]), BCD(rh->rh_time[MCA_RH_TIME_MDAY])); - printf(" time=%02d:%02d:%02d\n", + show_value(4, "time", "%02d:%02d:%02d", BCD(rh->rh_time[MCA_RH_TIME_HOUR]), BCD(rh->rh_time[MCA_RH_TIME_MIN]), BCD(rh->rh_time[MCA_RH_TIME_SEC])); if (rh->rh_flags & MCA_RH_FLAGS_PLATFORM_ID) - printf(" platform=%s\n", uuid(&rh->rh_platform)); + show_value(4, "platform", "%s", uuid(&rh->rh_platform)); printf(" </header>\n"); return (rh->rh_length); } @@ -118,19 +136,19 @@ show_cpu_mod(const char *what, int idx, struct mca_cpu_mod *cpu_mod) { printf(" <%s-%d>\n", what, idx); if (cpu_mod->cpu_mod_flags & MCA_CPU_MOD_FLAGS_INFO) - printf(" info=0x%016llx\n", + show_value(8, "info", "0x%016llx", (long long)cpu_mod->cpu_mod_info); if (cpu_mod->cpu_mod_flags & MCA_CPU_MOD_FLAGS_REQID) - printf(" requester=0x%016llx\n", + show_value(8, "requester", "0x%016llx", (long long)cpu_mod->cpu_mod_reqid); if (cpu_mod->cpu_mod_flags & MCA_CPU_MOD_FLAGS_RSPID) - printf(" responder=0x%016llx\n", + show_value(8, "responder", "0x%016llx", (long long)cpu_mod->cpu_mod_rspid); if (cpu_mod->cpu_mod_flags & MCA_CPU_MOD_FLAGS_TGTID) - printf(" target=0x%016llx\n", + show_value(8, "target", "0x%016llx", (long long)cpu_mod->cpu_mod_tgtid); if (cpu_mod->cpu_mod_flags & MCA_CPU_MOD_FLAGS_IP) - printf(" ip=0x%016llx\n", + show_value(8, "ip", "0x%016llx", (long long)cpu_mod->cpu_mod_ip); printf(" </%s-%d>\n", what, idx); } @@ -138,6 +156,7 @@ show_cpu_mod(const char *what, int idx, struct mca_cpu_mod *cpu_mod) static void show_cpu(struct mca_cpu_record *cpu) { + char var[16]; struct mca_cpu_mod *mod; struct mca_cpu_cpuid *cpuid; struct mca_cpu_psi *psi; @@ -146,11 +165,14 @@ show_cpu(struct mca_cpu_record *cpu) printf(" <cpu>\n"); if (cpu->cpu_flags & MCA_CPU_FLAGS_ERRMAP) - printf(" errmap=0x%016llx\n", (long long)cpu->cpu_errmap); + show_value(6, "errmap", "0x%016llx", + (long long)cpu->cpu_errmap); if (cpu->cpu_flags & MCA_CPU_FLAGS_STATE) - printf(" state=0x%016llx\n", (long long)cpu->cpu_state); + show_value(6, "state", "0x%016llx", + (long long)cpu->cpu_state); if (cpu->cpu_flags & MCA_CPU_FLAGS_CR_LID) - printf(" cr_lid=0x%016llx\n", (long long)cpu->cpu_cr_lid); + show_value(6, "cr_lid", "0x%016llx", + (long long)cpu->cpu_cr_lid); mod = (struct mca_cpu_mod*)(cpu + 1); n = MCA_CPU_FLAGS_CACHE(cpu->cpu_flags); @@ -170,9 +192,10 @@ show_cpu(struct mca_cpu_record *cpu) show_cpu_mod("ms", i, mod++); cpuid = (struct mca_cpu_cpuid*)mod; - for (i = 0; i < 6; i++) - printf(" cpuid%d=0x%016llx\n", i, - (long long)cpuid->cpuid[i]); + for (i = 0; i < 6; i++) { + sprintf(var, "cpuid-%d", i); + show_value(6, var, "0x%016llx", (long long)cpuid->cpuid[i]); + } psi = (struct mca_cpu_psi*)(cpuid + 1); /* TODO: Dump PSI */ @@ -186,41 +209,44 @@ show_memory(struct mca_mem_record *mem) printf(" <memory>\n"); if (mem->mem_flags & MCA_MEM_FLAGS_STATUS) - printf(" status=0x%016llx\n", (long long)mem->mem_status); + show_value(6, "status", "0x%016llx", + (long long)mem->mem_status); if (mem->mem_flags & MCA_MEM_FLAGS_ADDR) - printf(" address=0x%016llx\n", (long long)mem->mem_addr); + show_value(6, "address", "0x%016llx", + (long long)mem->mem_addr); if (mem->mem_flags & MCA_MEM_FLAGS_ADDRMASK) - printf(" mask=0x%016llx\n", (long long)mem->mem_addrmask); + show_value(6, "mask", "0x%016llx", + (long long)mem->mem_addrmask); if (mem->mem_flags & MCA_MEM_FLAGS_NODE) - printf(" node=0x%04x\n", mem->mem_node); + show_value(6, "node", "0x%04x", mem->mem_node); if (mem->mem_flags & MCA_MEM_FLAGS_CARD) - printf(" card=0x%04x\n", mem->mem_card); + show_value(6, "card", "0x%04x", mem->mem_card); if (mem->mem_flags & MCA_MEM_FLAGS_MODULE) - printf(" module=0x%04x\n", mem->mem_module); + show_value(6, "module", "0x%04x", mem->mem_module); if (mem->mem_flags & MCA_MEM_FLAGS_BANK) - printf(" bank=0x%04x\n", mem->mem_bank); + show_value(6, "bank", "0x%04x", mem->mem_bank); if (mem->mem_flags & MCA_MEM_FLAGS_DEVICE) - printf(" device=0x%04x\n", mem->mem_device); + show_value(6, "device", "0x%04x", mem->mem_device); if (mem->mem_flags & MCA_MEM_FLAGS_ROW) - printf(" row=0x%04x\n", mem->mem_row); + show_value(6, "row", "0x%04x", mem->mem_row); if (mem->mem_flags & MCA_MEM_FLAGS_COLUMN) - printf(" column=0x%04x\n", mem->mem_column); + show_value(6, "column", "0x%04x", mem->mem_column); if (mem->mem_flags & MCA_MEM_FLAGS_BITPOS) - printf(" bit=0x%04x\n", mem->mem_bitpos); + show_value(6, "bit", "0x%04x", mem->mem_bitpos); if (mem->mem_flags & MCA_MEM_FLAGS_REQID) - printf(" requester=0x%016llx\n", + show_value(6, "requester", "0x%016llx", (long long)mem->mem_reqid); if (mem->mem_flags & MCA_MEM_FLAGS_RSPID) - printf(" responder=0x%016llx\n", + show_value(6, "responder", "0x%016llx", (long long)mem->mem_rspid); if (mem->mem_flags & MCA_MEM_FLAGS_TGTID) - printf(" target=0x%016llx\n", + show_value(6, "target", "0x%016llx", (long long)mem->mem_tgtid); if (mem->mem_flags & MCA_MEM_FLAGS_BUSDATA) - printf(" status=0x%016llx\n", + show_value(6, "status", "0x%016llx", (long long)mem->mem_busdata); if (mem->mem_flags & MCA_MEM_FLAGS_OEM_ID) - printf(" oem=%s\n", uuid(&mem->mem_oem_id)); + show_value(6, "oem", "%s", uuid(&mem->mem_oem_id)); /* TODO: Dump OEM data */ printf(" </memory>\n"); @@ -238,32 +264,32 @@ show_pci_bus(struct mca_pcibus_record *pcibus) printf(" <pci-bus>\n"); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_STATUS) - printf(" status=0x%016llx\n", + show_value(6, "status", "0x%016llx", (long long)pcibus->pcibus_status); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_ERROR) - printf(" error=0x%04x\n", pcibus->pcibus_error); + show_value(6, "error", "0x%04x", pcibus->pcibus_error); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_BUS) - printf(" bus=0x%04x\n", pcibus->pcibus_bus); + show_value(6, "bus", "0x%04x", pcibus->pcibus_bus); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_ADDR) - printf(" address=0x%016llx\n", + show_value(6, "address", "0x%016llx", (long long)pcibus->pcibus_addr); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_DATA) - printf(" data=0x%016llx\n", + show_value(6, "data", "0x%016llx", (long long)pcibus->pcibus_data); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_CMD) - printf(" cmd=0x%016llx\n", + show_value(6, "cmd", "0x%016llx", (long long)pcibus->pcibus_cmd); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_REQID) - printf(" requester=0x%016llx\n", + show_value(6, "requester", "0x%016llx", (long long)pcibus->pcibus_reqid); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_RSPID) - printf(" responder=0x%016llx\n", + show_value(6, "responder", "0x%016llx", (long long)pcibus->pcibus_rspid); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_TGTID) - printf(" target=0x%016llx\n", + show_value(6, "target", "0x%016llx", (long long)pcibus->pcibus_tgtid); if (pcibus->pcibus_flags & MCA_PCIBUS_FLAGS_OEM_ID) - printf(" oem=%s\n", uuid(&pcibus->pcibus_oem_id)); + show_value(6, "oem", "%s", uuid(&pcibus->pcibus_oem_id)); /* TODO: Dump OEM data */ printf(" </pci-bus>\n"); @@ -281,22 +307,20 @@ show_pci_dev(struct mca_pcidev_record *pcidev) printf(" <pci-dev>\n"); if (pcidev->pcidev_flags & MCA_PCIDEV_FLAGS_STATUS) - printf(" status=0x%016llx\n", + show_value(6, "status", "0x%016llx", (long long)pcidev->pcidev_status); if (pcidev->pcidev_flags & MCA_PCIDEV_FLAGS_INFO) { - printf(" vendor=0x%04x\n", + show_value(6, "vendor", "0x%04x", pcidev->pcidev_info.info_vendor); - printf(" device=0x%04x\n", + show_value(6, "device", "0x%04x", pcidev->pcidev_info.info_device); - printf(" class=0x%06x\n", + show_value(6, "class", "0x%06x", MCA_PCIDEV_INFO_CLASS(pcidev->pcidev_info.info_ccfn)); - printf(" function=0x%02x\n", + show_value(6, "function", "0x%02x", MCA_PCIDEV_INFO_FUNCTION(pcidev->pcidev_info.info_ccfn)); - printf(" slot=0x%02x\n", - pcidev->pcidev_info.info_slot); - printf(" bus=0x%04x\n", - pcidev->pcidev_info.info_bus); - printf(" segment=0x%04x\n", + show_value(6, "slot", "0x%02x", pcidev->pcidev_info.info_slot); + show_value(6, "bus", "0x%04x", pcidev->pcidev_info.info_bus); + show_value(6, "segment", "0x%04x", pcidev->pcidev_info.info_segment); } /* TODO: dump registers */ @@ -323,8 +347,9 @@ show_section(struct mca_section_header *sh) static struct uuid uuid_generic = MCA_UUID_GENERIC; printf(" <section>\n"); - printf(" uuid=%s\n", uuid(&sh->sh_uuid)); - printf(" revision=%d.%d\n", BCD(sh->sh_major), BCD(sh->sh_minor)); + show_value(4, "uuid", "%s", uuid(&sh->sh_uuid)); + show_value(4, "revision", "%d.%d", BCD(sh->sh_major), + BCD(sh->sh_minor)); if (!memcmp(&sh->sh_uuid, &uuid_cpu, sizeof(uuid_cpu))) show_cpu((void*)(sh + 1)); |