Commit 7a94849e authored by Ard Biesheuvel's avatar Ard Biesheuvel

ARM: p2v: factor out BE8 handling

The big and little endian versions of the ARM p2v patching routine only
differ in the values of the constants, so factor those out into macros
so that we only have one version of the logic sequence to maintain.
Acked-by: default avatarNicolas Pitre <nico@fluxnic.net>
Reviewed-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: default avatarArd Biesheuvel <ardb@kernel.org>
parent 4b16421c
...@@ -95,23 +95,25 @@ ARM_BE8(rev16 ip, ip) ...@@ -95,23 +95,25 @@ ARM_BE8(rev16 ip, ip)
ARM_BE8(rev16 ip, ip) ARM_BE8(rev16 ip, ip)
strh ip, [r7] strh ip, [r7]
#else #else
moveq r0, #0x400000 @ set bit 22, mov to mvn instruction
b .Lnext
.Lloop: ldr ip, [r7, r3]
#ifdef CONFIG_CPU_ENDIAN_BE8 #ifdef CONFIG_CPU_ENDIAN_BE8
@ in BE8, we load data in BE, but instructions still in LE @ in BE8, we load data in BE, but instructions still in LE
bic ip, ip, #0xff000000 #define PV_BIT22 0x00004000
tst ip, #0x000f0000 @ check the rotation field #define PV_IMM8_MASK 0xff000000
orrne ip, ip, r6, lsl #24 @ mask in offset bits 31-24 #define PV_ROT_MASK 0x000f0000
biceq ip, ip, #0x00004000 @ clear bit 22
orreq ip, ip, r0, ror #8 @ mask in offset bits 7-0
#else #else
bic ip, ip, #0x000000ff #define PV_BIT22 0x00400000
tst ip, #0xf00 @ check the rotation field #define PV_IMM8_MASK 0x000000ff
orrne ip, ip, r6 @ mask in offset bits 31-24 #define PV_ROT_MASK 0xf00
biceq ip, ip, #0x400000 @ clear bit 22
orreq ip, ip, r0 @ mask in offset bits 7-0
#endif #endif
moveq r0, #0x400000 @ set bit 22, mov to mvn instruction
b .Lnext
.Lloop: ldr ip, [r7, r3]
bic ip, ip, #PV_IMM8_MASK
tst ip, #PV_ROT_MASK @ check the rotation field
orrne ip, ip, r6 ARM_BE8(, lsl #24) @ mask in offset bits 31-24
biceq ip, ip, #PV_BIT22 @ clear bit 22
orreq ip, ip, r0 ARM_BE8(, ror #8) @ mask in offset bits 7-0 (or bit 22)
str ip, [r7, r3] str ip, [r7, r3]
#endif #endif
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment