aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mm/proc-xscale.S
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mm/proc-xscale.S')
-rw-r--r--arch/arm/mm/proc-xscale.S62
1 files changed, 50 insertions, 12 deletions
diff --git a/arch/arm/mm/proc-xscale.S b/arch/arm/mm/proc-xscale.S
index f056c283682d..63037e2162f2 100644
--- a/arch/arm/mm/proc-xscale.S
+++ b/arch/arm/mm/proc-xscale.S
@@ -284,15 +284,16 @@ ENTRY(xscale_coherent_user_range)
284 mov pc, lr 284 mov pc, lr
285 285
286/* 286/*
287 * flush_kern_dcache_page(void *page) 287 * flush_kern_dcache_area(void *addr, size_t size)
288 * 288 *
289 * Ensure no D cache aliasing occurs, either with itself or 289 * Ensure no D cache aliasing occurs, either with itself or
290 * the I cache 290 * the I cache
291 * 291 *
292 * - addr - page aligned address 292 * - addr - kernel address
293 * - size - region size
293 */ 294 */
294ENTRY(xscale_flush_kern_dcache_page) 295ENTRY(xscale_flush_kern_dcache_area)
295 add r1, r0, #PAGE_SZ 296 add r1, r0, r1
2961: mcr p15, 0, r0, c7, c10, 1 @ clean D entry 2971: mcr p15, 0, r0, c7, c10, 1 @ clean D entry
297 mcr p15, 0, r0, c7, c6, 1 @ invalidate D entry 298 mcr p15, 0, r0, c7, c6, 1 @ invalidate D entry
298 add r0, r0, #CACHELINESIZE 299 add r0, r0, #CACHELINESIZE
@@ -314,7 +315,7 @@ ENTRY(xscale_flush_kern_dcache_page)
314 * - start - virtual start address 315 * - start - virtual start address
315 * - end - virtual end address 316 * - end - virtual end address
316 */ 317 */
317ENTRY(xscale_dma_inv_range) 318xscale_dma_inv_range:
318 tst r0, #CACHELINESIZE - 1 319 tst r0, #CACHELINESIZE - 1
319 bic r0, r0, #CACHELINESIZE - 1 320 bic r0, r0, #CACHELINESIZE - 1
320 mcrne p15, 0, r0, c7, c10, 1 @ clean D entry 321 mcrne p15, 0, r0, c7, c10, 1 @ clean D entry
@@ -335,7 +336,7 @@ ENTRY(xscale_dma_inv_range)
335 * - start - virtual start address 336 * - start - virtual start address
336 * - end - virtual end address 337 * - end - virtual end address
337 */ 338 */
338ENTRY(xscale_dma_clean_range) 339xscale_dma_clean_range:
339 bic r0, r0, #CACHELINESIZE - 1 340 bic r0, r0, #CACHELINESIZE - 1
3401: mcr p15, 0, r0, c7, c10, 1 @ clean D entry 3411: mcr p15, 0, r0, c7, c10, 1 @ clean D entry
341 add r0, r0, #CACHELINESIZE 342 add r0, r0, #CACHELINESIZE
@@ -362,15 +363,52 @@ ENTRY(xscale_dma_flush_range)
362 mcr p15, 0, r0, c7, c10, 4 @ Drain Write (& Fill) Buffer 363 mcr p15, 0, r0, c7, c10, 4 @ Drain Write (& Fill) Buffer
363 mov pc, lr 364 mov pc, lr
364 365
366/*
367 * dma_map_area(start, size, dir)
368 * - start - kernel virtual start address
369 * - size - size of region
370 * - dir - DMA direction
371 */
372ENTRY(xscale_dma_map_area)
373 add r1, r1, r0
374 cmp r2, #DMA_TO_DEVICE
375 beq xscale_dma_clean_range
376 bcs xscale_dma_inv_range
377 b xscale_dma_flush_range
378ENDPROC(xscale_dma_map_area)
379
380/*
381 * dma_map_area(start, size, dir)
382 * - start - kernel virtual start address
383 * - size - size of region
384 * - dir - DMA direction
385 */
386ENTRY(xscale_dma_a0_map_area)
387 add r1, r1, r0
388 teq r2, #DMA_TO_DEVICE
389 beq xscale_dma_clean_range
390 b xscale_dma_flush_range
391ENDPROC(xscsale_dma_a0_map_area)
392
393/*
394 * dma_unmap_area(start, size, dir)
395 * - start - kernel virtual start address
396 * - size - size of region
397 * - dir - DMA direction
398 */
399ENTRY(xscale_dma_unmap_area)
400 mov pc, lr
401ENDPROC(xscale_dma_unmap_area)
402
365ENTRY(xscale_cache_fns) 403ENTRY(xscale_cache_fns)
366 .long xscale_flush_kern_cache_all 404 .long xscale_flush_kern_cache_all
367 .long xscale_flush_user_cache_all 405 .long xscale_flush_user_cache_all
368 .long xscale_flush_user_cache_range 406 .long xscale_flush_user_cache_range
369 .long xscale_coherent_kern_range 407 .long xscale_coherent_kern_range
370 .long xscale_coherent_user_range 408 .long xscale_coherent_user_range
371 .long xscale_flush_kern_dcache_page 409 .long xscale_flush_kern_dcache_area
372 .long xscale_dma_inv_range 410 .long xscale_dma_map_area
373 .long xscale_dma_clean_range 411 .long xscale_dma_unmap_area
374 .long xscale_dma_flush_range 412 .long xscale_dma_flush_range
375 413
376/* 414/*
@@ -392,9 +430,9 @@ ENTRY(xscale_80200_A0_A1_cache_fns)
392 .long xscale_flush_user_cache_range 430 .long xscale_flush_user_cache_range
393 .long xscale_coherent_kern_range 431 .long xscale_coherent_kern_range
394 .long xscale_coherent_user_range 432 .long xscale_coherent_user_range
395 .long xscale_flush_kern_dcache_page 433 .long xscale_flush_kern_dcache_area
396 .long xscale_dma_flush_range 434 .long xscale_dma_a0_map_area
397 .long xscale_dma_clean_range 435 .long xscale_dma_unmap_area
398 .long xscale_dma_flush_range 436 .long xscale_dma_flush_range
399 437
400ENTRY(cpu_xscale_dcache_clean_area) 438ENTRY(cpu_xscale_dcache_clean_area)