powerpc/eeh: Drop pdn use in eeh_pe_tree_insert()
authorOliver O'Halloran <oohall@gmail.com>
Sat, 25 Jul 2020 08:12:30 +0000 (18:12 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Sun, 26 Jul 2020 13:34:21 +0000 (23:34 +1000)
This is mostly just to make the subsequent diffs less noisy. No functional
changes.

One thing that needs calling out is the removal of the "config_addr"
variable and replacing it with edev->bdfn. The contents of edev->bdfn are
the same, however it's worth pointing out that what RTAS calls a
"config_addr" isn't the same as the bdfn. The config_addr is supposed to
be: <bus><devfn><reg> with each field being an 8 bit number. Various parts
of the EEH code use BDFN and "config_addr" as interchangeable quantities
even though they aren't really.

Signed-off-by: Oliver O'Halloran <oohall@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20200725081231.39076-13-oohall@gmail.com
arch/powerpc/kernel/eeh_pe.c

index 97bf09d..8982058 100644 (file)
@@ -366,9 +366,8 @@ static struct eeh_pe *eeh_pe_get_parent(struct eeh_dev *edev)
  */
 int eeh_pe_tree_insert(struct eeh_dev *edev)
 {
+       struct pci_controller *hose = edev->controller;
        struct eeh_pe *pe, *parent;
-       struct pci_dn *pdn = eeh_dev_to_pdn(edev);
-       int config_addr = (pdn->busno << 8) | (pdn->devfn);
 
        /* Check if the PE number is valid */
        if (!eeh_has_flag(EEH_VALID_PE_ZERO) && !edev->pe_config_addr) {
@@ -382,7 +381,7 @@ int eeh_pe_tree_insert(struct eeh_dev *edev)
         * PE should be composed of PCI bus and its subordinate
         * components.
         */
-       pe = eeh_pe_get(pdn->phb, edev->pe_config_addr, config_addr);
+       pe = eeh_pe_get(hose, edev->pe_config_addr, edev->bdfn);
        if (pe) {
                if (pe->type & EEH_PE_INVALID) {
                        list_add_tail(&edev->entry, &pe->edevs);
@@ -416,15 +415,15 @@ int eeh_pe_tree_insert(struct eeh_dev *edev)
 
        /* Create a new EEH PE */
        if (edev->physfn)
-               pe = eeh_pe_alloc(pdn->phb, EEH_PE_VF);
+               pe = eeh_pe_alloc(hose, EEH_PE_VF);
        else
-               pe = eeh_pe_alloc(pdn->phb, EEH_PE_DEVICE);
+               pe = eeh_pe_alloc(hose, EEH_PE_DEVICE);
        if (!pe) {
                pr_err("%s: out of memory!\n", __func__);
                return -ENOMEM;
        }
        pe->addr        = edev->pe_config_addr;
-       pe->config_addr = config_addr;
+       pe->config_addr = edev->bdfn;
 
        /*
         * Put the new EEH PE into hierarchy tree. If the parent
@@ -434,10 +433,10 @@ int eeh_pe_tree_insert(struct eeh_dev *edev)
         */
        parent = eeh_pe_get_parent(edev);
        if (!parent) {
-               parent = eeh_phb_pe_get(pdn->phb);
+               parent = eeh_phb_pe_get(hose);
                if (!parent) {
                        pr_err("%s: No PHB PE is found (PHB Domain=%d)\n",
-                               __func__, pdn->phb->global_number);
+                               __func__, hose->global_number);
                        edev->pe = NULL;
                        kfree(pe);
                        return -EEXIST;