[Very RFC 11/46] powerpc/eeh: Convert various printfs to use edev, not pci_dn
Alexey Kardashevskiy
aik at ozlabs.ru
Fri Nov 22 15:55:17 AEDT 2019
On 20/11/2019 12:28, Oliver O'Halloran wrote:
> We use the pci_dn to retrieve the domain, bus, device, and function numbers for
> an EEH device. We now have that in the eeh_dev so covert the various printk()s
> we have around the place to source that information from the eeh_dev.
>
> Signed-off-by: Oliver O'Halloran <oohall at gmail.com>
> ---
> arch/powerpc/kernel/eeh.c | 14 ++++----------
> arch/powerpc/kernel/eeh_pe.c | 14 ++++++--------
> 2 files changed, 10 insertions(+), 18 deletions(-)
>
> diff --git a/arch/powerpc/kernel/eeh.c b/arch/powerpc/kernel/eeh.c
> index 63500e34e329..c8039fdb23ba 100644
> --- a/arch/powerpc/kernel/eeh.c
> +++ b/arch/powerpc/kernel/eeh.c
> @@ -167,23 +167,17 @@ void eeh_show_enabled(void)
> */
> static size_t eeh_dump_dev_log(struct eeh_dev *edev, char *buf, size_t len)
> {
> - struct pci_dn *pdn = eeh_dev_to_pdn(edev);
> u32 cfg;
> int cap, i;
> int n = 0, l = 0;
> char buffer[128];
>
> - if (!pdn) {
> - pr_warn("EEH: Note: No error log for absent device.\n");
> - return 0;
> - }
> -
> n += scnprintf(buf+n, len-n, "%04x:%02x:%02x.%01x\n",
> - pdn->phb->global_number, pdn->busno,
> - PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
> + edev->pe->phb->global_number, edev->bdfn >> 8,
> + PCI_SLOT(edev->bdfn), PCI_FUNC(edev->bdfn));
> pr_warn("EEH: of node=%04x:%02x:%02x.%01x\n",
> - pdn->phb->global_number, pdn->busno,
> - PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
> + edev->pe->phb->global_number, edev->bdfn >> 8,
> + PCI_SLOT(edev->bdfn), PCI_FUNC(edev->bdfn));
>
> eeh_ops->read_config(edev, PCI_VENDOR_ID, 4, &cfg);
> n += scnprintf(buf+n, len-n, "dev/vend:%08x\n", cfg);
> diff --git a/arch/powerpc/kernel/eeh_pe.c b/arch/powerpc/kernel/eeh_pe.c
> index 634963aa4a77..831f363f1732 100644
> --- a/arch/powerpc/kernel/eeh_pe.c
> +++ b/arch/powerpc/kernel/eeh_pe.c
> @@ -366,9 +366,8 @@ static struct eeh_pe *eeh_pe_get_parent(struct eeh_dev *edev)
> */
> int eeh_add_to_parent_pe(struct eeh_dev *edev)
> {
> + int config_addr = edev->bdfn;
> 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_add_to_parent_pe(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(edev->controller, edev->pe_config_addr, config_addr);
> if (pe) {
> if (pe->type & EEH_PE_INVALID) {
> list_add_tail(&edev->entry, &pe->edevs);
> @@ -416,9 +415,9 @@ int eeh_add_to_parent_pe(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(edev->controller, EEH_PE_VF);
> else
> - pe = eeh_pe_alloc(pdn->phb, EEH_PE_DEVICE);
> + pe = eeh_pe_alloc(edev->controller, EEH_PE_DEVICE);
> if (!pe) {
> pr_err("%s: out of memory!\n", __func__);
> return -ENOMEM;
> @@ -434,10 +433,10 @@ int eeh_add_to_parent_pe(struct eeh_dev *edev)
> */
> parent = eeh_pe_get_parent(edev);
> if (!parent) {
> - parent = eeh_phb_pe_get(pdn->phb);
> + parent = eeh_phb_pe_get(edev->controller);
> if (!parent) {
> pr_err("%s: No PHB PE is found (PHB Domain=%d)\n",
> - __func__, pdn->phb->global_number);
> + __func__, edev->controller->global_number);
> edev->pe = NULL;
> kfree(pe);
> return -EEXIST;
> @@ -698,7 +697,6 @@ void eeh_pe_state_clear(struct eeh_pe *root, int state, bool include_passed)
> */
> static void eeh_bridge_check_link(struct eeh_dev *edev)
> {
> - struct pci_dn *pdn = eeh_dev_to_pdn(edev);
This belongs to 09/46. Or just merge them.
> int cap;
> uint32_t val;
> int timeout = 0;
>
--
Alexey
More information about the Linuxppc-dev
mailing list