diff options
Diffstat (limited to 'arch/powerpc/kernel/pci-common.c')
-rw-r--r-- | arch/powerpc/kernel/pci-common.c | 45 |
1 files changed, 37 insertions, 8 deletions
diff --git a/arch/powerpc/kernel/pci-common.c b/arch/powerpc/kernel/pci-common.c index 0f4181272311..9c69e7e145c5 100644 --- a/arch/powerpc/kernel/pci-common.c +++ b/arch/powerpc/kernel/pci-common.c | |||
@@ -38,6 +38,7 @@ | |||
38 | #include <asm/eeh.h> | 38 | #include <asm/eeh.h> |
39 | 39 | ||
40 | static DEFINE_SPINLOCK(hose_spinlock); | 40 | static DEFINE_SPINLOCK(hose_spinlock); |
41 | LIST_HEAD(hose_list); | ||
41 | 42 | ||
42 | /* XXX kill that some day ... */ | 43 | /* XXX kill that some day ... */ |
43 | static int global_phb_number; /* Global phb counter */ | 44 | static int global_phb_number; /* Global phb counter */ |
@@ -49,7 +50,7 @@ resource_size_t isa_mem_base; | |||
49 | unsigned int ppc_pci_flags = 0; | 50 | unsigned int ppc_pci_flags = 0; |
50 | 51 | ||
51 | 52 | ||
52 | static struct dma_mapping_ops *pci_dma_ops; | 53 | static struct dma_mapping_ops *pci_dma_ops = &dma_direct_ops; |
53 | 54 | ||
54 | void set_pci_dma_ops(struct dma_mapping_ops *dma_ops) | 55 | void set_pci_dma_ops(struct dma_mapping_ops *dma_ops) |
55 | { | 56 | { |
@@ -113,19 +114,24 @@ void pcibios_free_controller(struct pci_controller *phb) | |||
113 | kfree(phb); | 114 | kfree(phb); |
114 | } | 115 | } |
115 | 116 | ||
117 | static resource_size_t pcibios_io_size(const struct pci_controller *hose) | ||
118 | { | ||
119 | #ifdef CONFIG_PPC64 | ||
120 | return hose->pci_io_size; | ||
121 | #else | ||
122 | return hose->io_resource.end - hose->io_resource.start + 1; | ||
123 | #endif | ||
124 | } | ||
125 | |||
116 | int pcibios_vaddr_is_ioport(void __iomem *address) | 126 | int pcibios_vaddr_is_ioport(void __iomem *address) |
117 | { | 127 | { |
118 | int ret = 0; | 128 | int ret = 0; |
119 | struct pci_controller *hose; | 129 | struct pci_controller *hose; |
120 | unsigned long size; | 130 | resource_size_t size; |
121 | 131 | ||
122 | spin_lock(&hose_spinlock); | 132 | spin_lock(&hose_spinlock); |
123 | list_for_each_entry(hose, &hose_list, list_node) { | 133 | list_for_each_entry(hose, &hose_list, list_node) { |
124 | #ifdef CONFIG_PPC64 | 134 | size = pcibios_io_size(hose); |
125 | size = hose->pci_io_size; | ||
126 | #else | ||
127 | size = hose->io_resource.end - hose->io_resource.start + 1; | ||
128 | #endif | ||
129 | if (address >= hose->io_base_virt && | 135 | if (address >= hose->io_base_virt && |
130 | address < (hose->io_base_virt + size)) { | 136 | address < (hose->io_base_virt + size)) { |
131 | ret = 1; | 137 | ret = 1; |
@@ -136,6 +142,29 @@ int pcibios_vaddr_is_ioport(void __iomem *address) | |||
136 | return ret; | 142 | return ret; |
137 | } | 143 | } |
138 | 144 | ||
145 | unsigned long pci_address_to_pio(phys_addr_t address) | ||
146 | { | ||
147 | struct pci_controller *hose; | ||
148 | resource_size_t size; | ||
149 | unsigned long ret = ~0; | ||
150 | |||
151 | spin_lock(&hose_spinlock); | ||
152 | list_for_each_entry(hose, &hose_list, list_node) { | ||
153 | size = pcibios_io_size(hose); | ||
154 | if (address >= hose->io_base_phys && | ||
155 | address < (hose->io_base_phys + size)) { | ||
156 | unsigned long base = | ||
157 | (unsigned long)hose->io_base_virt - _IO_BASE; | ||
158 | ret = base + (address - hose->io_base_phys); | ||
159 | break; | ||
160 | } | ||
161 | } | ||
162 | spin_unlock(&hose_spinlock); | ||
163 | |||
164 | return ret; | ||
165 | } | ||
166 | EXPORT_SYMBOL_GPL(pci_address_to_pio); | ||
167 | |||
139 | /* | 168 | /* |
140 | * Return the domain number for this bus. | 169 | * Return the domain number for this bus. |
141 | */ | 170 | */ |
@@ -1453,7 +1482,7 @@ void __init pcibios_resource_survey(void) | |||
1453 | * we proceed to assigning things that were left unassigned | 1482 | * we proceed to assigning things that were left unassigned |
1454 | */ | 1483 | */ |
1455 | if (!(ppc_pci_flags & PPC_PCI_PROBE_ONLY)) { | 1484 | if (!(ppc_pci_flags & PPC_PCI_PROBE_ONLY)) { |
1456 | pr_debug("PCI: Assigning unassigned resouces...\n"); | 1485 | pr_debug("PCI: Assigning unassigned resources...\n"); |
1457 | pci_assign_unassigned_resources(); | 1486 | pci_assign_unassigned_resources(); |
1458 | } | 1487 | } |
1459 | 1488 | ||