diff options
| author | Michael Sevakis <jethead71@rockbox.org> | 2008-04-17 00:07:06 +0000 |
|---|---|---|
| committer | Michael Sevakis <jethead71@rockbox.org> | 2008-04-17 00:07:06 +0000 |
| commit | 99a65dfc1ef034da43de56ae7a4964946d5d67f3 (patch) | |
| tree | dcd1e749f408501fcd0c21e9d76f281a464c3bc3 | |
| parent | 7fee4868f975c6de13fe4f5fe1f82546d0e0eadd (diff) | |
| download | rockbox-99a65dfc1ef034da43de56ae7a4964946d5d67f3.zip rockbox-99a65dfc1ef034da43de56ae7a4964946d5d67f3.tar.gz rockbox-99a65dfc1ef034da43de56ae7a4964946d5d67f3.tar.bz2 rockbox-99a65dfc1ef034da43de56ae7a4964946d5d67f3.tar.xz | |
Cache functions should include data and instruction barriers.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@17150 a1c6a512-1295-4272-9138-f99709370657
| -rw-r--r-- | firmware/target/arm/imx31/gigabeat-s/system-target.h | 9 | ||||
| -rw-r--r-- | firmware/target/arm/mmu-arm.c | 16 |
2 files changed, 18 insertions, 7 deletions
diff --git a/firmware/target/arm/imx31/gigabeat-s/system-target.h b/firmware/target/arm/imx31/gigabeat-s/system-target.h index 17f1593..e48b5d1 100644 --- a/firmware/target/arm/imx31/gigabeat-s/system-target.h +++ b/firmware/target/arm/imx31/gigabeat-s/system-target.h @@ -42,8 +42,13 @@ static inline void invalidate_icache(void) asm volatile( /* Clean and invalidate entire data cache */ "mcr p15, 0, %0, c7, c14, 0 \n" - /* Invalidate entire instruction cache */ + /* Invalidate entire intruction cache + * Also flushes the branch target cache */ "mcr p15, 0, %0, c7, c5, 0 \n" + /* Data synchronization barrier */ + "mcr p15, 0, %0, c7, c10, 4 \n" + /* Flush prefetch buffer */ + "mcr p15, 0, %0, c7, c5, 4 \n" : : "r"(0) ); } @@ -54,6 +59,8 @@ static inline void flush_icache(void) asm volatile ( /* Clean entire data cache */ "mcr p15, 0, %0, c7, c10, 0 \n" + /* Data synchronization barrier */ + "mcr p15, 0, r2, c7, c10, 4 \n" : : "r"(0) ); } diff --git a/firmware/target/arm/mmu-arm.c b/firmware/target/arm/mmu-arm.c index 5fa05d1..ffca7a4 100644 --- a/firmware/target/arm/mmu-arm.c +++ b/firmware/target/arm/mmu-arm.c @@ -90,9 +90,11 @@ void enable_mmu(void) { void __attribute__((naked)) invalidate_dcache_range(const void *base, unsigned int size) { asm volatile( - "add r1, r1, r0 \n" - "mcrr p15, 0, r1, r0, c14 \n" - "bx lr \n" + "add r1, r1, r0 \n" + "mov r2, #0 \n" + "mcrr p15, 0, r1, r0, c14 \n" /* Clean and invalidate dcache range */ + "mcr p15, 0, r2, c7, c10, 4 \n" /* Data synchronization barrier */ + "bx lr \n" ); (void)base; (void)size; } @@ -140,9 +142,11 @@ void invalidate_dcache_range(const void *base, unsigned int size) { void __attribute__((naked)) clean_dcache_range(const void *base, unsigned int size) { asm volatile( - "add r1, r1, r0 \n" - "mcrr p15, 0, r1, r0, c12 \n" - "bx lr \n" + "add r1, r1, r0 \n" + "mov r2, #0 \n" + "mcrr p15, 0, r1, r0, c12 \n" /* Clean dcache range */ + "mcr p15, 0, r2, c7, c10, 4 \n" /* Data synchronization barrier */ + "bx lr \n" ); (void)base; (void)size; } |