aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc/lib
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2008-12-09 07:09:07 -0500
committerDavid S. Miller <davem@davemloft.net>2008-12-09 07:09:07 -0500
commit18cdae68e7bb24f33883e58f366cde38ea89ba17 (patch)
tree891b87b5e3c0b605f5e7d2b9809282b67c005293 /arch/sparc/lib
parentae984d72e0632782dd98c3fcf469b9045ad0d449 (diff)
sparc: Commonize memcmp assembler.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc/lib')
-rw-r--r--arch/sparc/lib/Makefile2
-rw-r--r--arch/sparc/lib/memcmp.S27
-rw-r--r--arch/sparc/lib/memcmp_32.S30
-rw-r--r--arch/sparc/lib/memcmp_64.S28
4 files changed, 28 insertions, 59 deletions
diff --git a/arch/sparc/lib/Makefile b/arch/sparc/lib/Makefile
index 0db2c61a0f78..375016e19144 100644
--- a/arch/sparc/lib/Makefile
+++ b/arch/sparc/lib/Makefile
@@ -9,7 +9,7 @@ lib-$(CONFIG_SPARC32) += memcpy.o memset.o
9lib-y += strlen.o 9lib-y += strlen.o
10lib-y += checksum_$(BITS).o 10lib-y += checksum_$(BITS).o
11lib-$(CONFIG_SPARC32) += blockops.o 11lib-$(CONFIG_SPARC32) += blockops.o
12lib-y += memscan_$(BITS).o memcmp_$(BITS).o strncmp_$(BITS).o 12lib-y += memscan_$(BITS).o memcmp.o strncmp_$(BITS).o
13lib-y += strncpy_from_user_$(BITS).o strlen_user_$(BITS).o 13lib-y += strncpy_from_user_$(BITS).o strlen_user_$(BITS).o
14lib-$(CONFIG_SPARC32) += divdi3.o udivdi3.o 14lib-$(CONFIG_SPARC32) += divdi3.o udivdi3.o
15lib-$(CONFIG_SPARC32) += copy_user.o locks.o 15lib-$(CONFIG_SPARC32) += copy_user.o locks.o
diff --git a/arch/sparc/lib/memcmp.S b/arch/sparc/lib/memcmp.S
new file mode 100644
index 000000000000..efa106c41ed0
--- /dev/null
+++ b/arch/sparc/lib/memcmp.S
@@ -0,0 +1,27 @@
1/* Sparc optimized memcmp code.
2 *
3 * Copyright (C) 1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
4 * Copyright (C) 2000, 2008 David S. Miller (davem@davemloft.net)
5 */
6
7#include <linux/linkage.h>
8#include <asm/asm.h>
9
10 .text
11ENTRY(memcmp)
12 cmp %o2, 0
131: BRANCH32(be, pn, 2f)
14 nop
15 ldub [%o0], %g7
16 ldub [%o1], %g3
17 sub %o2, 1, %o2
18 add %o0, 1, %o0
19 add %o1, 1, %o1
20 subcc %g7, %g3, %g3
21 BRANCH32(be, pt, 1b)
22 cmp %o2, 0
23 retl
24 mov %g3, %o0
252: retl
26 mov 0, %o0
27ENDPROC(memcmp)
diff --git a/arch/sparc/lib/memcmp_32.S b/arch/sparc/lib/memcmp_32.S
deleted file mode 100644
index 9e21f0282659..000000000000
--- a/arch/sparc/lib/memcmp_32.S
+++ /dev/null
@@ -1,30 +0,0 @@
1 .text
2 .align 4
3 .global __memcmp, memcmp
4__memcmp:
5memcmp:
6 cmp %o2, 0
7 ble L3
8 mov 0, %g3
9L5:
10 ldub [%o0], %g2
11 ldub [%o1], %g3
12 sub %g2, %g3, %g2
13 mov %g2, %g3
14 sll %g2, 24, %g2
15
16 cmp %g2, 0
17 bne L3
18 add %o0, 1, %o0
19
20 add %o2, -1, %o2
21
22 cmp %o2, 0
23 bg L5
24 add %o1, 1, %o1
25L3:
26 sll %g3, 24, %o0
27 sra %o0, 24, %o0
28
29 retl
30 nop
diff --git a/arch/sparc/lib/memcmp_64.S b/arch/sparc/lib/memcmp_64.S
deleted file mode 100644
index d3fdaa898566..000000000000
--- a/arch/sparc/lib/memcmp_64.S
+++ /dev/null
@@ -1,28 +0,0 @@
1/*
2 * Sparc64 optimized memcmp code.
3 *
4 * Copyright (C) 1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
5 * Copyright (C) 2000 David S. Miller (davem@redhat.com)
6 */
7
8 .text
9 .align 32
10 .globl __memcmp, memcmp
11__memcmp:
12memcmp:
13 cmp %o2, 0 ! IEU1 Group
14loop: be,pn %icc, ret_0 ! CTI
15 nop ! IEU0
16 ldub [%o0], %g7 ! LSU Group
17 ldub [%o1], %g3 ! LSU Group
18 sub %o2, 1, %o2 ! IEU0
19 add %o0, 1, %o0 ! IEU1
20 add %o1, 1, %o1 ! IEU0 Group
21 subcc %g7, %g3, %g3 ! IEU1 Group
22 be,pt %icc, loop ! CTI
23 cmp %o2, 0 ! IEU1 Group
24
25ret_n0: retl
26 mov %g3, %o0
27ret_0: retl
28 mov 0, %o0