aboutsummaryrefslogtreecommitdiffstats
path: root/arch/ppc64/kernel/eeh.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/ppc64/kernel/eeh.c')
-rw-r--r--arch/ppc64/kernel/eeh.c33
1 files changed, 26 insertions, 7 deletions
diff --git a/arch/ppc64/kernel/eeh.c b/arch/ppc64/kernel/eeh.c
index bb11569d2b4b..99f11b66b5a0 100644
--- a/arch/ppc64/kernel/eeh.c
+++ b/arch/ppc64/kernel/eeh.c
@@ -219,9 +219,9 @@ pci_addr_cache_insert(struct pci_dev *dev, unsigned long alo,
219 while (*p) { 219 while (*p) {
220 parent = *p; 220 parent = *p;
221 piar = rb_entry(parent, struct pci_io_addr_range, rb_node); 221 piar = rb_entry(parent, struct pci_io_addr_range, rb_node);
222 if (alo < piar->addr_lo) { 222 if (ahi < piar->addr_lo) {
223 p = &parent->rb_left; 223 p = &parent->rb_left;
224 } else if (ahi > piar->addr_hi) { 224 } else if (alo > piar->addr_hi) {
225 p = &parent->rb_right; 225 p = &parent->rb_right;
226 } else { 226 } else {
227 if (dev != piar->pcidev || 227 if (dev != piar->pcidev ||
@@ -240,6 +240,11 @@ pci_addr_cache_insert(struct pci_dev *dev, unsigned long alo,
240 piar->pcidev = dev; 240 piar->pcidev = dev;
241 piar->flags = flags; 241 piar->flags = flags;
242 242
243#ifdef DEBUG
244 printk(KERN_DEBUG "PIAR: insert range=[%lx:%lx] dev=%s\n",
245 alo, ahi, pci_name (dev));
246#endif
247
243 rb_link_node(&piar->rb_node, parent, p); 248 rb_link_node(&piar->rb_node, parent, p);
244 rb_insert_color(&piar->rb_node, &pci_io_addr_cache_root.rb_root); 249 rb_insert_color(&piar->rb_node, &pci_io_addr_cache_root.rb_root);
245 250
@@ -301,7 +306,7 @@ static void __pci_addr_cache_insert_device(struct pci_dev *dev)
301 * we maintain a cache of devices that can be quickly searched. 306 * we maintain a cache of devices that can be quickly searched.
302 * This routine adds a device to that cache. 307 * This routine adds a device to that cache.
303 */ 308 */
304void pci_addr_cache_insert_device(struct pci_dev *dev) 309static void pci_addr_cache_insert_device(struct pci_dev *dev)
305{ 310{
306 unsigned long flags; 311 unsigned long flags;
307 312
@@ -344,7 +349,7 @@ restart:
344 * the tree multiple times (once per resource). 349 * the tree multiple times (once per resource).
345 * But so what; device removal doesn't need to be that fast. 350 * But so what; device removal doesn't need to be that fast.
346 */ 351 */
347void pci_addr_cache_remove_device(struct pci_dev *dev) 352static void pci_addr_cache_remove_device(struct pci_dev *dev)
348{ 353{
349 unsigned long flags; 354 unsigned long flags;
350 355
@@ -366,6 +371,9 @@ void __init pci_addr_cache_build(void)
366{ 371{
367 struct pci_dev *dev = NULL; 372 struct pci_dev *dev = NULL;
368 373
374 if (!eeh_subsystem_enabled)
375 return;
376
369 spin_lock_init(&pci_io_addr_cache_root.piar_lock); 377 spin_lock_init(&pci_io_addr_cache_root.piar_lock);
370 378
371 while ((dev = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, dev)) != NULL) { 379 while ((dev = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, dev)) != NULL) {
@@ -837,7 +845,7 @@ void eeh_add_device_early(struct device_node *dn)
837 info.buid_lo = BUID_LO(phb->buid); 845 info.buid_lo = BUID_LO(phb->buid);
838 early_enable_eeh(dn, &info); 846 early_enable_eeh(dn, &info);
839} 847}
840EXPORT_SYMBOL(eeh_add_device_early); 848EXPORT_SYMBOL_GPL(eeh_add_device_early);
841 849
842/** 850/**
843 * eeh_add_device_late - perform EEH initialization for the indicated pci device 851 * eeh_add_device_late - perform EEH initialization for the indicated pci device
@@ -848,6 +856,8 @@ EXPORT_SYMBOL(eeh_add_device_early);
848 */ 856 */
849void eeh_add_device_late(struct pci_dev *dev) 857void eeh_add_device_late(struct pci_dev *dev)
850{ 858{
859 struct device_node *dn;
860
851 if (!dev || !eeh_subsystem_enabled) 861 if (!dev || !eeh_subsystem_enabled)
852 return; 862 return;
853 863
@@ -855,9 +865,13 @@ void eeh_add_device_late(struct pci_dev *dev)
855 printk(KERN_DEBUG "EEH: adding device %s\n", pci_name(dev)); 865 printk(KERN_DEBUG "EEH: adding device %s\n", pci_name(dev));
856#endif 866#endif
857 867
868 pci_dev_get (dev);
869 dn = pci_device_to_OF_node(dev);
870 PCI_DN(dn)->pcidev = dev;
871
858 pci_addr_cache_insert_device (dev); 872 pci_addr_cache_insert_device (dev);
859} 873}
860EXPORT_SYMBOL(eeh_add_device_late); 874EXPORT_SYMBOL_GPL(eeh_add_device_late);
861 875
862/** 876/**
863 * eeh_remove_device - undo EEH setup for the indicated pci device 877 * eeh_remove_device - undo EEH setup for the indicated pci device
@@ -868,6 +882,7 @@ EXPORT_SYMBOL(eeh_add_device_late);
868 */ 882 */
869void eeh_remove_device(struct pci_dev *dev) 883void eeh_remove_device(struct pci_dev *dev)
870{ 884{
885 struct device_node *dn;
871 if (!dev || !eeh_subsystem_enabled) 886 if (!dev || !eeh_subsystem_enabled)
872 return; 887 return;
873 888
@@ -876,8 +891,12 @@ void eeh_remove_device(struct pci_dev *dev)
876 printk(KERN_DEBUG "EEH: remove device %s\n", pci_name(dev)); 891 printk(KERN_DEBUG "EEH: remove device %s\n", pci_name(dev));
877#endif 892#endif
878 pci_addr_cache_remove_device(dev); 893 pci_addr_cache_remove_device(dev);
894
895 dn = pci_device_to_OF_node(dev);
896 PCI_DN(dn)->pcidev = NULL;
897 pci_dev_put (dev);
879} 898}
880EXPORT_SYMBOL(eeh_remove_device); 899EXPORT_SYMBOL_GPL(eeh_remove_device);
881 900
882static int proc_eeh_show(struct seq_file *m, void *v) 901static int proc_eeh_show(struct seq_file *m, void *v)
883{ 902{