1*18c2aff7Sartem /*************************************************************************** 2*18c2aff7Sartem * 3*18c2aff7Sartem * devinfo_pci.c : PCI devices 4*18c2aff7Sartem * 5*18c2aff7Sartem * Copyright 2006 Sun Microsystems, Inc. All rights reserved. 6*18c2aff7Sartem * Use is subject to license terms. 7*18c2aff7Sartem * 8*18c2aff7Sartem * Licensed under the Academic Free License version 2.1 9*18c2aff7Sartem * 10*18c2aff7Sartem **************************************************************************/ 11*18c2aff7Sartem 12*18c2aff7Sartem #pragma ident "%Z%%M% %I% %E% SMI" 13*18c2aff7Sartem 14*18c2aff7Sartem #include <stdio.h> 15*18c2aff7Sartem #include <string.h> 16*18c2aff7Sartem #include <libdevinfo.h> 17*18c2aff7Sartem 18*18c2aff7Sartem #include "../osspec.h" 19*18c2aff7Sartem #include "../logger.h" 20*18c2aff7Sartem #include "../hald.h" 21*18c2aff7Sartem #include "../hald_dbus.h" 22*18c2aff7Sartem #include "../device_info.h" 23*18c2aff7Sartem #include "../util.h" 24*18c2aff7Sartem #include "../ids.h" 25*18c2aff7Sartem #include "devinfo_pci.h" 26*18c2aff7Sartem 27*18c2aff7Sartem HalDevice *devinfo_pci_add (HalDevice *parent, di_node_t node, char *devfs_path, char *device_type); 28*18c2aff7Sartem 29*18c2aff7Sartem DevinfoDevHandler devinfo_pci_handler = { 30*18c2aff7Sartem devinfo_pci_add, 31*18c2aff7Sartem NULL, 32*18c2aff7Sartem NULL, 33*18c2aff7Sartem NULL, 34*18c2aff7Sartem NULL, 35*18c2aff7Sartem NULL 36*18c2aff7Sartem }; 37*18c2aff7Sartem 38*18c2aff7Sartem HalDevice *devinfo_pci_add (HalDevice *parent, di_node_t node, char *devfs_path, char *device_type) 39*18c2aff7Sartem { 40*18c2aff7Sartem HalDevice *d; 41*18c2aff7Sartem char *s; 42*18c2aff7Sartem int *i; 43*18c2aff7Sartem int vid, pid, svid, spid; 44*18c2aff7Sartem 45*18c2aff7Sartem if ((device_type == NULL) || 46*18c2aff7Sartem ((strcmp (device_type, "pci") != 0) && 47*18c2aff7Sartem (strcmp (device_type, "pci-ide") != 0))) { 48*18c2aff7Sartem if (parent == NULL) { 49*18c2aff7Sartem return (NULL); 50*18c2aff7Sartem } else { 51*18c2aff7Sartem s = (char *)hal_device_property_get_string (parent, "info.bus"); 52*18c2aff7Sartem if ((s == NULL) || (strcmp (s, "pci") != 0)) { 53*18c2aff7Sartem return (NULL); 54*18c2aff7Sartem } 55*18c2aff7Sartem } 56*18c2aff7Sartem } 57*18c2aff7Sartem 58*18c2aff7Sartem d = hal_device_new (); 59*18c2aff7Sartem devinfo_set_default_properties (d, parent, node, devfs_path); 60*18c2aff7Sartem 61*18c2aff7Sartem hal_device_property_set_string (d, "info.bus", "pci"); 62*18c2aff7Sartem 63*18c2aff7Sartem vid = pid = svid = spid = 0; 64*18c2aff7Sartem if (di_prop_lookup_ints (DDI_DEV_T_ANY, node, "vendor-id", &i) > 0) { 65*18c2aff7Sartem vid = i[0]; 66*18c2aff7Sartem } 67*18c2aff7Sartem if (di_prop_lookup_ints (DDI_DEV_T_ANY, node, "device-id", &i) > 0) { 68*18c2aff7Sartem pid = i[0]; 69*18c2aff7Sartem } 70*18c2aff7Sartem if (di_prop_lookup_ints (DDI_DEV_T_ANY, node, "subsystem-vendor-id", &i) > 0) { 71*18c2aff7Sartem svid = i[0]; 72*18c2aff7Sartem } 73*18c2aff7Sartem if (di_prop_lookup_ints (DDI_DEV_T_ANY, node, "subsystem-id", &i) > 0) { 74*18c2aff7Sartem spid = i[0]; 75*18c2aff7Sartem } 76*18c2aff7Sartem hal_device_property_set_int (d, "pci.vendor_id", vid); 77*18c2aff7Sartem hal_device_property_set_int (d, "pci.product_id", pid); 78*18c2aff7Sartem hal_device_property_set_int (d, "pci.subsys_vendor_id", svid); 79*18c2aff7Sartem hal_device_property_set_int (d, "pci.subsys_product_id", spid); 80*18c2aff7Sartem 81*18c2aff7Sartem { 82*18c2aff7Sartem char *vendor_name; 83*18c2aff7Sartem char *product_name; 84*18c2aff7Sartem char *subsys_vendor_name; 85*18c2aff7Sartem char *subsys_product_name; 86*18c2aff7Sartem 87*18c2aff7Sartem ids_find_pci (hal_device_property_get_int (d, "pci.vendor_id"), 88*18c2aff7Sartem hal_device_property_get_int (d, "pci.product_id"), 89*18c2aff7Sartem hal_device_property_get_int (d, "pci.subsys_vendor_id"), 90*18c2aff7Sartem hal_device_property_get_int (d, "pci.subsys_product_id"), 91*18c2aff7Sartem &vendor_name, &product_name, &subsys_vendor_name, 92*18c2aff7Sartem &subsys_product_name); 93*18c2aff7Sartem 94*18c2aff7Sartem if (vendor_name != NULL) { 95*18c2aff7Sartem hal_device_property_set_string (d, "pci.vendor", vendor_name); 96*18c2aff7Sartem hal_device_property_set_string (d, "info.vendor", vendor_name); 97*18c2aff7Sartem } 98*18c2aff7Sartem 99*18c2aff7Sartem if (product_name != NULL) { 100*18c2aff7Sartem hal_device_property_set_string (d, "pci.product", product_name); 101*18c2aff7Sartem hal_device_property_set_string (d, "info.product", product_name); 102*18c2aff7Sartem } 103*18c2aff7Sartem 104*18c2aff7Sartem if (subsys_vendor_name != NULL) { 105*18c2aff7Sartem hal_device_property_set_string (d, "pci.subsys_vendor", 106*18c2aff7Sartem subsys_vendor_name); 107*18c2aff7Sartem } 108*18c2aff7Sartem 109*18c2aff7Sartem if (subsys_product_name != NULL) { 110*18c2aff7Sartem hal_device_property_set_string (d, "pci.subsys_product", subsys_product_name); 111*18c2aff7Sartem } 112*18c2aff7Sartem } 113*18c2aff7Sartem 114*18c2aff7Sartem devinfo_add_enqueue (d, devfs_path, &devinfo_pci_handler); 115*18c2aff7Sartem 116*18c2aff7Sartem return (d); 117*18c2aff7Sartem } 118*18c2aff7Sartem 119