|
@@ -912,7 +912,8 @@ machine_arch_initcall(pseries, find_existing_ddw_windows);
|
|
|
static int query_ddw(struct pci_dev *dev, const u32 *ddw_avail,
|
|
|
struct ddw_query_response *query)
|
|
|
{
|
|
|
- struct eeh_dev *edev;
|
|
|
+ struct device_node *dn;
|
|
|
+ struct pci_dn *pdn;
|
|
|
u32 cfg_addr;
|
|
|
u64 buid;
|
|
|
int ret;
|
|
@@ -923,11 +924,10 @@ static int query_ddw(struct pci_dev *dev, const u32 *ddw_avail,
|
|
|
* Retrieve them from the pci device, not the node with the
|
|
|
* dma-window property
|
|
|
*/
|
|
|
- edev = pci_dev_to_eeh_dev(dev);
|
|
|
- cfg_addr = edev->config_addr;
|
|
|
- if (edev->pe_config_addr)
|
|
|
- cfg_addr = edev->pe_config_addr;
|
|
|
- buid = edev->phb->buid;
|
|
|
+ dn = pci_device_to_OF_node(dev);
|
|
|
+ pdn = PCI_DN(dn);
|
|
|
+ buid = pdn->phb->buid;
|
|
|
+ cfg_addr = (pdn->busno << 8) | pdn->devfn;
|
|
|
|
|
|
ret = rtas_call(ddw_avail[0], 3, 5, (u32 *)query,
|
|
|
cfg_addr, BUID_HI(buid), BUID_LO(buid));
|
|
@@ -941,7 +941,8 @@ static int create_ddw(struct pci_dev *dev, const u32 *ddw_avail,
|
|
|
struct ddw_create_response *create, int page_shift,
|
|
|
int window_shift)
|
|
|
{
|
|
|
- struct eeh_dev *edev;
|
|
|
+ struct device_node *dn;
|
|
|
+ struct pci_dn *pdn;
|
|
|
u32 cfg_addr;
|
|
|
u64 buid;
|
|
|
int ret;
|
|
@@ -952,11 +953,10 @@ static int create_ddw(struct pci_dev *dev, const u32 *ddw_avail,
|
|
|
* Retrieve them from the pci device, not the node with the
|
|
|
* dma-window property
|
|
|
*/
|
|
|
- edev = pci_dev_to_eeh_dev(dev);
|
|
|
- cfg_addr = edev->config_addr;
|
|
|
- if (edev->pe_config_addr)
|
|
|
- cfg_addr = edev->pe_config_addr;
|
|
|
- buid = edev->phb->buid;
|
|
|
+ dn = pci_device_to_OF_node(dev);
|
|
|
+ pdn = PCI_DN(dn);
|
|
|
+ buid = pdn->phb->buid;
|
|
|
+ cfg_addr = (pdn->busno << 8) | pdn->devfn;
|
|
|
|
|
|
do {
|
|
|
/* extra outputs are LIOBN and dma-addr (hi, lo) */
|