diff options
Diffstat (limited to 'arch/arm/mm/proc-feroceon.S')
| -rw-r--r-- | arch/arm/mm/proc-feroceon.S | 54 | 
1 files changed, 46 insertions, 8 deletions
| diff --git a/arch/arm/mm/proc-feroceon.S b/arch/arm/mm/proc-feroceon.S index dbc39383e66a..53e632343849 100644 --- a/arch/arm/mm/proc-feroceon.S +++ b/arch/arm/mm/proc-feroceon.S @@ -274,7 +274,7 @@ ENTRY(feroceon_range_flush_kern_dcache_area)   * (same as v4wb)   */  	.align	5 -ENTRY(feroceon_dma_inv_range) +feroceon_dma_inv_range:  	tst	r0, #CACHE_DLINESIZE - 1  	bic	r0, r0, #CACHE_DLINESIZE - 1  	mcrne	p15, 0, r0, c7, c10, 1		@ clean D entry @@ -288,7 +288,7 @@ ENTRY(feroceon_dma_inv_range)  	mov	pc, lr  	.align	5 -ENTRY(feroceon_range_dma_inv_range) +feroceon_range_dma_inv_range:  	mrs	r2, cpsr  	tst	r0, #CACHE_DLINESIZE - 1  	mcrne	p15, 0, r0, c7, c10, 1		@ clean D entry @@ -314,7 +314,7 @@ ENTRY(feroceon_range_dma_inv_range)   * (same as v4wb)   */  	.align	5 -ENTRY(feroceon_dma_clean_range) +feroceon_dma_clean_range:  	bic	r0, r0, #CACHE_DLINESIZE - 1  1:	mcr	p15, 0, r0, c7, c10, 1		@ clean D entry  	add	r0, r0, #CACHE_DLINESIZE @@ -324,7 +324,7 @@ ENTRY(feroceon_dma_clean_range)  	mov	pc, lr  	.align	5 -ENTRY(feroceon_range_dma_clean_range) +feroceon_range_dma_clean_range:  	mrs	r2, cpsr  	cmp	r1, r0  	subne	r1, r1, #1			@ top address is inclusive @@ -367,6 +367,44 @@ ENTRY(feroceon_range_dma_flush_range)  	mcr	p15, 0, r0, c7, c10, 4		@ drain WB  	mov	pc, lr +/* + *	dma_map_area(start, size, dir) + *	- start	- kernel virtual start address + *	- size	- size of region + *	- dir	- DMA direction + */ +ENTRY(feroceon_dma_map_area) +	add	r1, r1, r0 +	cmp	r2, #DMA_TO_DEVICE +	beq	feroceon_dma_clean_range +	bcs	feroceon_dma_inv_range +	b	feroceon_dma_flush_range +ENDPROC(feroceon_dma_map_area) + +/* + *	dma_map_area(start, size, dir) + *	- start	- kernel virtual start address + *	- size	- size of region + *	- dir	- DMA direction + */ +ENTRY(feroceon_range_dma_map_area) +	add	r1, r1, r0 +	cmp	r2, #DMA_TO_DEVICE +	beq	feroceon_range_dma_clean_range +	bcs	feroceon_range_dma_inv_range +	b	feroceon_range_dma_flush_range +ENDPROC(feroceon_range_dma_map_area) + +/* + *	dma_unmap_area(start, size, dir) + *	- start	- kernel virtual start address + *	- size	- size of region + *	- dir	- DMA direction + */ +ENTRY(feroceon_dma_unmap_area) +	mov	pc, lr +ENDPROC(feroceon_dma_unmap_area) +  ENTRY(feroceon_cache_fns)  	.long	feroceon_flush_kern_cache_all  	.long	feroceon_flush_user_cache_all @@ -374,8 +412,8 @@ ENTRY(feroceon_cache_fns)  	.long	feroceon_coherent_kern_range  	.long	feroceon_coherent_user_range  	.long	feroceon_flush_kern_dcache_area -	.long	feroceon_dma_inv_range -	.long	feroceon_dma_clean_range +	.long	feroceon_dma_map_area +	.long	feroceon_dma_unmap_area  	.long	feroceon_dma_flush_range  ENTRY(feroceon_range_cache_fns) @@ -385,8 +423,8 @@ ENTRY(feroceon_range_cache_fns)  	.long	feroceon_coherent_kern_range  	.long	feroceon_coherent_user_range  	.long	feroceon_range_flush_kern_dcache_area -	.long	feroceon_range_dma_inv_range -	.long	feroceon_range_dma_clean_range +	.long	feroceon_range_dma_map_area +	.long	feroceon_dma_unmap_area  	.long	feroceon_range_dma_flush_range  	.align	5 | 
