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 | |
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')
-rw-r--r-- | arch/arm/lib/Makefile | 2 | ||||
-rw-r--r-- | arch/arm/lib/bswapsdi2.S | 36 |
2 files changed, 37 insertions, 1 deletions
diff --git a/arch/arm/lib/Makefile b/arch/arm/lib/Makefile index 47d7338561de..0573faab96ad 100644 --- a/arch/arm/lib/Makefile +++ b/arch/arm/lib/Makefile | |||
@@ -13,7 +13,7 @@ lib-y := backtrace.o changebit.o csumipv6.o csumpartial.o \ | |||
13 | ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \ | 13 | ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \ |
14 | ucmpdi2.o lib1funcs.o div64.o \ | 14 | ucmpdi2.o lib1funcs.o div64.o \ |
15 | io-readsb.o io-writesb.o io-readsl.o io-writesl.o \ | 15 | io-readsb.o io-writesb.o io-readsl.o io-writesl.o \ |
16 | call_with_stack.o | 16 | call_with_stack.o bswapsdi2.o |
17 | 17 | ||
18 | mmu-y := clear_user.o copy_page.o getuser.o putuser.o | 18 | mmu-y := clear_user.o copy_page.o getuser.o putuser.o |
19 | 19 | ||
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 | ||