aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips
diff options
context:
space:
mode:
authorMarkos Chandras <markos.chandras@imgtec.com>2013-12-09 10:28:10 -0500
committerRalf Baechle <ralf@linux-mips.org>2014-03-26 18:09:13 -0400
commit4968db4b9c4528b097ab4e549c4e0d0420dd1efc (patch)
treeeb6e7f405bb9abab9e1c75ca2cfd0b8648ad5fb9 /arch/mips
parentc48be43eb5248ff96dacda58f9e51ee8bfd058ac (diff)
MIPS: lib: strnlen_user: Add EVA support
In non-EVA mode, a strlen_user* alias is used for the strlen_kernel* symbols since the code is identical. In EVA mode, a new strlen_user* symbol is used which uses the EVA specific instructions to load values from userspace. Signed-off-by: Markos Chandras <markos.chandras@imgtec.com>
Diffstat (limited to 'arch/mips')
-rw-r--r--arch/mips/kernel/mips_ksyms.c4
-rw-r--r--arch/mips/lib/strnlen_user.S20
2 files changed, 24 insertions, 0 deletions
diff --git a/arch/mips/kernel/mips_ksyms.c b/arch/mips/kernel/mips_ksyms.c
index 6e58e97fcd39..a322db072c3c 100644
--- a/arch/mips/kernel/mips_ksyms.c
+++ b/arch/mips/kernel/mips_ksyms.c
@@ -22,6 +22,8 @@ extern long __strncpy_from_user_asm(char *__to, const char *__from,
22 long __len); 22 long __len);
23extern long __strlen_user_nocheck_asm(const char *s); 23extern long __strlen_user_nocheck_asm(const char *s);
24extern long __strlen_user_asm(const char *s); 24extern long __strlen_user_asm(const char *s);
25extern long __strnlen_kernel_nocheck_asm(const char *s);
26extern long __strnlen_kernel_asm(const char *s);
25extern long __strnlen_user_nocheck_asm(const char *s); 27extern long __strnlen_user_nocheck_asm(const char *s);
26extern long __strnlen_user_asm(const char *s); 28extern long __strnlen_user_asm(const char *s);
27 29
@@ -48,6 +50,8 @@ EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm);
48EXPORT_SYMBOL(__strncpy_from_user_asm); 50EXPORT_SYMBOL(__strncpy_from_user_asm);
49EXPORT_SYMBOL(__strlen_user_nocheck_asm); 51EXPORT_SYMBOL(__strlen_user_nocheck_asm);
50EXPORT_SYMBOL(__strlen_user_asm); 52EXPORT_SYMBOL(__strlen_user_asm);
53EXPORT_SYMBOL(__strnlen_kernel_nocheck_asm);
54EXPORT_SYMBOL(__strnlen_kernel_asm);
51EXPORT_SYMBOL(__strnlen_user_nocheck_asm); 55EXPORT_SYMBOL(__strnlen_user_nocheck_asm);
52EXPORT_SYMBOL(__strnlen_user_asm); 56EXPORT_SYMBOL(__strnlen_user_asm);
53 57
diff --git a/arch/mips/lib/strnlen_user.S b/arch/mips/lib/strnlen_user.S
index 44221602ce1c..f3af6995e2a6 100644
--- a/arch/mips/lib/strnlen_user.S
+++ b/arch/mips/lib/strnlen_user.S
@@ -35,7 +35,11 @@ FEXPORT(__strnlen_\func\()_nocheck_asm)
35 move v0, a0 35 move v0, a0
36 PTR_ADDU a1, a0 # stop pointer 36 PTR_ADDU a1, a0 # stop pointer
371: beq v0, a1, 1f # limit reached? 371: beq v0, a1, 1f # limit reached?
38.ifeqs "\func", "kernel"
38 EX(lb, t0, (v0), .Lfault\@) 39 EX(lb, t0, (v0), .Lfault\@)
40.else
41 EX(lbe, t0, (v0), .Lfault\@)
42.endif
39 PTR_ADDIU v0, 1 43 PTR_ADDIU v0, 1
40 bnez t0, 1b 44 bnez t0, 1b
411: PTR_SUBU v0, a0 451: PTR_SUBU v0, a0
@@ -47,4 +51,20 @@ FEXPORT(__strnlen_\func\()_nocheck_asm)
47 jr ra 51 jr ra
48 .endm 52 .endm
49 53
54#ifndef CONFIG_EVA
55 /* Set aliases */
56 .global __strnlen_user_asm
57 .global __strnlen_user_nocheck_asm
58 .set __strnlen_user_asm, __strnlen_kernel_asm
59 .set __strnlen_user_nocheck_asm, __strnlen_kernel_nocheck_asm
60#endif
61
62__BUILD_STRNLEN_ASM kernel
63
64#ifdef CONFIG_EVA
65
66 .set push
67 .set eva
50__BUILD_STRNLEN_ASM user 68__BUILD_STRNLEN_ASM user
69 .set pop
70#endif