ARM: 8055/1: cacheflush: use -st dsb option for ensuring completion
authorWill Deacon <will.deacon@arm.com>
Fri, 9 May 2014 17:36:27 +0000 (18:36 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Sun, 25 May 2014 22:47:46 +0000 (23:47 +0100)
dsb st can be used to ensure completion of pending cache maintenance
operations, so use it for the v7 cache maintenance operations.

Signed-off-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/include/asm/cacheflush.h
arch/arm/mm/cache-v7.S
arch/arm/mm/mmu.c

index 8b8b61685a3436158923b30cc80106364e02d509..00af9fe435e641e3c3a3ecf6cdcecfd082372c30 100644 (file)
@@ -212,7 +212,7 @@ extern void copy_to_user_page(struct vm_area_struct *, struct page *,
 static inline void __flush_icache_all(void)
 {
        __flush_icache_preferred();
-       dsb();
+       dsb(ishst);
 }
 
 /*
index 778bcf88ee798b4104f35fef3ed1d6fc933f3392..615c99e38ba1e0d1dfe0333b37a03cda8177f88d 100644 (file)
@@ -59,7 +59,7 @@ ENTRY(v7_invalidate_l1)
        bgt     2b
        cmp     r2, #0
        bgt     1b
-       dsb
+       dsb     st
        isb
        mov     pc, lr
 ENDPROC(v7_invalidate_l1)
@@ -166,7 +166,7 @@ skip:
 finished:
        mov     r10, #0                         @ swith back to cache level 0
        mcr     p15, 2, r10, c0, c0, 0          @ select current cache level in cssr
-       dsb
+       dsb     st
        isb
        mov     pc, lr
 ENDPROC(v7_flush_dcache_all)
@@ -335,7 +335,7 @@ ENTRY(v7_flush_kern_dcache_area)
        add     r0, r0, r2
        cmp     r0, r1
        blo     1b
-       dsb
+       dsb     st
        mov     pc, lr
 ENDPROC(v7_flush_kern_dcache_area)
 
@@ -368,7 +368,7 @@ v7_dma_inv_range:
        add     r0, r0, r2
        cmp     r0, r1
        blo     1b
-       dsb
+       dsb     st
        mov     pc, lr
 ENDPROC(v7_dma_inv_range)
 
@@ -390,7 +390,7 @@ v7_dma_clean_range:
        add     r0, r0, r2
        cmp     r0, r1
        blo     1b
-       dsb
+       dsb     st
        mov     pc, lr
 ENDPROC(v7_dma_clean_range)
 
@@ -412,7 +412,7 @@ ENTRY(v7_dma_flush_range)
        add     r0, r0, r2
        cmp     r0, r1
        blo     1b
-       dsb
+       dsb     st
        mov     pc, lr
 ENDPROC(v7_dma_flush_range)
 
index 09c0a16165dcd6325ed4fcd0ba3ab979f1639968..a991ce2f18d4f086a54a92feeaf555b559c722e3 100644 (file)
@@ -1465,7 +1465,7 @@ void __init early_paging_init(const struct machine_desc *mdesc,
         * just complicate the code.
         */
        flush_cache_louis();
-       dsb();
+       dsb(ishst);
        isb();
 
        /* remap level 1 table */