diff options
author | Markos Chandras <markos.chandras@imgtec.com> | 2014-01-02 11:40:20 -0500 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2014-03-26 18:09:14 -0400 |
commit | b3c3025b2c5536c2b243f4947cffe58628758020 (patch) | |
tree | 0e2028c7fa0e2ac20371b54f9bb91729a34d8c1c /arch | |
parent | cc59fe5b88bff926376019851aa88e96b6039eea (diff) |
MIPS: lib: strncpy_user: Add EVA support
In non-EVA mode, strncpy_from_user* aliases are used for the
strncpy_from_kernel* symbols since the code is identical. In EVA
mode, new strcpy_from_user* symbols are used which use the EVA
specific instructions to load values from userspace.
Signed-off-by: Markos Chandras <markos.chandras@imgtec.com>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/mips/kernel/mips_ksyms.c | 6 | ||||
-rw-r--r-- | arch/mips/lib/strncpy_user.S | 19 |
2 files changed, 25 insertions, 0 deletions
diff --git a/arch/mips/kernel/mips_ksyms.c b/arch/mips/kernel/mips_ksyms.c index 742ed7d790a0..675bd0578d3f 100644 --- a/arch/mips/kernel/mips_ksyms.c +++ b/arch/mips/kernel/mips_ksyms.c | |||
@@ -16,6 +16,10 @@ | |||
16 | #include <asm/ftrace.h> | 16 | #include <asm/ftrace.h> |
17 | 17 | ||
18 | extern void *__bzero(void *__s, size_t __count); | 18 | extern void *__bzero(void *__s, size_t __count); |
19 | extern long __strncpy_from_kernel_nocheck_asm(char *__to, | ||
20 | const char *__from, long __len); | ||
21 | extern long __strncpy_from_kernel_asm(char *__to, const char *__from, | ||
22 | long __len); | ||
19 | extern long __strncpy_from_user_nocheck_asm(char *__to, | 23 | extern long __strncpy_from_user_nocheck_asm(char *__to, |
20 | const char *__from, long __len); | 24 | const char *__from, long __len); |
21 | extern long __strncpy_from_user_asm(char *__to, const char *__from, | 25 | extern long __strncpy_from_user_asm(char *__to, const char *__from, |
@@ -48,6 +52,8 @@ EXPORT_SYMBOL(copy_page); | |||
48 | EXPORT_SYMBOL(__copy_user); | 52 | EXPORT_SYMBOL(__copy_user); |
49 | EXPORT_SYMBOL(__copy_user_inatomic); | 53 | EXPORT_SYMBOL(__copy_user_inatomic); |
50 | EXPORT_SYMBOL(__bzero); | 54 | EXPORT_SYMBOL(__bzero); |
55 | EXPORT_SYMBOL(__strncpy_from_kernel_nocheck_asm); | ||
56 | EXPORT_SYMBOL(__strncpy_from_kernel_asm); | ||
51 | EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm); | 57 | EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm); |
52 | EXPORT_SYMBOL(__strncpy_from_user_asm); | 58 | EXPORT_SYMBOL(__strncpy_from_user_asm); |
53 | EXPORT_SYMBOL(__strlen_kernel_nocheck_asm); | 59 | EXPORT_SYMBOL(__strlen_kernel_nocheck_asm); |
diff --git a/arch/mips/lib/strncpy_user.S b/arch/mips/lib/strncpy_user.S index 51b38ab1478a..d3301cd1e9a5 100644 --- a/arch/mips/lib/strncpy_user.S +++ b/arch/mips/lib/strncpy_user.S | |||
@@ -38,7 +38,11 @@ FEXPORT(__strncpy_from_\func\()_nocheck_asm) | |||
38 | .set noreorder | 38 | .set noreorder |
39 | move t0, zero | 39 | move t0, zero |
40 | move v1, a1 | 40 | move v1, a1 |
41 | .ifeqs "\func","kernel" | ||
41 | 1: EX(lbu, v0, (v1), .Lfault\@) | 42 | 1: EX(lbu, v0, (v1), .Lfault\@) |
43 | .else | ||
44 | 1: EX(lbue, v0, (v1), .Lfault\@) | ||
45 | .endif | ||
42 | PTR_ADDIU v1, 1 | 46 | PTR_ADDIU v1, 1 |
43 | R10KCBARRIER(0(ra)) | 47 | R10KCBARRIER(0(ra)) |
44 | beqz v0, 2f | 48 | beqz v0, 2f |
@@ -63,4 +67,19 @@ FEXPORT(__strncpy_from_\func\()_nocheck_asm) | |||
63 | 67 | ||
64 | .endm | 68 | .endm |
65 | 69 | ||
70 | #ifndef CONFIG_EVA | ||
71 | /* Set aliases */ | ||
72 | .global __strncpy_from_user_asm | ||
73 | .global __strncpy_from_user_nocheck_asm | ||
74 | .set __strncpy_from_user_asm, __strncpy_from_kernel_asm | ||
75 | .set __strncpy_from_user_nocheck_asm, __strncpy_from_kernel_nocheck_asm | ||
76 | #endif | ||
77 | |||
78 | __BUILD_STRNCPY_ASM kernel | ||
79 | |||
80 | #ifdef CONFIG_EVA | ||
81 | .set push | ||
82 | .set eva | ||
66 | __BUILD_STRNCPY_ASM user | 83 | __BUILD_STRNCPY_ASM user |
84 | .set pop | ||
85 | #endif | ||