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 | ||
