Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/acpitools/acpidump - Decode DMAR's ANDD (ACPI Name ...
details: https://anonhg.NetBSD.org/src/rev/90d4464c6e77
branches: trunk
changeset: 433772:90d4464c6e77
user: msaitoh <msaitoh%NetBSD.org@localhost>
date: Wed Oct 03 09:52:59 2018 +0000
description:
- Decode DMAR's ANDD (ACPI Name Space).
- Add X2APIC_MODE flag of DMAR. Note that Intel's VT-d's document says the
flag's name is DMA_CTRL_PLATFORM_OPT_IN but actbl1.h says it's
DMAR_X2APIC_MODE.
diffstat:
usr.sbin/acpitools/acpidump/acpi.c | 21 +++++++++++++++++++--
1 files changed, 19 insertions(+), 2 deletions(-)
diffs (63 lines):
diff -r fff392632dc2 -r 90d4464c6e77 usr.sbin/acpitools/acpidump/acpi.c
--- a/usr.sbin/acpitools/acpidump/acpi.c Wed Oct 03 09:46:11 2018 +0000
+++ b/usr.sbin/acpitools/acpidump/acpi.c Wed Oct 03 09:52:59 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi.c,v 1.30 2018/10/03 09:46:11 msaitoh Exp $ */
+/* $NetBSD: acpi.c,v 1.31 2018/10/03 09:52:59 msaitoh Exp $ */
/*-
* Copyright (c) 1998 Doug Rabson
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: acpi.c,v 1.30 2018/10/03 09:46:11 msaitoh Exp $");
+__RCSID("$NetBSD: acpi.c,v 1.31 2018/10/03 09:52:59 msaitoh Exp $");
#include <sys/param.h>
#include <sys/endian.h>
@@ -2520,6 +2520,8 @@
return ("IOAPIC");
case 4:
return ("HPET");
+ case 5:
+ return ("ACPI Name space");
default:
snprintf(typebuf, sizeof(typebuf), "%d", type);
return (typebuf);
@@ -2667,6 +2669,17 @@
printf("\tProximityDomain=0x%08x\n", rhsa->ProximityDomain);
}
+static void
+acpi_handle_dmar_andd(ACPI_DMAR_ANDD *andd)
+{
+
+ printf("\n");
+ printf("\tType=ANDD\n");
+ printf("\tLength=%d\n", andd->Header.Length);
+ printf("\tDeviceNumber=%d\n", andd->DeviceNumber);
+ printf("\tDeviceName=0x%s\n", andd->DeviceName);
+}
+
static int
acpi_handle_dmar_remapping_structure(void *addr, int remaining)
{
@@ -2691,6 +2704,9 @@
case ACPI_DMAR_TYPE_HARDWARE_AFFINITY:
acpi_handle_dmar_rhsa(addr);
break;
+ case ACPI_DMAR_TYPE_NAMESPACE:
+ acpi_handle_dmar_andd(addr);
+ break;
default:
printf("\n");
printf("\tType=%d\n", hdr->Type);
@@ -2721,6 +2737,7 @@
printf("\tFlags=");
PRINTFLAG(dmar->Flags, INTR_REMAP);
PRINTFLAG(dmar->Flags, X2APIC_OPT_OUT);
+ PRINTFLAG(dmar->Flags, X2APIC_MODE);
PRINTFLAG_END();
#undef PRINTFLAG
Home |
Main Index |
Thread Index |
Old Index