aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorMarkos Chandras <markos.chandras@imgtec.com>2014-01-02 11:40:20 -0500
committerRalf Baechle <ralf@linux-mips.org>2014-03-26 18:09:14 -0400
commitb3c3025b2c5536c2b243f4947cffe58628758020 (patch)
tree0e2028c7fa0e2ac20371b54f9bb91729a34d8c1c /arch
parentcc59fe5b88bff926376019851aa88e96b6039eea (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.c6
-rw-r--r--arch/mips/lib/strncpy_user.S19
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
18extern void *__bzero(void *__s, size_t __count); 18extern void *__bzero(void *__s, size_t __count);
19extern long __strncpy_from_kernel_nocheck_asm(char *__to,
20 const char *__from, long __len);
21extern long __strncpy_from_kernel_asm(char *__to, const char *__from,
22 long __len);
19extern long __strncpy_from_user_nocheck_asm(char *__to, 23extern long __strncpy_from_user_nocheck_asm(char *__to,
20 const char *__from, long __len); 24 const char *__from, long __len);
21extern long __strncpy_from_user_asm(char *__to, const char *__from, 25extern long __strncpy_from_user_asm(char *__to, const char *__from,
@@ -48,6 +52,8 @@ EXPORT_SYMBOL(copy_page);
48EXPORT_SYMBOL(__copy_user); 52EXPORT_SYMBOL(__copy_user);
49EXPORT_SYMBOL(__copy_user_inatomic); 53EXPORT_SYMBOL(__copy_user_inatomic);
50EXPORT_SYMBOL(__bzero); 54EXPORT_SYMBOL(__bzero);
55EXPORT_SYMBOL(__strncpy_from_kernel_nocheck_asm);
56EXPORT_SYMBOL(__strncpy_from_kernel_asm);
51EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm); 57EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm);
52EXPORT_SYMBOL(__strncpy_from_user_asm); 58EXPORT_SYMBOL(__strncpy_from_user_asm);
53EXPORT_SYMBOL(__strlen_kernel_nocheck_asm); 59EXPORT_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"
411: EX(lbu, v0, (v1), .Lfault\@) 421: EX(lbu, v0, (v1), .Lfault\@)
43.else
441: 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