diff options
author | Kim Phillips <kim.phillips@freescale.com> | 2013-11-05 23:15:24 -0500 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2013-12-29 07:32:45 -0500 |
commit | 017f161a55b48807a73fc9dff0b69f081bf43ee3 (patch) | |
tree | 1c440562e87f4c394d483935486019cc9854ffe8 /arch/arm/lib/bswapsdi2.S | |
parent | 03aa6580e336c19e923372a3b6b72a300f24880c (diff) |
ARM: 7877/1: use built-in byte swap function
Enable the compiler intrinsic for byte swapping on arch ARM. This
allows the compiler to detect and be able to optimize out byte
swappings, and has a very modest benefit on vmlinux size (Linaro gcc
4.8):
text data bss dec hex filename
2840310 123932 61960 3026202 2e2d1a vmlinux-lart #orig
2840152 123932 61960 3026044 2e2c7c vmlinux-lart #builtin-bswap
6473120 314840 5616016 12403976 bd4508 vmlinux-mxs #orig
6472586 314848 5616016 12403450 bd42fa vmlinux-mxs #builtin-bswap
7419872 318372 379556 8117800 7bde28 vmlinux-imx_v6_v7 #orig
7419170 318364 379556 8117090 7bdb62 vmlinux-imx_v6_v7 #builtin-bswap
Signed-off-by: Kim Phillips <kim.phillips@freescale.com>
Reviewed-by: Nicolas Pitre <nico@linaro.org>
Acked-by: David Woodhouse <David.Woodhouse@intel.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/lib/bswapsdi2.S')
-rw-r--r-- | arch/arm/lib/bswapsdi2.S | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/arch/arm/lib/bswapsdi2.S b/arch/arm/lib/bswapsdi2.S new file mode 100644 index 000000000000..9fcdd154eff9 --- /dev/null +++ b/arch/arm/lib/bswapsdi2.S | |||
@@ -0,0 +1,36 @@ | |||
1 | #include <linux/linkage.h> | ||
2 | |||
3 | #if __LINUX_ARM_ARCH__ >= 6 | ||
4 | ENTRY(__bswapsi2) | ||
5 | rev r0, r0 | ||
6 | bx lr | ||
7 | ENDPROC(__bswapsi2) | ||
8 | |||
9 | ENTRY(__bswapdi2) | ||
10 | rev r3, r0 | ||
11 | rev r0, r1 | ||
12 | mov r1, r3 | ||
13 | bx lr | ||
14 | ENDPROC(__bswapdi2) | ||
15 | #else | ||
16 | ENTRY(__bswapsi2) | ||
17 | eor r3, r0, r0, ror #16 | ||
18 | mov r3, r3, lsr #8 | ||
19 | bic r3, r3, #0xff00 | ||
20 | eor r0, r3, r0, ror #8 | ||
21 | mov pc, lr | ||
22 | ENDPROC(__bswapsi2) | ||
23 | |||
24 | ENTRY(__bswapdi2) | ||
25 | mov ip, r1 | ||
26 | eor r3, ip, ip, ror #16 | ||
27 | eor r1, r0, r0, ror #16 | ||
28 | mov r1, r1, lsr #8 | ||
29 | mov r3, r3, lsr #8 | ||
30 | bic r3, r3, #0xff00 | ||
31 | bic r1, r1, #0xff00 | ||
32 | eor r1, r1, r0, ror #8 | ||
33 | eor r0, r3, ip, ror #8 | ||
34 | mov pc, lr | ||
35 | ENDPROC(__bswapdi2) | ||
36 | #endif | ||