aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc
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
parentae984d72e0632782dd98c3fcf469b9045ad0d449 (diff)
sparc: Commonize memcmp assembler.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc')
-rw-r--r--arch/sparc/kernel/sparc_ksyms_32.c2
-rw-r--r--arch/sparc/kernel/sparc_ksyms_64.c2
-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
6 files changed, 28 insertions, 63 deletions
diff --git a/arch/sparc/kernel/sparc_ksyms_32.c b/arch/sparc/kernel/sparc_ksyms_32.c
index 3c80562faa8a..a4d45fc29b21 100644
--- a/arch/sparc/kernel/sparc_ksyms_32.c
+++ b/arch/sparc/kernel/sparc_ksyms_32.c
@@ -61,7 +61,6 @@ extern void (*bzero_1page)(void *);
61extern void *__bzero(void *, size_t); 61extern void *__bzero(void *, size_t);
62extern void *__memscan_zero(void *, size_t); 62extern void *__memscan_zero(void *, size_t);
63extern void *__memscan_generic(void *, int, size_t); 63extern void *__memscan_generic(void *, int, size_t);
64extern int __memcmp(const void *, const void *, __kernel_size_t);
65extern int __strncmp(const char *, const char *, __kernel_size_t); 64extern int __strncmp(const char *, const char *, __kernel_size_t);
66 65
67extern int __ashrdi3(int, int); 66extern int __ashrdi3(int, int);
@@ -211,7 +210,6 @@ EXPORT_SYMBOL(bzero_1page);
211EXPORT_SYMBOL(__bzero); 210EXPORT_SYMBOL(__bzero);
212EXPORT_SYMBOL(__memscan_zero); 211EXPORT_SYMBOL(__memscan_zero);
213EXPORT_SYMBOL(__memscan_generic); 212EXPORT_SYMBOL(__memscan_generic);
214EXPORT_SYMBOL(__memcmp);
215EXPORT_SYMBOL(__strncmp); 213EXPORT_SYMBOL(__strncmp);
216EXPORT_SYMBOL(__memmove); 214EXPORT_SYMBOL(__memmove);
217 215
diff --git a/arch/sparc/kernel/sparc_ksyms_64.c b/arch/sparc/kernel/sparc_ksyms_64.c
index e6d2bb86a46f..59e7ca0108e9 100644
--- a/arch/sparc/kernel/sparc_ksyms_64.c
+++ b/arch/sparc/kernel/sparc_ksyms_64.c
@@ -62,7 +62,6 @@ extern pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags);
62extern void *__bzero(void *, size_t); 62extern void *__bzero(void *, size_t);
63extern void *__memscan_zero(void *, size_t); 63extern void *__memscan_zero(void *, size_t);
64extern void *__memscan_generic(void *, int, size_t); 64extern void *__memscan_generic(void *, int, size_t);
65extern int __memcmp(const void *, const void *, __kernel_size_t);
66extern __kernel_size_t strlen(const char *); 65extern __kernel_size_t strlen(const char *);
67extern void sys_sigsuspend(void); 66extern void sys_sigsuspend(void);
68extern int compat_sys_ioctl(unsigned int fd, unsigned int cmd, u32 arg); 67extern int compat_sys_ioctl(unsigned int fd, unsigned int cmd, u32 arg);
@@ -223,7 +222,6 @@ EXPORT_SYMBOL(copy_user_page);
223EXPORT_SYMBOL(__bzero); 222EXPORT_SYMBOL(__bzero);
224EXPORT_SYMBOL(__memscan_zero); 223EXPORT_SYMBOL(__memscan_zero);
225EXPORT_SYMBOL(__memscan_generic); 224EXPORT_SYMBOL(__memscan_generic);
226EXPORT_SYMBOL(__memcmp);
227EXPORT_SYMBOL(__memset); 225EXPORT_SYMBOL(__memset);
228 226
229EXPORT_SYMBOL(csum_partial); 227EXPORT_SYMBOL(csum_partial);
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