diff options
Diffstat (limited to 'arch/ppc/kernel/pci.c')
-rw-r--r-- | arch/ppc/kernel/pci.c | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/arch/ppc/kernel/pci.c b/arch/ppc/kernel/pci.c index f7fae5f153b2..50c75eec8874 100644 --- a/arch/ppc/kernel/pci.c +++ b/arch/ppc/kernel/pci.c | |||
@@ -815,8 +815,7 @@ EXPORT_SYMBOL(pci_device_to_OF_node); | |||
815 | * to set pci_assign_all_buses to 1 and still use RTAS for PCI | 815 | * to set pci_assign_all_buses to 1 and still use RTAS for PCI |
816 | * config cycles. | 816 | * config cycles. |
817 | */ | 817 | */ |
818 | struct pci_controller* | 818 | struct pci_controller* pci_find_hose_for_OF_device(struct device_node* node) |
819 | pci_find_hose_for_OF_device(struct device_node* node) | ||
820 | { | 819 | { |
821 | if (!have_of) | 820 | if (!have_of) |
822 | return NULL; | 821 | return NULL; |
@@ -942,7 +941,7 @@ pci_process_bridge_OF_ranges(struct pci_controller *hose, | |||
942 | while (ranges && (rlen -= np * sizeof(unsigned int)) >= 0) { | 941 | while (ranges && (rlen -= np * sizeof(unsigned int)) >= 0) { |
943 | res = NULL; | 942 | res = NULL; |
944 | size = ranges[na+4]; | 943 | size = ranges[na+4]; |
945 | switch (ranges[0] >> 24) { | 944 | switch ((ranges[0] >> 24) & 0x3) { |
946 | case 1: /* I/O space */ | 945 | case 1: /* I/O space */ |
947 | if (ranges[2] != 0) | 946 | if (ranges[2] != 0) |
948 | break; | 947 | break; |
@@ -956,6 +955,8 @@ pci_process_bridge_OF_ranges(struct pci_controller *hose, | |||
956 | res = &hose->io_resource; | 955 | res = &hose->io_resource; |
957 | res->flags = IORESOURCE_IO; | 956 | res->flags = IORESOURCE_IO; |
958 | res->start = ranges[2]; | 957 | res->start = ranges[2]; |
958 | DBG("PCI: IO 0x%lx -> 0x%lx\n", | ||
959 | res->start, res->start + size - 1); | ||
959 | break; | 960 | break; |
960 | case 2: /* memory space */ | 961 | case 2: /* memory space */ |
961 | memno = 0; | 962 | memno = 0; |
@@ -973,7 +974,11 @@ pci_process_bridge_OF_ranges(struct pci_controller *hose, | |||
973 | if (memno < 3) { | 974 | if (memno < 3) { |
974 | res = &hose->mem_resources[memno]; | 975 | res = &hose->mem_resources[memno]; |
975 | res->flags = IORESOURCE_MEM; | 976 | res->flags = IORESOURCE_MEM; |
977 | if(ranges[0] & 0x40000000) | ||
978 | res->flags |= IORESOURCE_PREFETCH; | ||
976 | res->start = ranges[na+2]; | 979 | res->start = ranges[na+2]; |
980 | DBG("PCI: MEM[%d] 0x%lx -> 0x%lx\n", memno, | ||
981 | res->start, res->start + size - 1); | ||
977 | } | 982 | } |
978 | break; | 983 | break; |
979 | } | 984 | } |
@@ -1806,6 +1811,23 @@ void pci_iounmap(struct pci_dev *dev, void __iomem *addr) | |||
1806 | EXPORT_SYMBOL(pci_iomap); | 1811 | EXPORT_SYMBOL(pci_iomap); |
1807 | EXPORT_SYMBOL(pci_iounmap); | 1812 | EXPORT_SYMBOL(pci_iounmap); |
1808 | 1813 | ||
1814 | unsigned long pci_address_to_pio(phys_addr_t address) | ||
1815 | { | ||
1816 | struct pci_controller* hose = hose_head; | ||
1817 | |||
1818 | for (; hose; hose = hose->next) { | ||
1819 | unsigned int size = hose->io_resource.end - | ||
1820 | hose->io_resource.start + 1; | ||
1821 | if (address >= hose->io_base_phys && | ||
1822 | address < (hose->io_base_phys + size)) { | ||
1823 | unsigned long base = | ||
1824 | (unsigned long)hose->io_base_virt - _IO_BASE; | ||
1825 | return base + (address - hose->io_base_phys); | ||
1826 | } | ||
1827 | } | ||
1828 | return (unsigned int)-1; | ||
1829 | } | ||
1830 | EXPORT_SYMBOL(pci_address_to_pio); | ||
1809 | 1831 | ||
1810 | /* | 1832 | /* |
1811 | * Null PCI config access functions, for the case when we can't | 1833 | * Null PCI config access functions, for the case when we can't |