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