powerpc/eeh: Remove unnecessary pointer to phb from eeh_dev
authorAlexey Kardashevskiy <aik@ozlabs.ru>
Tue, 29 Aug 2017 07:34:01 +0000 (17:34 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Thu, 31 Aug 2017 04:26:09 +0000 (14:26 +1000)
The eeh_dev struct already holds a pointer to pci_dn which it does not
exist without and pci_dn itself holds the very same pointer so just
use it.

Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/include/asm/eeh.h
arch/powerpc/kernel/eeh.c
arch/powerpc/kernel/eeh_dev.c
arch/powerpc/kernel/eeh_driver.c
arch/powerpc/kernel/eeh_pe.c
arch/powerpc/platforms/powernv/eeh-powernv.c
arch/powerpc/platforms/pseries/eeh_pseries.c

index 26a6a43..777d37a 100644 (file)
@@ -141,7 +141,6 @@ struct eeh_dev {
        struct eeh_pe *pe;              /* Associated PE                */
        struct list_head list;          /* Form link list in the PE     */
        struct list_head rmv_list;      /* Record the removed edevs     */
-       struct pci_controller *phb;     /* Associated PHB               */
        struct pci_dn *pdn;             /* Associated PCI device node   */
        struct pci_dev *pdev;           /* Associated PCI device        */
        bool in_error;                  /* Error flag for edev          */
index 5e6887c..66c98c1 100644 (file)
@@ -170,10 +170,10 @@ static size_t eeh_dump_dev_log(struct eeh_dev *edev, char *buf, size_t len)
        char buffer[128];
 
        n += scnprintf(buf+n, len-n, "%04x:%02x:%02x.%01x\n",
-                      edev->phb->global_number, pdn->busno,
+                      pdn->phb->global_number, pdn->busno,
                       PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
        pr_warn("EEH: of node=%04x:%02x:%02x.%01x\n",
-               edev->phb->global_number, pdn->busno,
+               pdn->phb->global_number, pdn->busno,
                PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
 
        eeh_ops->read_config(pdn, PCI_VENDOR_ID, 4, &cfg);
@@ -1064,7 +1064,7 @@ core_initcall_sync(eeh_init);
  */
 void eeh_add_device_early(struct pci_dn *pdn)
 {
-       struct pci_controller *phb;
+       struct pci_controller *phb = pdn ? pdn->phb : NULL;
        struct eeh_dev *edev = pdn_to_eeh_dev(pdn);
 
        if (!edev)
@@ -1074,7 +1074,6 @@ void eeh_add_device_early(struct pci_dn *pdn)
                return;
 
        /* USB Bus children of PCI devices will not have BUID's */
-       phb = edev->phb;
        if (NULL == phb ||
            (eeh_has_flag(EEH_PROBE_MODE_DEVTREE) && 0 == phb->buid))
                return;
index d6b2ca7..bdf4a36 100644 (file)
@@ -50,7 +50,6 @@
  */
 struct eeh_dev *eeh_dev_init(struct pci_dn *pdn)
 {
-       struct pci_controller *phb = pdn->phb;
        struct eeh_dev *edev;
 
        /* Allocate EEH device */
@@ -64,7 +63,6 @@ struct eeh_dev *eeh_dev_init(struct pci_dn *pdn)
        /* Associate EEH device with OF node */
        pdn->edev = edev;
        edev->pdn = pdn;
-       edev->phb = phb;
        INIT_LIST_HEAD(&edev->list);
        INIT_LIST_HEAD(&edev->rmv_list);
 
index c405c79..8b84019 100644 (file)
@@ -428,7 +428,7 @@ static void *eeh_add_virt_device(void *data, void *userdata)
 
        if (!(edev->physfn)) {
                pr_warn("%s: EEH dev %04x:%02x:%02x.%01x not for VF\n",
-                       __func__, edev->phb->global_number, pdn->busno,
+                       __func__, pdn->phb->global_number, pdn->busno,
                        PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
                return NULL;
        }
index 84d79f3..419c3f0 100644 (file)
@@ -339,11 +339,12 @@ static struct eeh_pe *eeh_pe_get_parent(struct eeh_dev *edev)
 int eeh_add_to_parent_pe(struct eeh_dev *edev)
 {
        struct eeh_pe *pe, *parent;
+       struct pci_dn *pdn = eeh_dev_to_pdn(edev);
 
        /* Check if the PE number is valid */
        if (!eeh_has_flag(EEH_VALID_PE_ZERO) && !edev->pe_config_addr) {
                pr_err("%s: Invalid PE#0 for edev 0x%x on PHB#%x\n",
-                      __func__, edev->config_addr, edev->phb->global_number);
+                      __func__, edev->config_addr, pdn->phb->global_number);
                return -EINVAL;
        }
 
@@ -353,7 +354,7 @@ int eeh_add_to_parent_pe(struct eeh_dev *edev)
         * PE should be composed of PCI bus and its subordinate
         * components.
         */
-       pe = eeh_pe_get(edev->pdn->phb, edev->pe_config_addr,
+       pe = eeh_pe_get(pdn->phb, edev->pe_config_addr,
                        edev->config_addr);
        if (pe && !(pe->type & EEH_PE_INVALID)) {
                /* Mark the PE as type of PCI bus */
@@ -363,7 +364,7 @@ int eeh_add_to_parent_pe(struct eeh_dev *edev)
                /* Put the edev to PE */
                list_add_tail(&edev->list, &pe->edevs);
                pr_debug("EEH: Add %04x:%02x:%02x.%01x to Bus PE#%x\n",
-                       edev->phb->global_number,
+                        pdn->phb->global_number,
                        edev->config_addr >> 8,
                        PCI_SLOT(edev->config_addr & 0xFF),
                        PCI_FUNC(edev->config_addr & 0xFF),
@@ -386,7 +387,7 @@ int eeh_add_to_parent_pe(struct eeh_dev *edev)
 
                pr_debug("EEH: Add %04x:%02x:%02x.%01x to Device "
                         "PE#%x, Parent PE#%x\n",
-                       edev->phb->global_number,
+                        pdn->phb->global_number,
                        edev->config_addr >> 8,
                         PCI_SLOT(edev->config_addr & 0xFF),
                         PCI_FUNC(edev->config_addr & 0xFF),
@@ -396,9 +397,9 @@ int eeh_add_to_parent_pe(struct eeh_dev *edev)
 
        /* Create a new EEH PE */
        if (edev->physfn)
-               pe = eeh_pe_alloc(edev->phb, EEH_PE_VF);
+               pe = eeh_pe_alloc(pdn->phb, EEH_PE_VF);
        else
-               pe = eeh_pe_alloc(edev->phb, EEH_PE_DEVICE);
+               pe = eeh_pe_alloc(pdn->phb, EEH_PE_DEVICE);
        if (!pe) {
                pr_err("%s: out of memory!\n", __func__);
                return -ENOMEM;
@@ -414,10 +415,10 @@ int eeh_add_to_parent_pe(struct eeh_dev *edev)
         */
        parent = eeh_pe_get_parent(edev);
        if (!parent) {
-               parent = eeh_phb_pe_get(edev->phb);
+               parent = eeh_phb_pe_get(pdn->phb);
                if (!parent) {
                        pr_err("%s: No PHB PE is found (PHB Domain=%d)\n",
-                               __func__, edev->phb->global_number);
+                               __func__, pdn->phb->global_number);
                        edev->pe = NULL;
                        kfree(pe);
                        return -EEXIST;
@@ -434,7 +435,7 @@ int eeh_add_to_parent_pe(struct eeh_dev *edev)
        edev->pe = pe;
        pr_debug("EEH: Add %04x:%02x:%02x.%01x to "
                 "Device PE#%x, Parent PE#%x\n",
-                edev->phb->global_number,
+                pdn->phb->global_number,
                 edev->config_addr >> 8,
                 PCI_SLOT(edev->config_addr & 0xFF),
                 PCI_FUNC(edev->config_addr & 0xFF),
@@ -456,10 +457,11 @@ int eeh_rmv_from_parent_pe(struct eeh_dev *edev)
 {
        struct eeh_pe *pe, *parent, *child;
        int cnt;
+       struct pci_dn *pdn = eeh_dev_to_pdn(edev);
 
        if (!edev->pe) {
                pr_debug("%s: No PE found for device %04x:%02x:%02x.%01x\n",
-                        __func__,  edev->phb->global_number,
+                        __func__,  pdn->phb->global_number,
                         edev->config_addr >> 8,
                         PCI_SLOT(edev->config_addr & 0xFF),
                         PCI_FUNC(edev->config_addr & 0xFF));
@@ -722,7 +724,7 @@ static void eeh_bridge_check_link(struct eeh_dev *edev)
                return;
 
        pr_debug("%s: Check PCIe link for %04x:%02x:%02x.%01x ...\n",
-                __func__, edev->phb->global_number,
+                __func__, pdn->phb->global_number,
                 edev->config_addr >> 8,
                 PCI_SLOT(edev->config_addr & 0xFF),
                 PCI_FUNC(edev->config_addr & 0xFF));
index ac8c01c..552b0cd 100644 (file)
@@ -926,7 +926,6 @@ void pnv_pci_reset_secondary_bus(struct pci_dev *dev)
 static void pnv_eeh_wait_for_pending(struct pci_dn *pdn, const char *type,
                                     int pos, u16 mask)
 {
-       struct eeh_dev *edev = pdn_to_eeh_dev(pdn);
        int i, status = 0;
 
        /* Wait for Transaction Pending bit to be cleared */
@@ -940,7 +939,7 @@ static void pnv_eeh_wait_for_pending(struct pci_dn *pdn, const char *type,
 
        pr_warn("%s: Pending transaction while issuing %sFLR to %04x:%02x:%02x.%01x\n",
                __func__, type,
-               edev->phb->global_number, pdn->busno,
+               pdn->phb->global_number, pdn->busno,
                PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
 }
 
@@ -1714,7 +1713,7 @@ static int pnv_eeh_restore_config(struct pci_dn *pdn)
        if (edev->physfn) {
                ret = pnv_eeh_restore_vf_config(pdn);
        } else {
-               phb = edev->phb->private_data;
+               phb = pdn->phb->private_data;
                ret = opal_pci_reinit(phb->opal_id,
                                      OPAL_REINIT_PCI_DEV, edev->config_addr);
        }
index 1eef46d..04c8c18 100644 (file)
@@ -247,7 +247,7 @@ static void *pseries_eeh_probe(struct pci_dn *pdn, void *data)
 
        /* Initialize the fake PE */
        memset(&pe, 0, sizeof(struct eeh_pe));
-       pe.phb = edev->phb;
+       pe.phb = pdn->phb;
        pe.config_addr = (pdn->busno << 16) | (pdn->devfn << 8);
 
        /* Enable EEH on the device */