Page MenuHomeFreeBSD

D8721.id.diff
No OneTemporary

D8721.id.diff

Index: head/sys/dev/acpica/acpi.c
===================================================================
--- head/sys/dev/acpica/acpi.c
+++ head/sys/dev/acpica/acpi.c
@@ -68,6 +68,8 @@
#include <dev/acpica/acpivar.h>
#include <dev/acpica/acpiio.h>
+#include <dev/pci/pcivar.h>
+
#include <vm/vm_param.h>
static MALLOC_DEFINE(M_ACPIDEV, "acpidev", "ACPI devices");
@@ -923,6 +925,15 @@
case ISA_IVAR_LOGICALID:
*(int *)result = acpi_isa_get_logicalid(child);
break;
+ case PCI_IVAR_CLASS:
+ *(uint8_t*)result = (ad->ad_cls_class >> 16) & 0xff;
+ break;
+ case PCI_IVAR_SUBCLASS:
+ *(uint8_t*)result = (ad->ad_cls_class >> 8) & 0xff;
+ break;
+ case PCI_IVAR_PROGIF:
+ *(uint8_t*)result = (ad->ad_cls_class >> 0) & 0xff;
+ break;
default:
return (ENOENT);
}
@@ -1961,6 +1972,8 @@
static ACPI_STATUS
acpi_probe_child(ACPI_HANDLE handle, UINT32 level, void *context, void **status)
{
+ ACPI_DEVICE_INFO *devinfo;
+ struct acpi_device *ad;
struct acpi_prw_data prw;
ACPI_OBJECT_TYPE type;
ACPI_HANDLE h;
@@ -2054,6 +2067,17 @@
* device not to have any resources.
*/
acpi_parse_resources(child, handle, &acpi_res_parse_set, NULL);
+
+ ad = device_get_ivars(child);
+ ad->ad_cls_class = 0xffffff;
+ if (ACPI_SUCCESS(AcpiGetObjectInfo(handle, &devinfo))) {
+ if ((devinfo->Valid & ACPI_VALID_CLS) != 0 &&
+ devinfo->ClassCode.Length >= ACPI_PCICLS_STRING_SIZE) {
+ ad->ad_cls_class = strtoul(devinfo->ClassCode.String,
+ NULL, 16);
+ }
+ AcpiOsFree(devinfo);
+ }
break;
}
}
Index: head/sys/dev/acpica/acpivar.h
===================================================================
--- head/sys/dev/acpica/acpivar.h
+++ head/sys/dev/acpica/acpivar.h
@@ -85,6 +85,7 @@
ACPI_HANDLE ad_handle;
void *ad_private;
int ad_flags;
+ int ad_cls_class;
/* Resources */
struct resource_list ad_rl;

File Metadata

Mime Type
text/plain
Expires
Mon, Apr 20, 4:11 PM (17 h, 5 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
31812141
Default Alt Text
D8721.id.diff (1 KB)

Event Timeline