ARC: [mm] micro-optimize page size icache invalidate
authorVineet Gupta <vgupta@synopsys.com>
Fri, 12 Apr 2013 10:02:06 +0000 (15:32 +0530)
committerVineet Gupta <vgupta@synopsys.com>
Tue, 7 May 2013 13:38:14 +0000 (19:08 +0530)
start address is already page aligned and size is const PAGE_SIZE,
thus fixups for alignment not needed in generated code.

bloat-o-meter vmlinux-mm5 vmlinux
add/remove: 0/0 grow/shrink: 0/1 up/down: 0/-32 (-32)
function                                     old     new   delta
__inv_icache_page                             82      50     -32

Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
arch/arc/mm/cache_arc700.c

index da9de401681d524e1b96abf2e6f91a7360d59933..3a9ef63b1a970fb0507bdb32ef14b932aeb930db 100644 (file)
@@ -406,9 +406,18 @@ static void __ic_line_inv_vaddr(unsigned long phy_start, unsigned long vaddr,
        int num_lines, slack;
        unsigned int addr;
 
-       slack = phy_start & ~ICACHE_LINE_MASK;
-       sz += slack;
-       phy_start -= slack;
+       /*
+        * Ensure we properly floor/ceil the non-line aligned/sized requests:
+        * However page sized flushes can be compile time optimised.
+        *  -@phy_start will be cache-line aligned already (being page aligned)
+        *  -@sz will be integral multiple of line size (being page sized).
+        */
+       if (!(__builtin_constant_p(sz) && sz == PAGE_SIZE)) {
+               slack = phy_start & ~ICACHE_LINE_MASK;
+               sz += slack;
+               phy_start -= slack;
+       }
+
        num_lines = DIV_ROUND_UP(sz, ARC_ICACHE_LINE_LEN);
 
 #if (CONFIG_ARC_MMU_VER > 2)