提交 4968db4b 编写于 作者: M Markos Chandras 提交者: Ralf Baechle

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: NMarkos Chandras <markos.chandras@imgtec.com>
上级 c48be43e
...@@ -22,6 +22,8 @@ extern long __strncpy_from_user_asm(char *__to, const char *__from, ...@@ -22,6 +22,8 @@ extern long __strncpy_from_user_asm(char *__to, const char *__from,
long __len); long __len);
extern long __strlen_user_nocheck_asm(const char *s); extern long __strlen_user_nocheck_asm(const char *s);
extern long __strlen_user_asm(const char *s); extern long __strlen_user_asm(const char *s);
extern long __strnlen_kernel_nocheck_asm(const char *s);
extern long __strnlen_kernel_asm(const char *s);
extern long __strnlen_user_nocheck_asm(const char *s); extern long __strnlen_user_nocheck_asm(const char *s);
extern long __strnlen_user_asm(const char *s); extern long __strnlen_user_asm(const char *s);
...@@ -48,6 +50,8 @@ EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm); ...@@ -48,6 +50,8 @@ EXPORT_SYMBOL(__strncpy_from_user_nocheck_asm);
EXPORT_SYMBOL(__strncpy_from_user_asm); EXPORT_SYMBOL(__strncpy_from_user_asm);
EXPORT_SYMBOL(__strlen_user_nocheck_asm); EXPORT_SYMBOL(__strlen_user_nocheck_asm);
EXPORT_SYMBOL(__strlen_user_asm); EXPORT_SYMBOL(__strlen_user_asm);
EXPORT_SYMBOL(__strnlen_kernel_nocheck_asm);
EXPORT_SYMBOL(__strnlen_kernel_asm);
EXPORT_SYMBOL(__strnlen_user_nocheck_asm); EXPORT_SYMBOL(__strnlen_user_nocheck_asm);
EXPORT_SYMBOL(__strnlen_user_asm); EXPORT_SYMBOL(__strnlen_user_asm);
......
...@@ -35,7 +35,11 @@ FEXPORT(__strnlen_\func\()_nocheck_asm) ...@@ -35,7 +35,11 @@ FEXPORT(__strnlen_\func\()_nocheck_asm)
move v0, a0 move v0, a0
PTR_ADDU a1, a0 # stop pointer PTR_ADDU a1, a0 # stop pointer
1: beq v0, a1, 1f # limit reached? 1: beq v0, a1, 1f # limit reached?
.ifeqs "\func", "kernel"
EX(lb, t0, (v0), .Lfault\@) EX(lb, t0, (v0), .Lfault\@)
.else
EX(lbe, t0, (v0), .Lfault\@)
.endif
PTR_ADDIU v0, 1 PTR_ADDIU v0, 1
bnez t0, 1b bnez t0, 1b
1: PTR_SUBU v0, a0 1: PTR_SUBU v0, a0
...@@ -47,4 +51,20 @@ FEXPORT(__strnlen_\func\()_nocheck_asm) ...@@ -47,4 +51,20 @@ FEXPORT(__strnlen_\func\()_nocheck_asm)
jr ra jr ra
.endm .endm
#ifndef CONFIG_EVA
/* Set aliases */
.global __strnlen_user_asm
.global __strnlen_user_nocheck_asm
.set __strnlen_user_asm, __strnlen_kernel_asm
.set __strnlen_user_nocheck_asm, __strnlen_kernel_nocheck_asm
#endif
__BUILD_STRNLEN_ASM kernel
#ifdef CONFIG_EVA
.set push
.set eva
__BUILD_STRNLEN_ASM user __BUILD_STRNLEN_ASM user
.set pop
#endif
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册