diff options
author | Markos Chandras <markos.chandras@imgtec.com> | 2014-01-02 11:04:38 -0500 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2014-03-26 18:09:13 -0400 |
commit | 053970542f049d3e30dc4be6eb19e92ff1f70f00 (patch) | |
tree | 63fcc75f9ae253079349d640b0fd7a9caf1c9060 | |
parent | 5cc494972adbaeff08a1b7544acaa608c68cd527 (diff) |
MIPS: lib: strlen_user: Add EVA support
In non-EVA mode, strlen_user* aliases are used for the
strlen_kernel* symbols since the code is identical. In EVA
mode, new strlen_user* symbols are used which use the EVA
specific instructions to load values from userspace.
Signed-off-by: Markos Chandras <markos.chandras@imgtec.com>
-rw-r--r-- | arch/mips/kernel/mips_ksyms.c | 4 | ||||
-rw-r--r-- | arch/mips/lib/strlen_user.S | 20 |
2 files changed, 24 insertions, 0 deletions
diff --git a/arch/mips/kernel/mips_ksyms.c b/arch/mips/kernel/mips_ksyms.c index a322db072c3c..742ed7d790a0 100644 --- a/arch/mips/kernel/mips_ksyms.c +++ b/arch/mips/kernel/mips_ksyms.c | |||
@@ -20,6 +20,8 @@ extern long __strncpy_from_user_nocheck_asm(char *__to, | |||
20 | const char *__from, long __len); | 20 | const char *__from, long __len); |
21 | extern long __strncpy_from_user_asm(char *__to, const char *__from, | 21 | extern long __strncpy_from_user_asm(char *__to, const char *__from, |
22 | long __len); | 22 | long __len); |
23 | extern long __strlen_kernel_nocheck_asm(const char *s); | ||
24 | extern long __strlen_kernel_asm(const char *s); | ||
23 | extern long __strlen_user_nocheck_asm(const char *s); | 25 | extern long __strlen_user_nocheck_asm(const char *s); |
24 | extern long __strlen_user_asm(const char *s); | 26 | extern long __strlen_user_asm(const char *s); |
25 | extern long __strnlen_kernel_nocheck_asm(const char *s); | 27 | extern long __strnlen_kernel_nocheck_asm(const char *s); |
@@ -48,6 +50,8 @@ EXPORT_SYMBOL(__copy_user_inatomic); | |||
48 | EXPORT_SYMBOL(__bzero); | 50 | EXPORT_SYMBOL(__bzero); |
49 | EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm); | 51 | EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm); |
50 | EXPORT_SYMBOL(__strncpy_from_user_asm); | 52 | EXPORT_SYMBOL(__strncpy_from_user_asm); |
53 | EXPORT_SYMBOL(__strlen_kernel_nocheck_asm); | ||
54 | EXPORT_SYMBOL(__strlen_kernel_asm); | ||
51 | EXPORT_SYMBOL(__strlen_user_nocheck_asm); | 55 | EXPORT_SYMBOL(__strlen_user_nocheck_asm); |
52 | EXPORT_SYMBOL(__strlen_user_asm); | 56 | EXPORT_SYMBOL(__strlen_user_asm); |
53 | EXPORT_SYMBOL(__strnlen_kernel_nocheck_asm); | 57 | EXPORT_SYMBOL(__strnlen_kernel_nocheck_asm); |
diff --git a/arch/mips/lib/strlen_user.S b/arch/mips/lib/strlen_user.S index 6e8bdb373213..bef65c98df59 100644 --- a/arch/mips/lib/strlen_user.S +++ b/arch/mips/lib/strlen_user.S | |||
@@ -30,7 +30,11 @@ LEAF(__strlen_\func\()_asm) | |||
30 | 30 | ||
31 | FEXPORT(__strlen_\func\()_nocheck_asm) | 31 | FEXPORT(__strlen_\func\()_nocheck_asm) |
32 | move v0, a0 | 32 | move v0, a0 |
33 | .ifeqs "\func", "kernel" | ||
33 | 1: EX(lbu, v1, (v0), .Lfault\@) | 34 | 1: EX(lbu, v1, (v0), .Lfault\@) |
35 | .else | ||
36 | 1: EX(lbue, v1, (v0), .Lfault\@) | ||
37 | .endif | ||
34 | PTR_ADDIU v0, 1 | 38 | PTR_ADDIU v0, 1 |
35 | bnez v1, 1b | 39 | bnez v1, 1b |
36 | PTR_SUBU v0, a0 | 40 | PTR_SUBU v0, a0 |
@@ -41,4 +45,20 @@ FEXPORT(__strlen_\func\()_nocheck_asm) | |||
41 | jr ra | 45 | jr ra |
42 | .endm | 46 | .endm |
43 | 47 | ||
48 | #ifndef CONFIG_EVA | ||
49 | /* Set aliases */ | ||
50 | .global __strlen_user_asm | ||
51 | .global __strlen_user_nocheck_asm | ||
52 | .set __strlen_user_asm, __strlen_kernel_asm | ||
53 | .set __strlen_user_nocheck_asm, __strlen_kernel_nocheck_asm | ||
54 | #endif | ||
55 | |||
56 | __BUILD_STRLEN_ASM kernel | ||
57 | |||
58 | #ifdef CONFIG_EVA | ||
59 | |||
60 | .set push | ||
61 | .set eva | ||
44 | __BUILD_STRLEN_ASM user | 62 | __BUILD_STRLEN_ASM user |
63 | .set pop | ||
64 | #endif | ||