3 * Purpose: PCI Express Port Bus Driver's Bus Overloading Functions
5 * Copyright (C) 2004 Intel
6 * Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com)
9 #include <linux/module.h>
10 #include <linux/pci.h>
11 #include <linux/kernel.h>
12 #include <linux/errno.h>
15 #include <linux/pcieport_if.h>
17 static int pcie_port_bus_match(struct device
*dev
, struct device_driver
*drv
);
18 static int pcie_port_bus_suspend(struct device
*dev
, pm_message_t state
);
19 static int pcie_port_bus_resume(struct device
*dev
);
21 struct bus_type pcie_port_bus_type
= {
22 .name
= "pci_express",
23 .match
= pcie_port_bus_match
,
24 .suspend
= pcie_port_bus_suspend
,
25 .resume
= pcie_port_bus_resume
,
27 EXPORT_SYMBOL_GPL(pcie_port_bus_type
);
29 static int pcie_port_bus_match(struct device
*dev
, struct device_driver
*drv
)
31 struct pcie_device
*pciedev
;
32 struct pcie_port_service_driver
*driver
;
34 if (drv
->bus
!= &pcie_port_bus_type
|| dev
->bus
!= &pcie_port_bus_type
)
37 pciedev
= to_pcie_device(dev
);
38 driver
= to_service_driver(drv
);
39 if ( (driver
->id_table
->vendor
!= PCI_ANY_ID
&&
40 driver
->id_table
->vendor
!= pciedev
->id
.vendor
) ||
41 (driver
->id_table
->device
!= PCI_ANY_ID
&&
42 driver
->id_table
->device
!= pciedev
->id
.device
) ||
43 (driver
->id_table
->port_type
!= PCIE_ANY_PORT
&&
44 driver
->id_table
->port_type
!= pciedev
->id
.port_type
) ||
45 driver
->id_table
->service_type
!= pciedev
->id
.service_type
)
51 static int pcie_port_bus_suspend(struct device
*dev
, pm_message_t state
)
53 struct pcie_device
*pciedev
;
54 struct pcie_port_service_driver
*driver
;
56 if (!dev
|| !dev
->driver
)
59 pciedev
= to_pcie_device(dev
);
60 driver
= to_service_driver(dev
->driver
);
61 if (driver
&& driver
->suspend
)
62 driver
->suspend(pciedev
, state
);
66 static int pcie_port_bus_resume(struct device
*dev
)
68 struct pcie_device
*pciedev
;
69 struct pcie_port_service_driver
*driver
;
71 if (!dev
|| !dev
->driver
)
74 pciedev
= to_pcie_device(dev
);
75 driver
= to_service_driver(dev
->driver
);
76 if (driver
&& driver
->resume
)
77 driver
->resume(pciedev
);