2 * linux/arch/alpha/kernel/pci_iommu.c
5 #include <linux/kernel.h>
8 #include <linux/slab.h>
9 #include <linux/bootmem.h>
10 #include <linux/scatterlist.h>
11 #include <linux/log2.h>
12 #include <linux/dma-mapping.h>
15 #include <asm/hwrpb.h>
23 # define DBGA(args...) printk(KERN_DEBUG args)
25 # define DBGA(args...)
28 # define DBGA2(args...) printk(KERN_DEBUG args)
30 # define DBGA2(args...)
33 #define DEBUG_NODIRECT 0
34 #define DEBUG_FORCEDAC 0
36 #define ISA_DMA_MASK 0x00ffffff
38 static inline unsigned long
39 mk_iommu_pte(unsigned long paddr
)
41 return (paddr
>> (PAGE_SHIFT
-1)) | 1;
45 calc_npages(long bytes
)
47 return (bytes
+ PAGE_SIZE
- 1) >> PAGE_SHIFT
;
51 /* Return the minimum of MAX or the first power of two larger
55 size_for_memory(unsigned long max
)
57 unsigned long mem
= max_low_pfn
<< PAGE_SHIFT
;
59 max
= roundup_pow_of_two(mem
);
63 struct pci_iommu_arena
* __init
64 iommu_arena_new_node(int nid
, struct pci_controller
*hose
, dma_addr_t base
,
65 unsigned long window_size
, unsigned long align
)
67 unsigned long mem_size
;
68 struct pci_iommu_arena
*arena
;
70 mem_size
= window_size
/ (PAGE_SIZE
/ sizeof(unsigned long));
72 /* Note that the TLB lookup logic uses bitwise concatenation,
73 not addition, so the required arena alignment is based on
74 the size of the window. Retain the align parameter so that
75 particular systems can over-align the arena. */
80 #ifdef CONFIG_DISCONTIGMEM
82 if (!NODE_DATA(nid
) ||
83 (NULL
== (arena
= alloc_bootmem_node(NODE_DATA(nid
),
85 printk("%s: couldn't allocate arena from node %d\n"
86 " falling back to system-wide allocation\n",
88 arena
= alloc_bootmem(sizeof(*arena
));
91 if (!NODE_DATA(nid
) ||
92 (NULL
== (arena
->ptes
= __alloc_bootmem_node(NODE_DATA(nid
),
96 printk("%s: couldn't allocate arena ptes from node %d\n"
97 " falling back to system-wide allocation\n",
99 arena
->ptes
= __alloc_bootmem(mem_size
, align
, 0);
102 #else /* CONFIG_DISCONTIGMEM */
104 arena
= alloc_bootmem(sizeof(*arena
));
105 arena
->ptes
= __alloc_bootmem(mem_size
, align
, 0);
107 #endif /* CONFIG_DISCONTIGMEM */
109 spin_lock_init(&arena
->lock
);
111 arena
->dma_base
= base
;
112 arena
->size
= window_size
;
113 arena
->next_entry
= 0;
115 /* Align allocations to a multiple of a page size. Not needed
116 unless there are chip bugs. */
117 arena
->align_entry
= 1;
122 struct pci_iommu_arena
* __init
123 iommu_arena_new(struct pci_controller
*hose
, dma_addr_t base
,
124 unsigned long window_size
, unsigned long align
)
126 return iommu_arena_new_node(0, hose
, base
, window_size
, align
);
129 /* Must be called with the arena lock held */
131 iommu_arena_find_pages(struct pci_iommu_arena
*arena
, long n
, long mask
)
136 /* Search forward for the first mask-aligned sequence of N free ptes */
138 nent
= arena
->size
>> PAGE_SHIFT
;
139 p
= (arena
->next_entry
+ mask
) & ~mask
;
141 while (i
< n
&& p
+i
< nent
) {
143 p
= (p
+ i
+ 1 + mask
) & ~mask
, i
= 0;
149 /* Reached the end. Flush the TLB and restart the
150 search from the beginning. */
151 alpha_mv
.mv_pci_tbi(arena
->hose
, 0, -1);
154 while (i
< n
&& p
+i
< nent
) {
156 p
= (p
+ i
+ 1 + mask
) & ~mask
, i
= 0;
165 /* Success. It's the responsibility of the caller to mark them
166 in use before releasing the lock */
171 iommu_arena_alloc(struct pci_iommu_arena
*arena
, long n
, unsigned int align
)
177 spin_lock_irqsave(&arena
->lock
, flags
);
179 /* Search for N empty ptes */
181 mask
= max(align
, arena
->align_entry
) - 1;
182 p
= iommu_arena_find_pages(arena
, n
, mask
);
184 spin_unlock_irqrestore(&arena
->lock
, flags
);
188 /* Success. Mark them all in use, ie not zero and invalid
189 for the iommu tlb that could load them from under us.
190 The chip specific bits will fill this in with something
191 kosher when we return. */
192 for (i
= 0; i
< n
; ++i
)
193 ptes
[p
+i
] = IOMMU_INVALID_PTE
;
195 arena
->next_entry
= p
+ n
;
196 spin_unlock_irqrestore(&arena
->lock
, flags
);
202 iommu_arena_free(struct pci_iommu_arena
*arena
, long ofs
, long n
)
207 p
= arena
->ptes
+ ofs
;
208 for (i
= 0; i
< n
; ++i
)
212 /* True if the machine supports DAC addressing, and DEV can
213 make use of it given MASK. */
214 static int pci_dac_dma_supported(struct pci_dev
*hwdev
, u64 mask
);
216 /* Map a single buffer of the indicated size for PCI DMA in streaming
217 mode. The 32-bit PCI bus mastering address to use is returned.
218 Once the device is given the dma address, the device owns this memory
219 until either pci_unmap_single or pci_dma_sync_single is performed. */
222 pci_map_single_1(struct pci_dev
*pdev
, void *cpu_addr
, size_t size
,
225 struct pci_controller
*hose
= pdev
? pdev
->sysdata
: pci_isa_hose
;
226 dma_addr_t max_dma
= pdev
? pdev
->dma_mask
: ISA_DMA_MASK
;
227 struct pci_iommu_arena
*arena
;
228 long npages
, dma_ofs
, i
;
231 unsigned int align
= 0;
233 paddr
= __pa(cpu_addr
);
236 /* First check to see if we can use the direct map window. */
237 if (paddr
+ size
+ __direct_map_base
- 1 <= max_dma
238 && paddr
+ size
<= __direct_map_size
) {
239 ret
= paddr
+ __direct_map_base
;
241 DBGA2("pci_map_single: [%p,%lx] -> direct %lx from %p\n",
242 cpu_addr
, size
, ret
, __builtin_return_address(0));
248 /* Next, use DAC if selected earlier. */
250 ret
= paddr
+ alpha_mv
.pci_dac_offset
;
252 DBGA2("pci_map_single: [%p,%lx] -> DAC %lx from %p\n",
253 cpu_addr
, size
, ret
, __builtin_return_address(0));
258 /* If the machine doesn't define a pci_tbi routine, we have to
259 assume it doesn't support sg mapping, and, since we tried to
260 use direct_map above, it now must be considered an error. */
261 if (! alpha_mv
.mv_pci_tbi
) {
262 static int been_here
= 0; /* Only print the message once. */
264 printk(KERN_WARNING
"pci_map_single: no HW sg\n");
270 arena
= hose
->sg_pci
;
271 if (!arena
|| arena
->dma_base
+ arena
->size
- 1 > max_dma
)
272 arena
= hose
->sg_isa
;
274 npages
= calc_npages((paddr
& ~PAGE_MASK
) + size
);
276 /* Force allocation to 64KB boundary for ISA bridges. */
277 if (pdev
&& pdev
== isa_bridge
)
279 dma_ofs
= iommu_arena_alloc(arena
, npages
, align
);
281 printk(KERN_WARNING
"pci_map_single failed: "
282 "could not allocate dma page tables\n");
287 for (i
= 0; i
< npages
; ++i
, paddr
+= PAGE_SIZE
)
288 arena
->ptes
[i
+ dma_ofs
] = mk_iommu_pte(paddr
);
290 ret
= arena
->dma_base
+ dma_ofs
* PAGE_SIZE
;
291 ret
+= (unsigned long)cpu_addr
& ~PAGE_MASK
;
293 DBGA2("pci_map_single: [%p,%lx] np %ld -> sg %lx from %p\n",
294 cpu_addr
, size
, npages
, ret
, __builtin_return_address(0));
300 pci_map_single(struct pci_dev
*pdev
, void *cpu_addr
, size_t size
, int dir
)
304 if (dir
== PCI_DMA_NONE
)
307 dac_allowed
= pdev
? pci_dac_dma_supported(pdev
, pdev
->dma_mask
) : 0;
308 return pci_map_single_1(pdev
, cpu_addr
, size
, dac_allowed
);
310 EXPORT_SYMBOL(pci_map_single
);
313 pci_map_page(struct pci_dev
*pdev
, struct page
*page
, unsigned long offset
,
314 size_t size
, int dir
)
318 if (dir
== PCI_DMA_NONE
)
321 dac_allowed
= pdev
? pci_dac_dma_supported(pdev
, pdev
->dma_mask
) : 0;
322 return pci_map_single_1(pdev
, (char *)page_address(page
) + offset
,
325 EXPORT_SYMBOL(pci_map_page
);
327 /* Unmap a single streaming mode DMA translation. The DMA_ADDR and
328 SIZE must match what was provided for in a previous pci_map_single
329 call. All other usages are undefined. After this call, reads by
330 the cpu to the buffer are guaranteed to see whatever the device
334 pci_unmap_single(struct pci_dev
*pdev
, dma_addr_t dma_addr
, size_t size
,
338 struct pci_controller
*hose
= pdev
? pdev
->sysdata
: pci_isa_hose
;
339 struct pci_iommu_arena
*arena
;
340 long dma_ofs
, npages
;
342 if (direction
== PCI_DMA_NONE
)
345 if (dma_addr
>= __direct_map_base
346 && dma_addr
< __direct_map_base
+ __direct_map_size
) {
349 DBGA2("pci_unmap_single: direct [%lx,%lx] from %p\n",
350 dma_addr
, size
, __builtin_return_address(0));
355 if (dma_addr
> 0xffffffff) {
356 DBGA2("pci64_unmap_single: DAC [%lx,%lx] from %p\n",
357 dma_addr
, size
, __builtin_return_address(0));
361 arena
= hose
->sg_pci
;
362 if (!arena
|| dma_addr
< arena
->dma_base
)
363 arena
= hose
->sg_isa
;
365 dma_ofs
= (dma_addr
- arena
->dma_base
) >> PAGE_SHIFT
;
366 if (dma_ofs
* PAGE_SIZE
>= arena
->size
) {
367 printk(KERN_ERR
"Bogus pci_unmap_single: dma_addr %lx "
368 " base %lx size %x\n", dma_addr
, arena
->dma_base
,
374 npages
= calc_npages((dma_addr
& ~PAGE_MASK
) + size
);
376 spin_lock_irqsave(&arena
->lock
, flags
);
378 iommu_arena_free(arena
, dma_ofs
, npages
);
380 /* If we're freeing ptes above the `next_entry' pointer (they
381 may have snuck back into the TLB since the last wrap flush),
382 we need to flush the TLB before reallocating the latter. */
383 if (dma_ofs
>= arena
->next_entry
)
384 alpha_mv
.mv_pci_tbi(hose
, dma_addr
, dma_addr
+ size
- 1);
386 spin_unlock_irqrestore(&arena
->lock
, flags
);
388 DBGA2("pci_unmap_single: sg [%lx,%lx] np %ld from %p\n",
389 dma_addr
, size
, npages
, __builtin_return_address(0));
391 EXPORT_SYMBOL(pci_unmap_single
);
394 pci_unmap_page(struct pci_dev
*pdev
, dma_addr_t dma_addr
,
395 size_t size
, int direction
)
397 pci_unmap_single(pdev
, dma_addr
, size
, direction
);
399 EXPORT_SYMBOL(pci_unmap_page
);
401 /* Allocate and map kernel buffer using consistent mode DMA for PCI
402 device. Returns non-NULL cpu-view pointer to the buffer if
403 successful and sets *DMA_ADDRP to the pci side dma address as well,
404 else DMA_ADDRP is undefined. */
407 pci_alloc_consistent(struct pci_dev
*pdev
, size_t size
, dma_addr_t
*dma_addrp
)
410 long order
= get_order(size
);
411 gfp_t gfp
= GFP_ATOMIC
;
414 cpu_addr
= (void *)__get_free_pages(gfp
, order
);
416 printk(KERN_INFO
"pci_alloc_consistent: "
417 "get_free_pages failed from %p\n",
418 __builtin_return_address(0));
419 /* ??? Really atomic allocation? Otherwise we could play
420 with vmalloc and sg if we can't find contiguous memory. */
423 memset(cpu_addr
, 0, size
);
425 *dma_addrp
= pci_map_single_1(pdev
, cpu_addr
, size
, 0);
426 if (*dma_addrp
== 0) {
427 free_pages((unsigned long)cpu_addr
, order
);
428 if (alpha_mv
.mv_pci_tbi
|| (gfp
& GFP_DMA
))
430 /* The address doesn't fit required mask and we
431 do not have iommu. Try again with GFP_DMA. */
436 DBGA2("pci_alloc_consistent: %lx -> [%p,%x] from %p\n",
437 size
, cpu_addr
, *dma_addrp
, __builtin_return_address(0));
441 EXPORT_SYMBOL(pci_alloc_consistent
);
443 /* Free and unmap a consistent DMA buffer. CPU_ADDR and DMA_ADDR must
444 be values that were returned from pci_alloc_consistent. SIZE must
445 be the same as what as passed into pci_alloc_consistent.
446 References to the memory and mappings associated with CPU_ADDR or
447 DMA_ADDR past this call are illegal. */
450 pci_free_consistent(struct pci_dev
*pdev
, size_t size
, void *cpu_addr
,
453 pci_unmap_single(pdev
, dma_addr
, size
, PCI_DMA_BIDIRECTIONAL
);
454 free_pages((unsigned long)cpu_addr
, get_order(size
));
456 DBGA2("pci_free_consistent: [%x,%lx] from %p\n",
457 dma_addr
, size
, __builtin_return_address(0));
459 EXPORT_SYMBOL(pci_free_consistent
);
461 /* Classify the elements of the scatterlist. Write dma_address
462 of each element with:
463 0 : Followers all physically adjacent.
464 1 : Followers all virtually adjacent.
465 -1 : Not leader, physically adjacent to previous.
466 -2 : Not leader, virtually adjacent to previous.
467 Write dma_length of each leader with the combined lengths of
468 the mergable followers. */
470 #define SG_ENT_VIRT_ADDRESS(SG) (sg_virt((SG)))
471 #define SG_ENT_PHYS_ADDRESS(SG) __pa(SG_ENT_VIRT_ADDRESS(SG))
474 sg_classify(struct device
*dev
, struct scatterlist
*sg
, struct scatterlist
*end
,
477 unsigned long next_paddr
;
478 struct scatterlist
*leader
;
479 long leader_flag
, leader_length
;
480 unsigned int max_seg_size
;
484 leader_length
= leader
->length
;
485 next_paddr
= SG_ENT_PHYS_ADDRESS(leader
) + leader_length
;
487 /* we will not marge sg without device. */
488 max_seg_size
= dev
? dma_get_max_seg_size(dev
) : 0;
489 for (++sg
; sg
< end
; ++sg
) {
490 unsigned long addr
, len
;
491 addr
= SG_ENT_PHYS_ADDRESS(sg
);
494 if (leader_length
+ len
> max_seg_size
)
497 if (next_paddr
== addr
) {
498 sg
->dma_address
= -1;
499 leader_length
+= len
;
500 } else if (((next_paddr
| addr
) & ~PAGE_MASK
) == 0 && virt_ok
) {
501 sg
->dma_address
= -2;
503 leader_length
+= len
;
506 leader
->dma_address
= leader_flag
;
507 leader
->dma_length
= leader_length
;
513 next_paddr
= addr
+ len
;
516 leader
->dma_address
= leader_flag
;
517 leader
->dma_length
= leader_length
;
520 /* Given a scatterlist leader, choose an allocation method and fill
524 sg_fill(struct device
*dev
, struct scatterlist
*leader
, struct scatterlist
*end
,
525 struct scatterlist
*out
, struct pci_iommu_arena
*arena
,
526 dma_addr_t max_dma
, int dac_allowed
)
528 unsigned long paddr
= SG_ENT_PHYS_ADDRESS(leader
);
529 long size
= leader
->dma_length
;
530 struct scatterlist
*sg
;
532 long npages
, dma_ofs
, i
;
535 /* If everything is physically contiguous, and the addresses
536 fall into the direct-map window, use it. */
537 if (leader
->dma_address
== 0
538 && paddr
+ size
+ __direct_map_base
- 1 <= max_dma
539 && paddr
+ size
<= __direct_map_size
) {
540 out
->dma_address
= paddr
+ __direct_map_base
;
541 out
->dma_length
= size
;
543 DBGA(" sg_fill: [%p,%lx] -> direct %lx\n",
544 __va(paddr
), size
, out
->dma_address
);
550 /* If physically contiguous and DAC is available, use it. */
551 if (leader
->dma_address
== 0 && dac_allowed
) {
552 out
->dma_address
= paddr
+ alpha_mv
.pci_dac_offset
;
553 out
->dma_length
= size
;
555 DBGA(" sg_fill: [%p,%lx] -> DAC %lx\n",
556 __va(paddr
), size
, out
->dma_address
);
561 /* Otherwise, we'll use the iommu to make the pages virtually
565 npages
= calc_npages(paddr
+ size
);
566 dma_ofs
= iommu_arena_alloc(arena
, npages
, 0);
568 /* If we attempted a direct map above but failed, die. */
569 if (leader
->dma_address
== 0)
572 /* Otherwise, break up the remaining virtually contiguous
573 hunks into individual direct maps and retry. */
574 sg_classify(dev
, leader
, end
, 0);
575 return sg_fill(dev
, leader
, end
, out
, arena
, max_dma
, dac_allowed
);
578 out
->dma_address
= arena
->dma_base
+ dma_ofs
*PAGE_SIZE
+ paddr
;
579 out
->dma_length
= size
;
581 DBGA(" sg_fill: [%p,%lx] -> sg %lx np %ld\n",
582 __va(paddr
), size
, out
->dma_address
, npages
);
584 /* All virtually contiguous. We need to find the length of each
585 physically contiguous subsegment to fill in the ptes. */
586 ptes
= &arena
->ptes
[dma_ofs
];
590 struct scatterlist
*last_sg
= sg
;
594 paddr
= SG_ENT_PHYS_ADDRESS(sg
);
596 while (sg
+1 < end
&& (int) sg
[1].dma_address
== -1) {
597 size
+= sg
[1].length
;
601 npages
= calc_npages((paddr
& ~PAGE_MASK
) + size
);
604 for (i
= 0; i
< npages
; ++i
, paddr
+= PAGE_SIZE
)
605 *ptes
++ = mk_iommu_pte(paddr
);
608 DBGA(" (%ld) [%p,%x] np %ld\n",
609 last_sg
- leader
, SG_ENT_VIRT_ADDRESS(last_sg
),
610 last_sg
->length
, npages
);
611 while (++last_sg
<= sg
) {
612 DBGA(" (%ld) [%p,%x] cont\n",
613 last_sg
- leader
, SG_ENT_VIRT_ADDRESS(last_sg
),
617 } while (++sg
< end
&& (int) sg
->dma_address
< 0);
623 pci_map_sg(struct pci_dev
*pdev
, struct scatterlist
*sg
, int nents
,
626 struct scatterlist
*start
, *end
, *out
;
627 struct pci_controller
*hose
;
628 struct pci_iommu_arena
*arena
;
633 if (direction
== PCI_DMA_NONE
)
636 dac_allowed
= pdev
? pci_dac_dma_supported(pdev
, pdev
->dma_mask
) : 0;
638 dev
= pdev
? &pdev
->dev
: NULL
;
640 /* Fast path single entry scatterlists. */
642 sg
->dma_length
= sg
->length
;
644 = pci_map_single_1(pdev
, SG_ENT_VIRT_ADDRESS(sg
),
645 sg
->length
, dac_allowed
);
646 return sg
->dma_address
!= 0;
652 /* First, prepare information about the entries. */
653 sg_classify(dev
, sg
, end
, alpha_mv
.mv_pci_tbi
!= 0);
655 /* Second, figure out where we're going to map things. */
656 if (alpha_mv
.mv_pci_tbi
) {
657 hose
= pdev
? pdev
->sysdata
: pci_isa_hose
;
658 max_dma
= pdev
? pdev
->dma_mask
: ISA_DMA_MASK
;
659 arena
= hose
->sg_pci
;
660 if (!arena
|| arena
->dma_base
+ arena
->size
- 1 > max_dma
)
661 arena
= hose
->sg_isa
;
668 /* Third, iterate over the scatterlist leaders and allocate
669 dma space as needed. */
670 for (out
= sg
; sg
< end
; ++sg
) {
671 if ((int) sg
->dma_address
< 0)
673 if (sg_fill(dev
, sg
, end
, out
, arena
, max_dma
, dac_allowed
) < 0)
678 /* Mark the end of the list for pci_unmap_sg. */
682 if (out
- start
== 0)
683 printk(KERN_WARNING
"pci_map_sg failed: no entries?\n");
684 DBGA("pci_map_sg: %ld entries\n", out
- start
);
689 printk(KERN_WARNING
"pci_map_sg failed: "
690 "could not allocate dma page tables\n");
692 /* Some allocation failed while mapping the scatterlist
693 entries. Unmap them now. */
695 pci_unmap_sg(pdev
, start
, out
- start
, direction
);
698 EXPORT_SYMBOL(pci_map_sg
);
700 /* Unmap a set of streaming mode DMA translations. Again, cpu read
701 rules concerning calls here are the same as for pci_unmap_single()
705 pci_unmap_sg(struct pci_dev
*pdev
, struct scatterlist
*sg
, int nents
,
709 struct pci_controller
*hose
;
710 struct pci_iommu_arena
*arena
;
711 struct scatterlist
*end
;
713 dma_addr_t fbeg
, fend
;
715 if (direction
== PCI_DMA_NONE
)
718 if (! alpha_mv
.mv_pci_tbi
)
721 hose
= pdev
? pdev
->sysdata
: pci_isa_hose
;
722 max_dma
= pdev
? pdev
->dma_mask
: ISA_DMA_MASK
;
723 arena
= hose
->sg_pci
;
724 if (!arena
|| arena
->dma_base
+ arena
->size
- 1 > max_dma
)
725 arena
= hose
->sg_isa
;
729 spin_lock_irqsave(&arena
->lock
, flags
);
731 for (end
= sg
+ nents
; sg
< end
; ++sg
) {
737 addr
= sg
->dma_address
;
738 size
= sg
->dma_length
;
742 if (addr
> 0xffffffff) {
743 /* It's a DAC address -- nothing to do. */
744 DBGA(" (%ld) DAC [%lx,%lx]\n",
745 sg
- end
+ nents
, addr
, size
);
749 if (addr
>= __direct_map_base
750 && addr
< __direct_map_base
+ __direct_map_size
) {
752 DBGA(" (%ld) direct [%lx,%lx]\n",
753 sg
- end
+ nents
, addr
, size
);
757 DBGA(" (%ld) sg [%lx,%lx]\n",
758 sg
- end
+ nents
, addr
, size
);
760 npages
= calc_npages((addr
& ~PAGE_MASK
) + size
);
761 ofs
= (addr
- arena
->dma_base
) >> PAGE_SHIFT
;
762 iommu_arena_free(arena
, ofs
, npages
);
764 tend
= addr
+ size
- 1;
765 if (fbeg
> addr
) fbeg
= addr
;
766 if (fend
< tend
) fend
= tend
;
769 /* If we're freeing ptes above the `next_entry' pointer (they
770 may have snuck back into the TLB since the last wrap flush),
771 we need to flush the TLB before reallocating the latter. */
772 if ((fend
- arena
->dma_base
) >> PAGE_SHIFT
>= arena
->next_entry
)
773 alpha_mv
.mv_pci_tbi(hose
, fbeg
, fend
);
775 spin_unlock_irqrestore(&arena
->lock
, flags
);
777 DBGA("pci_unmap_sg: %ld entries\n", nents
- (end
- sg
));
779 EXPORT_SYMBOL(pci_unmap_sg
);
782 /* Return whether the given PCI device DMA address mask can be
783 supported properly. */
786 pci_dma_supported(struct pci_dev
*pdev
, u64 mask
)
788 struct pci_controller
*hose
;
789 struct pci_iommu_arena
*arena
;
791 /* If there exists a direct map, and the mask fits either
792 the entire direct mapped space or the total system memory as
793 shifted by the map base */
794 if (__direct_map_size
!= 0
795 && (__direct_map_base
+ __direct_map_size
- 1 <= mask
||
796 __direct_map_base
+ (max_low_pfn
<< PAGE_SHIFT
) - 1 <= mask
))
799 /* Check that we have a scatter-gather arena that fits. */
800 hose
= pdev
? pdev
->sysdata
: pci_isa_hose
;
801 arena
= hose
->sg_isa
;
802 if (arena
&& arena
->dma_base
+ arena
->size
- 1 <= mask
)
804 arena
= hose
->sg_pci
;
805 if (arena
&& arena
->dma_base
+ arena
->size
- 1 <= mask
)
808 /* As last resort try ZONE_DMA. */
809 if (!__direct_map_base
&& MAX_DMA_ADDRESS
- IDENT_ADDR
- 1 <= mask
)
814 EXPORT_SYMBOL(pci_dma_supported
);
818 * AGP GART extensions to the IOMMU
821 iommu_reserve(struct pci_iommu_arena
*arena
, long pg_count
, long align_mask
)
827 if (!arena
) return -EINVAL
;
829 spin_lock_irqsave(&arena
->lock
, flags
);
831 /* Search for N empty ptes. */
833 p
= iommu_arena_find_pages(arena
, pg_count
, align_mask
);
835 spin_unlock_irqrestore(&arena
->lock
, flags
);
839 /* Success. Mark them all reserved (ie not zero and invalid)
840 for the iommu tlb that could load them from under us.
841 They will be filled in with valid bits by _bind() */
842 for (i
= 0; i
< pg_count
; ++i
)
843 ptes
[p
+i
] = IOMMU_RESERVED_PTE
;
845 arena
->next_entry
= p
+ pg_count
;
846 spin_unlock_irqrestore(&arena
->lock
, flags
);
852 iommu_release(struct pci_iommu_arena
*arena
, long pg_start
, long pg_count
)
857 if (!arena
) return -EINVAL
;
861 /* Make sure they're all reserved first... */
862 for(i
= pg_start
; i
< pg_start
+ pg_count
; i
++)
863 if (ptes
[i
] != IOMMU_RESERVED_PTE
)
866 iommu_arena_free(arena
, pg_start
, pg_count
);
871 iommu_bind(struct pci_iommu_arena
*arena
, long pg_start
, long pg_count
,
872 unsigned long *physaddrs
)
878 if (!arena
) return -EINVAL
;
880 spin_lock_irqsave(&arena
->lock
, flags
);
884 for(j
= pg_start
; j
< pg_start
+ pg_count
; j
++) {
885 if (ptes
[j
] != IOMMU_RESERVED_PTE
) {
886 spin_unlock_irqrestore(&arena
->lock
, flags
);
891 for(i
= 0, j
= pg_start
; i
< pg_count
; i
++, j
++)
892 ptes
[j
] = mk_iommu_pte(physaddrs
[i
]);
894 spin_unlock_irqrestore(&arena
->lock
, flags
);
900 iommu_unbind(struct pci_iommu_arena
*arena
, long pg_start
, long pg_count
)
905 if (!arena
) return -EINVAL
;
907 p
= arena
->ptes
+ pg_start
;
908 for(i
= 0; i
< pg_count
; i
++)
909 p
[i
] = IOMMU_RESERVED_PTE
;
914 /* True if the machine supports DAC addressing, and DEV can
915 make use of it given MASK. */
918 pci_dac_dma_supported(struct pci_dev
*dev
, u64 mask
)
920 dma64_addr_t dac_offset
= alpha_mv
.pci_dac_offset
;
923 /* If this is not set, the machine doesn't support DAC at all. */
927 /* The device has to be able to address our DAC bit. */
928 if ((dac_offset
& dev
->dma_mask
) != dac_offset
)
931 /* If both conditions above are met, we are fine. */
932 DBGA("pci_dac_dma_supported %s from %p\n",
933 ok
? "yes" : "no", __builtin_return_address(0));
938 /* Helper for generic DMA-mapping functions. */
941 alpha_gendev_to_pci(struct device
*dev
)
943 if (dev
&& dev
->bus
== &pci_bus_type
)
944 return to_pci_dev(dev
);
946 /* Assume that non-PCI devices asking for DMA are either ISA or EISA,
950 /* Assume non-busmaster ISA DMA when dma_mask is not set (the ISA
951 bridge is bus master then). */
952 if (!dev
|| !dev
->dma_mask
|| !*dev
->dma_mask
)
955 /* For EISA bus masters, return isa_bridge (it might have smaller
956 dma_mask due to wiring limitations). */
957 if (*dev
->dma_mask
>= isa_bridge
->dma_mask
)
960 /* This assumes ISA bus master with dma_mask 0xffffff. */
963 EXPORT_SYMBOL(alpha_gendev_to_pci
);
966 dma_set_mask(struct device
*dev
, u64 mask
)
968 if (!dev
->dma_mask
||
969 !pci_dma_supported(alpha_gendev_to_pci(dev
), mask
))
972 *dev
->dma_mask
= mask
;
976 EXPORT_SYMBOL(dma_set_mask
);