swiotlb: factor out copy to/from device
Impact: generalize IO bounce memcpys Signed-off-by: Ian Campbell <ian.campbell@citrix.com> Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
b81ea27b23
commit
1b548f667c
1 changed files with 13 additions and 4 deletions
|
@ -312,6 +312,15 @@ static int is_swiotlb_buffer(char *addr)
|
||||||
return addr >= io_tlb_start && addr < io_tlb_end;
|
return addr >= io_tlb_start && addr < io_tlb_end;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
__sync_single(char *buffer, char *dma_addr, size_t size, int dir)
|
||||||
|
{
|
||||||
|
if (dir == DMA_TO_DEVICE)
|
||||||
|
memcpy(dma_addr, buffer, size);
|
||||||
|
else
|
||||||
|
memcpy(buffer, dma_addr, size);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Allocates bounce buffer and returns its kernel virtual address.
|
* Allocates bounce buffer and returns its kernel virtual address.
|
||||||
*/
|
*/
|
||||||
|
@ -413,7 +422,7 @@ map_single(struct device *hwdev, char *buffer, size_t size, int dir)
|
||||||
for (i = 0; i < nslots; i++)
|
for (i = 0; i < nslots; i++)
|
||||||
io_tlb_orig_addr[index+i] = buffer + (i << IO_TLB_SHIFT);
|
io_tlb_orig_addr[index+i] = buffer + (i << IO_TLB_SHIFT);
|
||||||
if (dir == DMA_TO_DEVICE || dir == DMA_BIDIRECTIONAL)
|
if (dir == DMA_TO_DEVICE || dir == DMA_BIDIRECTIONAL)
|
||||||
memcpy(dma_addr, buffer, size);
|
__sync_single(buffer, dma_addr, size, DMA_TO_DEVICE);
|
||||||
|
|
||||||
return dma_addr;
|
return dma_addr;
|
||||||
}
|
}
|
||||||
|
@ -437,7 +446,7 @@ unmap_single(struct device *hwdev, char *dma_addr, size_t size, int dir)
|
||||||
* bounce... copy the data back into the original buffer * and
|
* bounce... copy the data back into the original buffer * and
|
||||||
* delete the bounce buffer.
|
* delete the bounce buffer.
|
||||||
*/
|
*/
|
||||||
memcpy(buffer, dma_addr, size);
|
__sync_single(buffer, dma_addr, size, DMA_FROM_DEVICE);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Return the buffer to the free list by setting the corresponding
|
* Return the buffer to the free list by setting the corresponding
|
||||||
|
@ -477,13 +486,13 @@ sync_single(struct device *hwdev, char *dma_addr, size_t size,
|
||||||
switch (target) {
|
switch (target) {
|
||||||
case SYNC_FOR_CPU:
|
case SYNC_FOR_CPU:
|
||||||
if (likely(dir == DMA_FROM_DEVICE || dir == DMA_BIDIRECTIONAL))
|
if (likely(dir == DMA_FROM_DEVICE || dir == DMA_BIDIRECTIONAL))
|
||||||
memcpy(buffer, dma_addr, size);
|
__sync_single(buffer, dma_addr, size, DMA_FROM_DEVICE);
|
||||||
else
|
else
|
||||||
BUG_ON(dir != DMA_TO_DEVICE);
|
BUG_ON(dir != DMA_TO_DEVICE);
|
||||||
break;
|
break;
|
||||||
case SYNC_FOR_DEVICE:
|
case SYNC_FOR_DEVICE:
|
||||||
if (likely(dir == DMA_TO_DEVICE || dir == DMA_BIDIRECTIONAL))
|
if (likely(dir == DMA_TO_DEVICE || dir == DMA_BIDIRECTIONAL))
|
||||||
memcpy(dma_addr, buffer, size);
|
__sync_single(buffer, dma_addr, size, DMA_TO_DEVICE);
|
||||||
else
|
else
|
||||||
BUG_ON(dir != DMA_FROM_DEVICE);
|
BUG_ON(dir != DMA_FROM_DEVICE);
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue