diff options
Diffstat (limited to 'arch/ia64/sn')
-rw-r--r-- | arch/ia64/sn/pci/pci_dma.c | 64 |
1 files changed, 26 insertions, 38 deletions
diff --git a/arch/ia64/sn/pci/pci_dma.c b/arch/ia64/sn/pci/pci_dma.c index 174a74e63882..efdd69490009 100644 --- a/arch/ia64/sn/pci/pci_dma.c +++ b/arch/ia64/sn/pci/pci_dma.c | |||
@@ -32,7 +32,7 @@ | |||
32 | * this function. Of course, SN only supports devices that have 32 or more | 32 | * this function. Of course, SN only supports devices that have 32 or more |
33 | * address bits when using the PMU. | 33 | * address bits when using the PMU. |
34 | */ | 34 | */ |
35 | int sn_dma_supported(struct device *dev, u64 mask) | 35 | static int sn_dma_supported(struct device *dev, u64 mask) |
36 | { | 36 | { |
37 | BUG_ON(dev->bus != &pci_bus_type); | 37 | BUG_ON(dev->bus != &pci_bus_type); |
38 | 38 | ||
@@ -40,7 +40,6 @@ int sn_dma_supported(struct device *dev, u64 mask) | |||
40 | return 0; | 40 | return 0; |
41 | return 1; | 41 | return 1; |
42 | } | 42 | } |
43 | EXPORT_SYMBOL(sn_dma_supported); | ||
44 | 43 | ||
45 | /** | 44 | /** |
46 | * sn_dma_set_mask - set the DMA mask | 45 | * sn_dma_set_mask - set the DMA mask |
@@ -76,8 +75,8 @@ EXPORT_SYMBOL(sn_dma_set_mask); | |||
76 | * queue for a SCSI controller). See Documentation/DMA-API.txt for | 75 | * queue for a SCSI controller). See Documentation/DMA-API.txt for |
77 | * more information. | 76 | * more information. |
78 | */ | 77 | */ |
79 | void *sn_dma_alloc_coherent(struct device *dev, size_t size, | 78 | static void *sn_dma_alloc_coherent(struct device *dev, size_t size, |
80 | dma_addr_t * dma_handle, gfp_t flags) | 79 | dma_addr_t * dma_handle, gfp_t flags) |
81 | { | 80 | { |
82 | void *cpuaddr; | 81 | void *cpuaddr; |
83 | unsigned long phys_addr; | 82 | unsigned long phys_addr; |
@@ -125,7 +124,6 @@ void *sn_dma_alloc_coherent(struct device *dev, size_t size, | |||
125 | 124 | ||
126 | return cpuaddr; | 125 | return cpuaddr; |
127 | } | 126 | } |
128 | EXPORT_SYMBOL(sn_dma_alloc_coherent); | ||
129 | 127 | ||
130 | /** | 128 | /** |
131 | * sn_pci_free_coherent - free memory associated with coherent DMAable region | 129 | * sn_pci_free_coherent - free memory associated with coherent DMAable region |
@@ -137,8 +135,8 @@ EXPORT_SYMBOL(sn_dma_alloc_coherent); | |||
137 | * Frees the memory allocated by dma_alloc_coherent(), potentially unmapping | 135 | * Frees the memory allocated by dma_alloc_coherent(), potentially unmapping |
138 | * any associated IOMMU mappings. | 136 | * any associated IOMMU mappings. |
139 | */ | 137 | */ |
140 | void sn_dma_free_coherent(struct device *dev, size_t size, void *cpu_addr, | 138 | static void sn_dma_free_coherent(struct device *dev, size_t size, void *cpu_addr, |
141 | dma_addr_t dma_handle) | 139 | dma_addr_t dma_handle) |
142 | { | 140 | { |
143 | struct pci_dev *pdev = to_pci_dev(dev); | 141 | struct pci_dev *pdev = to_pci_dev(dev); |
144 | struct sn_pcibus_provider *provider = SN_PCIDEV_BUSPROVIDER(pdev); | 142 | struct sn_pcibus_provider *provider = SN_PCIDEV_BUSPROVIDER(pdev); |
@@ -148,7 +146,6 @@ void sn_dma_free_coherent(struct device *dev, size_t size, void *cpu_addr, | |||
148 | provider->dma_unmap(pdev, dma_handle, 0); | 146 | provider->dma_unmap(pdev, dma_handle, 0); |
149 | free_pages((unsigned long)cpu_addr, get_order(size)); | 147 | free_pages((unsigned long)cpu_addr, get_order(size)); |
150 | } | 148 | } |
151 | EXPORT_SYMBOL(sn_dma_free_coherent); | ||
152 | 149 | ||
153 | /** | 150 | /** |
154 | * sn_dma_map_single_attrs - map a single page for DMA | 151 | * sn_dma_map_single_attrs - map a single page for DMA |
@@ -174,9 +171,9 @@ EXPORT_SYMBOL(sn_dma_free_coherent); | |||
174 | * TODO: simplify our interface; | 171 | * TODO: simplify our interface; |
175 | * figure out how to save dmamap handle so can use two step. | 172 | * figure out how to save dmamap handle so can use two step. |
176 | */ | 173 | */ |
177 | dma_addr_t sn_dma_map_single_attrs(struct device *dev, void *cpu_addr, | 174 | static dma_addr_t sn_dma_map_single_attrs(struct device *dev, void *cpu_addr, |
178 | size_t size, int direction, | 175 | size_t size, int direction, |
179 | struct dma_attrs *attrs) | 176 | struct dma_attrs *attrs) |
180 | { | 177 | { |
181 | dma_addr_t dma_addr; | 178 | dma_addr_t dma_addr; |
182 | unsigned long phys_addr; | 179 | unsigned long phys_addr; |
@@ -202,7 +199,6 @@ dma_addr_t sn_dma_map_single_attrs(struct device *dev, void *cpu_addr, | |||
202 | } | 199 | } |
203 | return dma_addr; | 200 | return dma_addr; |
204 | } | 201 | } |
205 | EXPORT_SYMBOL(sn_dma_map_single_attrs); | ||
206 | 202 | ||
207 | /** | 203 | /** |
208 | * sn_dma_unmap_single_attrs - unamp a DMA mapped page | 204 | * sn_dma_unmap_single_attrs - unamp a DMA mapped page |
@@ -216,9 +212,9 @@ EXPORT_SYMBOL(sn_dma_map_single_attrs); | |||
216 | * by @dma_handle into the coherence domain. On SN, we're always cache | 212 | * by @dma_handle into the coherence domain. On SN, we're always cache |
217 | * coherent, so we just need to free any ATEs associated with this mapping. | 213 | * coherent, so we just need to free any ATEs associated with this mapping. |
218 | */ | 214 | */ |
219 | void sn_dma_unmap_single_attrs(struct device *dev, dma_addr_t dma_addr, | 215 | static void sn_dma_unmap_single_attrs(struct device *dev, dma_addr_t dma_addr, |
220 | size_t size, int direction, | 216 | size_t size, int direction, |
221 | struct dma_attrs *attrs) | 217 | struct dma_attrs *attrs) |
222 | { | 218 | { |
223 | struct pci_dev *pdev = to_pci_dev(dev); | 219 | struct pci_dev *pdev = to_pci_dev(dev); |
224 | struct sn_pcibus_provider *provider = SN_PCIDEV_BUSPROVIDER(pdev); | 220 | struct sn_pcibus_provider *provider = SN_PCIDEV_BUSPROVIDER(pdev); |
@@ -227,7 +223,6 @@ void sn_dma_unmap_single_attrs(struct device *dev, dma_addr_t dma_addr, | |||
227 | 223 | ||
228 | provider->dma_unmap(pdev, dma_addr, direction); | 224 | provider->dma_unmap(pdev, dma_addr, direction); |
229 | } | 225 | } |
230 | EXPORT_SYMBOL(sn_dma_unmap_single_attrs); | ||
231 | 226 | ||
232 | /** | 227 | /** |
233 | * sn_dma_unmap_sg_attrs - unmap a DMA scatterlist | 228 | * sn_dma_unmap_sg_attrs - unmap a DMA scatterlist |
@@ -239,9 +234,9 @@ EXPORT_SYMBOL(sn_dma_unmap_single_attrs); | |||
239 | * | 234 | * |
240 | * Unmap a set of streaming mode DMA translations. | 235 | * Unmap a set of streaming mode DMA translations. |
241 | */ | 236 | */ |
242 | void sn_dma_unmap_sg_attrs(struct device *dev, struct scatterlist *sgl, | 237 | static void sn_dma_unmap_sg_attrs(struct device *dev, struct scatterlist *sgl, |
243 | int nhwentries, int direction, | 238 | int nhwentries, int direction, |
244 | struct dma_attrs *attrs) | 239 | struct dma_attrs *attrs) |
245 | { | 240 | { |
246 | int i; | 241 | int i; |
247 | struct pci_dev *pdev = to_pci_dev(dev); | 242 | struct pci_dev *pdev = to_pci_dev(dev); |
@@ -256,7 +251,6 @@ void sn_dma_unmap_sg_attrs(struct device *dev, struct scatterlist *sgl, | |||
256 | sg->dma_length = 0; | 251 | sg->dma_length = 0; |
257 | } | 252 | } |
258 | } | 253 | } |
259 | EXPORT_SYMBOL(sn_dma_unmap_sg_attrs); | ||
260 | 254 | ||
261 | /** | 255 | /** |
262 | * sn_dma_map_sg_attrs - map a scatterlist for DMA | 256 | * sn_dma_map_sg_attrs - map a scatterlist for DMA |
@@ -273,8 +267,8 @@ EXPORT_SYMBOL(sn_dma_unmap_sg_attrs); | |||
273 | * | 267 | * |
274 | * Maps each entry of @sg for DMA. | 268 | * Maps each entry of @sg for DMA. |
275 | */ | 269 | */ |
276 | int sn_dma_map_sg_attrs(struct device *dev, struct scatterlist *sgl, | 270 | static int sn_dma_map_sg_attrs(struct device *dev, struct scatterlist *sgl, |
277 | int nhwentries, int direction, struct dma_attrs *attrs) | 271 | int nhwentries, int direction, struct dma_attrs *attrs) |
278 | { | 272 | { |
279 | unsigned long phys_addr; | 273 | unsigned long phys_addr; |
280 | struct scatterlist *saved_sg = sgl, *sg; | 274 | struct scatterlist *saved_sg = sgl, *sg; |
@@ -321,41 +315,35 @@ int sn_dma_map_sg_attrs(struct device *dev, struct scatterlist *sgl, | |||
321 | 315 | ||
322 | return nhwentries; | 316 | return nhwentries; |
323 | } | 317 | } |
324 | EXPORT_SYMBOL(sn_dma_map_sg_attrs); | ||
325 | 318 | ||
326 | void sn_dma_sync_single_for_cpu(struct device *dev, dma_addr_t dma_handle, | 319 | static void sn_dma_sync_single_for_cpu(struct device *dev, dma_addr_t dma_handle, |
327 | size_t size, int direction) | 320 | size_t size, int direction) |
328 | { | 321 | { |
329 | BUG_ON(dev->bus != &pci_bus_type); | 322 | BUG_ON(dev->bus != &pci_bus_type); |
330 | } | 323 | } |
331 | EXPORT_SYMBOL(sn_dma_sync_single_for_cpu); | ||
332 | 324 | ||
333 | void sn_dma_sync_single_for_device(struct device *dev, dma_addr_t dma_handle, | 325 | static void sn_dma_sync_single_for_device(struct device *dev, dma_addr_t dma_handle, |
334 | size_t size, int direction) | 326 | size_t size, int direction) |
335 | { | 327 | { |
336 | BUG_ON(dev->bus != &pci_bus_type); | 328 | BUG_ON(dev->bus != &pci_bus_type); |
337 | } | 329 | } |
338 | EXPORT_SYMBOL(sn_dma_sync_single_for_device); | ||
339 | 330 | ||
340 | void sn_dma_sync_sg_for_cpu(struct device *dev, struct scatterlist *sg, | 331 | static void sn_dma_sync_sg_for_cpu(struct device *dev, struct scatterlist *sg, |
341 | int nelems, int direction) | 332 | int nelems, int direction) |
342 | { | 333 | { |
343 | BUG_ON(dev->bus != &pci_bus_type); | 334 | BUG_ON(dev->bus != &pci_bus_type); |
344 | } | 335 | } |
345 | EXPORT_SYMBOL(sn_dma_sync_sg_for_cpu); | ||
346 | 336 | ||
347 | void sn_dma_sync_sg_for_device(struct device *dev, struct scatterlist *sg, | 337 | static void sn_dma_sync_sg_for_device(struct device *dev, struct scatterlist *sg, |
348 | int nelems, int direction) | 338 | int nelems, int direction) |
349 | { | 339 | { |
350 | BUG_ON(dev->bus != &pci_bus_type); | 340 | BUG_ON(dev->bus != &pci_bus_type); |
351 | } | 341 | } |
352 | EXPORT_SYMBOL(sn_dma_sync_sg_for_device); | ||
353 | 342 | ||
354 | int sn_dma_mapping_error(struct device *dev, dma_addr_t dma_addr) | 343 | static int sn_dma_mapping_error(struct device *dev, dma_addr_t dma_addr) |
355 | { | 344 | { |
356 | return 0; | 345 | return 0; |
357 | } | 346 | } |
358 | EXPORT_SYMBOL(sn_dma_mapping_error); | ||
359 | 347 | ||
360 | char *sn_pci_get_legacy_mem(struct pci_bus *bus) | 348 | char *sn_pci_get_legacy_mem(struct pci_bus *bus) |
361 | { | 349 | { |
@@ -467,7 +455,7 @@ int sn_pci_legacy_write(struct pci_bus *bus, u16 port, u32 val, u8 size) | |||
467 | return ret; | 455 | return ret; |
468 | } | 456 | } |
469 | 457 | ||
470 | struct dma_mapping_ops sn_dma_ops = { | 458 | static struct dma_mapping_ops sn_dma_ops = { |
471 | .alloc_coherent = sn_dma_alloc_coherent, | 459 | .alloc_coherent = sn_dma_alloc_coherent, |
472 | .free_coherent = sn_dma_free_coherent, | 460 | .free_coherent = sn_dma_free_coherent, |
473 | .map_single_attrs = sn_dma_map_single_attrs, | 461 | .map_single_attrs = sn_dma_map_single_attrs, |