diff options
-rw-r--r-- | arch/arm/boot/compressed/head.S | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S index adf583cd0c35..ae7ecc286e7a 100644 --- a/arch/arm/boot/compressed/head.S +++ b/arch/arm/boot/compressed/head.S | |||
@@ -447,7 +447,11 @@ __setup_mmu: sub r3, r4, #16384 @ Page directory size | |||
447 | orr r1, r1, #3 << 10 | 447 | orr r1, r1, #3 << 10 |
448 | add r2, r3, #16384 | 448 | add r2, r3, #16384 |
449 | 1: cmp r1, r9 @ if virt > start of RAM | 449 | 1: cmp r1, r9 @ if virt > start of RAM |
450 | #ifdef CONFIG_CPU_DCACHE_WRITETHROUGH | ||
451 | orrhs r1, r1, #0x08 @ set cacheable | ||
452 | #else | ||
450 | orrhs r1, r1, #0x0c @ set cacheable, bufferable | 453 | orrhs r1, r1, #0x0c @ set cacheable, bufferable |
454 | #endif | ||
451 | cmp r1, r10 @ if virt > end of RAM | 455 | cmp r1, r10 @ if virt > end of RAM |
452 | bichs r1, r1, #0x0c @ clear cacheable, bufferable | 456 | bichs r1, r1, #0x0c @ clear cacheable, bufferable |
453 | str r1, [r0], #4 @ 1:1 mapping | 457 | str r1, [r0], #4 @ 1:1 mapping |
@@ -472,6 +476,12 @@ __setup_mmu: sub r3, r4, #16384 @ Page directory size | |||
472 | mov pc, lr | 476 | mov pc, lr |
473 | ENDPROC(__setup_mmu) | 477 | ENDPROC(__setup_mmu) |
474 | 478 | ||
479 | __arm926ejs_mmu_cache_on: | ||
480 | #ifdef CONFIG_CPU_DCACHE_WRITETHROUGH | ||
481 | mov r0, #4 @ put dcache in WT mode | ||
482 | mcr p15, 7, r0, c15, c0, 0 | ||
483 | #endif | ||
484 | |||
475 | __armv4_mmu_cache_on: | 485 | __armv4_mmu_cache_on: |
476 | mov r12, lr | 486 | mov r12, lr |
477 | #ifdef CONFIG_MMU | 487 | #ifdef CONFIG_MMU |
@@ -653,6 +663,12 @@ proc_types: | |||
653 | W(b) __armv4_mpu_cache_off | 663 | W(b) __armv4_mpu_cache_off |
654 | W(b) __armv4_mpu_cache_flush | 664 | W(b) __armv4_mpu_cache_flush |
655 | 665 | ||
666 | .word 0x41069260 @ ARM926EJ-S (v5TEJ) | ||
667 | .word 0xff0ffff0 | ||
668 | b __arm926ejs_mmu_cache_on | ||
669 | b __armv4_mmu_cache_off | ||
670 | b __armv5tej_mmu_cache_flush | ||
671 | |||
656 | .word 0x00007000 @ ARM7 IDs | 672 | .word 0x00007000 @ ARM7 IDs |
657 | .word 0x0000f000 | 673 | .word 0x0000f000 |
658 | mov pc, lr | 674 | mov pc, lr |