diff options
Diffstat (limited to 'arch/powerpc/kernel/prom_parse.c')
-rw-r--r-- | arch/powerpc/kernel/prom_parse.c | 30 |
1 files changed, 20 insertions, 10 deletions
diff --git a/arch/powerpc/kernel/prom_parse.c b/arch/powerpc/kernel/prom_parse.c index 6a7e997c401d..a10825a5dfe6 100644 --- a/arch/powerpc/kernel/prom_parse.c +++ b/arch/powerpc/kernel/prom_parse.c | |||
@@ -598,11 +598,6 @@ static struct device_node *of_irq_find_parent(struct device_node *child) | |||
598 | return p; | 598 | return p; |
599 | } | 599 | } |
600 | 600 | ||
601 | static u8 of_irq_pci_swizzle(u8 slot, u8 pin) | ||
602 | { | ||
603 | return (((pin - 1) + slot) % 4) + 1; | ||
604 | } | ||
605 | |||
606 | /* This doesn't need to be called if you don't have any special workaround | 601 | /* This doesn't need to be called if you don't have any special workaround |
607 | * flags to pass | 602 | * flags to pass |
608 | */ | 603 | */ |
@@ -644,14 +639,17 @@ void of_irq_map_init(unsigned int flags) | |||
644 | 639 | ||
645 | } | 640 | } |
646 | 641 | ||
647 | int of_irq_map_raw(struct device_node *parent, u32 *intspec, u32 *addr, | 642 | int of_irq_map_raw(struct device_node *parent, u32 *intspec, u32 ointsize, |
648 | struct of_irq *out_irq) | 643 | u32 *addr, struct of_irq *out_irq) |
649 | { | 644 | { |
650 | struct device_node *ipar, *tnode, *old = NULL, *newpar = NULL; | 645 | struct device_node *ipar, *tnode, *old = NULL, *newpar = NULL; |
651 | u32 *tmp, *imap, *imask; | 646 | u32 *tmp, *imap, *imask; |
652 | u32 intsize = 1, addrsize, newintsize = 0, newaddrsize = 0; | 647 | u32 intsize = 1, addrsize, newintsize = 0, newaddrsize = 0; |
653 | int imaplen, match, i; | 648 | int imaplen, match, i; |
654 | 649 | ||
650 | DBG("of_irq_map_raw: par=%s,intspec=[0x%08x 0x%08x...],ointsize=%d\n", | ||
651 | parent->full_name, intspec[0], intspec[1], ointsize); | ||
652 | |||
655 | ipar = of_node_get(parent); | 653 | ipar = of_node_get(parent); |
656 | 654 | ||
657 | /* First get the #interrupt-cells property of the current cursor | 655 | /* First get the #interrupt-cells property of the current cursor |
@@ -675,6 +673,9 @@ int of_irq_map_raw(struct device_node *parent, u32 *intspec, u32 *addr, | |||
675 | 673 | ||
676 | DBG("of_irq_map_raw: ipar=%s, size=%d\n", ipar->full_name, intsize); | 674 | DBG("of_irq_map_raw: ipar=%s, size=%d\n", ipar->full_name, intsize); |
677 | 675 | ||
676 | if (ointsize != intsize) | ||
677 | return -EINVAL; | ||
678 | |||
678 | /* Look for this #address-cells. We have to implement the old linux | 679 | /* Look for this #address-cells. We have to implement the old linux |
679 | * trick of looking for the parent here as some device-trees rely on it | 680 | * trick of looking for the parent here as some device-trees rely on it |
680 | */ | 681 | */ |
@@ -880,17 +881,26 @@ int of_irq_map_one(struct device_node *device, int index, struct of_irq *out_irq | |||
880 | } | 881 | } |
881 | intsize = *tmp; | 882 | intsize = *tmp; |
882 | 883 | ||
884 | DBG(" intsize=%d intlen=%d\n", intsize, intlen); | ||
885 | |||
883 | /* Check index */ | 886 | /* Check index */ |
884 | if ((index + 1) * intsize > intlen) | 887 | if ((index + 1) * intsize > intlen) |
885 | return -EINVAL; | 888 | return -EINVAL; |
886 | 889 | ||
887 | /* Get new specifier and map it */ | 890 | /* Get new specifier and map it */ |
888 | res = of_irq_map_raw(p, intspec + index * intsize, addr, out_irq); | 891 | res = of_irq_map_raw(p, intspec + index * intsize, intsize, |
892 | addr, out_irq); | ||
889 | of_node_put(p); | 893 | of_node_put(p); |
890 | return res; | 894 | return res; |
891 | } | 895 | } |
892 | EXPORT_SYMBOL_GPL(of_irq_map_one); | 896 | EXPORT_SYMBOL_GPL(of_irq_map_one); |
893 | 897 | ||
898 | #ifdef CONFIG_PCI | ||
899 | static u8 of_irq_pci_swizzle(u8 slot, u8 pin) | ||
900 | { | ||
901 | return (((pin - 1) + slot) % 4) + 1; | ||
902 | } | ||
903 | |||
894 | int of_irq_map_pci(struct pci_dev *pdev, struct of_irq *out_irq) | 904 | int of_irq_map_pci(struct pci_dev *pdev, struct of_irq *out_irq) |
895 | { | 905 | { |
896 | struct device_node *dn, *ppnode; | 906 | struct device_node *dn, *ppnode; |
@@ -964,7 +974,7 @@ int of_irq_map_pci(struct pci_dev *pdev, struct of_irq *out_irq) | |||
964 | laddr[0] = (pdev->bus->number << 16) | 974 | laddr[0] = (pdev->bus->number << 16) |
965 | | (pdev->devfn << 8); | 975 | | (pdev->devfn << 8); |
966 | laddr[1] = laddr[2] = 0; | 976 | laddr[1] = laddr[2] = 0; |
967 | return of_irq_map_raw(ppnode, &lspec, laddr, out_irq); | 977 | return of_irq_map_raw(ppnode, &lspec, 1, laddr, out_irq); |
968 | } | 978 | } |
969 | EXPORT_SYMBOL_GPL(of_irq_map_pci); | 979 | EXPORT_SYMBOL_GPL(of_irq_map_pci); |
970 | 980 | #endif /* CONFIG_PCI */ | |