void eeh_sysfs_add_device(struct pci_dev *pdev);
 void eeh_sysfs_remove_device(struct pci_dev *pdev);
 
-static inline const char *eeh_pci_name(struct pci_dev *pdev) 
-{ 
-       return pdev ? pci_name(pdev) : "<null>";
-} 
-
 static inline const char *eeh_driver_name(struct pci_dev *pdev)
 {
        return (pdev && pdev->driver) ? pdev->driver->name : "<null>";
 
        /* Access to IO BARs might get this far and still not want checking. */
        if (!pe) {
                eeh_stats.ignored_check++;
-               pr_debug("EEH: Ignored check for %s\n",
-                       eeh_pci_name(dev));
+               eeh_edev_dbg(edev, "Ignored check\n");
                return 0;
        }
 
                        if (dn)
                                location = of_get_property(dn, "ibm,loc-code",
                                                NULL);
-                       printk(KERN_ERR "EEH: %d reads ignored for recovering device at "
-                               "location=%s driver=%s pci addr=%s\n",
+                       eeh_edev_err(edev, "%d reads ignored for recovering device at location=%s driver=%s\n",
                                pe->check_count,
                                location ? location : "unknown",
-                               eeh_driver_name(dev), eeh_pci_name(dev));
-                       printk(KERN_ERR "EEH: Might be infinite loop in %s driver\n",
+                               eeh_driver_name(dev));
+                       eeh_edev_err(edev, "Might be infinite loop in %s driver\n",
                                eeh_driver_name(dev));
                        dump_stack();
                }
        if (!dev)
                return;
 
-       pr_debug("EEH: Adding device %s\n", pci_name(dev));
-
        pdn = pci_get_pdn_by_devfn(dev->bus, dev->devfn);
        edev = pdn_to_eeh_dev(pdn);
+       eeh_edev_dbg(edev, "Adding device\n");
        if (edev->pdev == dev) {
-               pr_debug("EEH: Device %s already referenced!\n", pci_name(dev));
+               eeh_edev_dbg(edev, "Device already referenced!\n");
                return;
        }
 
        edev = pci_dev_to_eeh_dev(dev);
 
        /* Unregister the device with the EEH/PCI address search system */
-       pr_debug("EEH: Removing device %s\n", pci_name(dev));
+       dev_dbg(&dev->dev, "EEH: Removing device\n");
 
        if (!edev || !edev->pdev || !edev->pe) {
-               pr_debug("EEH: Not referenced !\n");
+               dev_dbg(&dev->dev, "EEH: Device not referenced!\n");
                return;
        }
 
 
        piar->pcidev = dev;
        piar->flags = flags;
 
-       pr_debug("PIAR: insert range=[%pap:%pap] dev=%s\n",
-                &alo, &ahi, pci_name(dev));
+       eeh_edev_dbg(piar->edev, "PIAR: insert range=[%pap:%pap]\n",
+                &alo, &ahi);
 
        rb_link_node(&piar->rb_node, parent, p);
        rb_insert_color(&piar->rb_node, &pci_io_addr_cache_root.rb_root);
                piar = rb_entry(n, struct pci_io_addr_range, rb_node);
 
                if (piar->pcidev == dev) {
-                       pr_debug("PIAR: remove range=[%pap:%pap] dev=%s\n",
-                                &piar->addr_lo, &piar->addr_hi, pci_name(dev));
+                       eeh_edev_dbg(piar->edev, "PIAR: remove range=[%pap:%pap]\n",
+                                &piar->addr_lo, &piar->addr_hi);
                        rb_erase(n, &pci_io_addr_cache_root.rb_root);
                        kfree(piar);
                        goto restart;
 
 {
        struct pci_driver *driver;
        struct pci_dev *dev = eeh_dev_to_pci_dev(edev);
-       struct pci_dn *pdn = eeh_dev_to_pdn(edev);
 
        if (!(edev->physfn)) {
-               pr_warn("%s: EEH dev %04x:%02x:%02x.%01x not for VF\n",
-                       __func__, pdn->phb->global_number, pdn->busno,
-                       PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
+               eeh_edev_warn(edev, "Not for VF\n");
                return NULL;
        }
 
        }
 
 #ifdef CONFIG_PCI_IOV
-       pci_iov_add_virtfn(edev->physfn, pdn->vf_index);
+       pci_iov_add_virtfn(edev->physfn, eeh_dev_to_pdn(edev)->vf_index);
 #endif
        return NULL;
 }
 
 
        /* 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__, config_addr, pdn->phb->global_number);
+               eeh_edev_err(edev, "PE#0 is invalid for this PHB!\n");
                return -EINVAL;
        }
 
 
                /* Put the edev to PE */
                list_add_tail(&edev->entry, &pe->edevs);
-               pr_debug("EEH: Add %04x:%02x:%02x.%01x to Bus PE#%x\n",
-                        pdn->phb->global_number,
-                        pdn->busno,
-                        PCI_SLOT(pdn->devfn),
-                        PCI_FUNC(pdn->devfn),
-                        pe->addr);
+               eeh_edev_dbg(edev, "Added to bus PE\n");
                return 0;
        } else if (pe && (pe->type & EEH_PE_INVALID)) {
                list_add_tail(&edev->entry, &pe->edevs);
                        parent = parent->parent;
                }
 
-               pr_debug("EEH: Add %04x:%02x:%02x.%01x to Device "
-                        "PE#%x, Parent PE#%x\n",
-                        pdn->phb->global_number,
-                        pdn->busno,
-                        PCI_SLOT(pdn->devfn),
-                        PCI_FUNC(pdn->devfn),
-                        pe->addr, pe->parent->addr);
+               eeh_edev_dbg(edev, "Added to device PE (parent: PE#%x)\n",
+                            pe->parent->addr);
                return 0;
        }
 
        list_add_tail(&pe->child, &parent->child_list);
        list_add_tail(&edev->entry, &pe->edevs);
        edev->pe = pe;
-       pr_debug("EEH: Add %04x:%02x:%02x.%01x to "
-                "Device PE#%x, Parent PE#%x\n",
-                pdn->phb->global_number,
-                pdn->busno,
-                PCI_SLOT(pdn->devfn),
-                PCI_FUNC(pdn->devfn),
-                pe->addr, pe->parent->addr);
+       eeh_edev_dbg(edev, "Added to device PE (parent: PE#%x)\n",
+                    pe->parent->addr);
 
        return 0;
 }
 {
        struct eeh_pe *pe, *parent, *child;
        int cnt;
-       struct pci_dn *pdn = eeh_dev_to_pdn(edev);
 
        pe = eeh_dev_to_pe(edev);
        if (!pe) {
-               pr_debug("%s: No PE found for device %04x:%02x:%02x.%01x\n",
-                        __func__,  pdn->phb->global_number,
-                        pdn->busno,
-                        PCI_SLOT(pdn->devfn),
-                        PCI_FUNC(pdn->devfn));
+               eeh_edev_dbg(edev, "No PE found for device.\n");
                return -EEXIST;
        }
 
        if (!(edev->mode & (EEH_DEV_ROOT_PORT | EEH_DEV_DS_PORT)))
                return;
 
-       pr_debug("%s: Check PCIe link for %04x:%02x:%02x.%01x ...\n",
-                __func__, pdn->phb->global_number,
-                pdn->busno,
-                PCI_SLOT(pdn->devfn),
-                PCI_FUNC(pdn->devfn));
+       eeh_edev_dbg(edev, "Checking PCIe link...\n");
 
        /* Check slot status */
        cap = edev->pcie_cap;
        eeh_ops->read_config(pdn, cap + PCI_EXP_SLTSTA, 2, &val);
        if (!(val & PCI_EXP_SLTSTA_PDS)) {
-               pr_debug("  No card in the slot (0x%04x) !\n", val);
+               eeh_edev_dbg(edev, "No card in the slot (0x%04x) !\n", val);
                return;
        }
 
        if (val & PCI_EXP_SLTCAP_PCP) {
                eeh_ops->read_config(pdn, cap + PCI_EXP_SLTCTL, 2, &val);
                if (val & PCI_EXP_SLTCTL_PCC) {
-                       pr_debug("  In power-off state, power it on ...\n");
+                       eeh_edev_dbg(edev, "In power-off state, power it on ...\n");
                        val &= ~(PCI_EXP_SLTCTL_PCC | PCI_EXP_SLTCTL_PIC);
                        val |= (0x0100 & PCI_EXP_SLTCTL_PIC);
                        eeh_ops->write_config(pdn, cap + PCI_EXP_SLTCTL, 2, val);
        /* Check link */
        eeh_ops->read_config(pdn, cap + PCI_EXP_LNKCAP, 4, &val);
        if (!(val & PCI_EXP_LNKCAP_DLLLARC)) {
-               pr_debug("  No link reporting capability (0x%08x) \n", val);
+               eeh_edev_dbg(edev, "No link reporting capability (0x%08x) \n", val);
                msleep(1000);
                return;
        }
        }
 
        if (val & PCI_EXP_LNKSTA_DLLLA)
-               pr_debug("  Link up (%s)\n",
+               eeh_edev_dbg(edev, "Link up (%s)\n",
                         (val & PCI_EXP_LNKSTA_CLS_2_5GB) ? "2.5GB" : "5GB");
        else
-               pr_debug("  Link not ready (0x%04x)\n", val);
+               eeh_edev_dbg(edev, "Link not ready (0x%04x)\n", val);
 }
 
 #define BYTE_SWAP(OFF) (8*((OFF)/4)+3-(OFF))
 
        if (eeh_has_flag(EEH_FORCE_DISABLED))
                return;
 
-       pr_debug("%s: EEH: Setting up device %s.\n", __func__, pci_name(pdev));
+       dev_dbg(&pdev->dev, "EEH: Setting up device\n");
        eeh_add_device_early(pdn);
        eeh_add_device_late(pdev);
        eeh_sysfs_add_device(pdev);
        int ret;
        int config_addr = (pdn->busno << 8) | (pdn->devfn);
 
-       pr_debug("%s: probing %04x:%02x:%02x.%01x\n",
-               __func__, hose->global_number, pdn->busno,
-               PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
-
        /*
         * When probing the root bridge, which doesn't have any
         * subordinate PCI devices. We don't have OF node for
        if ((pdn->class_code >> 8) == PCI_CLASS_BRIDGE_ISA)
                return NULL;
 
+       eeh_edev_dbg(edev, "Probing device\n");
+
        /* Initialize eeh device */
        edev->class_code = pdn->class_code;
        edev->mode      &= 0xFFFFFF00;
        /* Create PE */
        ret = eeh_add_to_parent_pe(edev);
        if (ret) {
-               pr_warn("%s: Can't add PCI dev %04x:%02x:%02x.%01x to parent PE (%x)\n",
-                       __func__, hose->global_number, pdn->busno,
-                       PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn), ret);
+               eeh_edev_warn(edev, "Failed to add device to PE (code %d)\n", ret);
                return NULL;
        }
 
        /* Save memory bars */
        eeh_save_bars(edev);
 
-       pr_debug("%s: EEH enabled on %02x:%02x.%01x PHB#%x-PE#%x\n",
-               __func__, pdn->busno, PCI_SLOT(pdn->devfn),
-               PCI_FUNC(pdn->devfn), edev->pe->phb->global_number,
-               edev->pe->addr);
+       eeh_edev_dbg(edev, "EEH enabled on device\n");
 
        return NULL;
 }
 
        if (eeh_has_flag(EEH_FORCE_DISABLED))
                return;
 
-       pr_debug("%s: EEH: Setting up device %s.\n", __func__, pci_name(pdev));
+       dev_dbg(&pdev->dev, "EEH: Setting up device\n");
 #ifdef CONFIG_PCI_IOV
        if (pdev->is_virtfn) {
                struct pci_dn *physfn_pdn;
        int enable = 0;
        int ret;
 
-       pr_debug("%s: probing %04x:%02x:%02x.%01x\n",
-               __func__, pdn->phb->global_number, pdn->busno,
-               PCI_SLOT(pdn->devfn), PCI_FUNC(pdn->devfn));
-
        /* Retrieve OF node and eeh device */
        edev = pdn_to_eeh_dev(pdn);
        if (!edev || edev->pe)
         if ((pdn->class_code >> 8) == PCI_CLASS_BRIDGE_ISA)
                return NULL;
 
+       eeh_edev_dbg(edev, "Probing device\n");
+
        /*
         * Update class code and mode of eeh device. We need
         * correctly reflects that current device is root port
        pe.config_addr = (pdn->busno << 16) | (pdn->devfn << 8);
 
        /* Enable EEH on the device */
+       eeh_edev_dbg(edev, "Enabling EEH on device\n");
        ret = eeh_ops->set_option(&pe, EEH_OPT_ENABLE);
        if (ret) {
-               pr_debug("%s: EEH failed to enable on %02x:%02x.%01x PHB#%x-PE#%x (code %d)\n",
-                       __func__, pdn->busno, PCI_SLOT(pdn->devfn),
-                       PCI_FUNC(pdn->devfn), pe.phb->global_number,
-                       pe.addr, ret);
+               eeh_edev_dbg(edev, "EEH failed to enable on device (code %d)\n", ret);
        } else {
                /* Retrieve PE address */
                edev->pe_config_addr = eeh_ops->get_pe_addr(&pe);
                        edev->pe_config_addr = pdn_to_eeh_dev(pdn->parent)->pe_config_addr;
                        eeh_add_to_parent_pe(edev);
                }
-               pr_debug("%s: EEH %s on %02x:%02x.%01x PHB#%x-PE#%x (code %d)\n",
-                       __func__, (enable ? "enabled" : "unsupported"),
-                       pdn->busno, PCI_SLOT(pdn->devfn),
-                       PCI_FUNC(pdn->devfn), pe.phb->global_number,
-                       pe.addr, ret);
+               eeh_edev_dbg(edev, "EEH is %s on device (code %d)\n",
+                            (enable ? "enabled" : "unsupported"), ret);
        }
 
        /* Save memory bars */