armv8/cache.S: Triple with single instruction
authorPierre-Clément Tosi <ptosi@google.com>
Fri, 27 Aug 2021 16:04:10 +0000 (18:04 +0200)
committerTom Rini <trini@konsulko.com>
Thu, 23 Sep 2021 12:55:06 +0000 (08:55 -0400)
Replace the current 2-instruction 2-step tripling code by a
corresponding single instruction leveraging ARMv8-A's "flexible second
operand as a register with optional shift". This has the added benefit
(albeit arguably negligible) of reducing the final code size.

Fix the comment as the tripled cache level is placed in x12, not x0.

Signed-off-by: Pierre-Clément Tosi <ptosi@google.com>
arch/arm/cpu/armv8/cache.S

index eec2958107a67fafb38be0c91dd684ffa1bef600..d1cee23437da1422b304b0bd2c31302448eb1dd0 100644 (file)
@@ -80,8 +80,7 @@ ENTRY(__asm_dcache_all)
        /* x15 <- return address */
 
 loop_level:
-       lsl     x12, x0, #1
-       add     x12, x12, x0            /* x0 <- tripled cache level */
+       add     x12, x0, x0, lsl #1     /* x12 <- tripled cache level */
        lsr     x12, x10, x12
        and     x12, x12, #7            /* x12 <- cache type */
        cmp     x12, #2