b668970e61
kernelci.org reports tons of build warnings for linux-next:
35 WARNING: "memcpy" [fs/fat/msdos.ko] has no CRC!
35 WARNING: "__copy_user" [fs/fat/fat.ko] has no CRC!
32 WARNING: EXPORT symbol "memset" [vmlinux] version generation failed, symbol will not be versioned.
32 WARNING: EXPORT symbol "copy_page" [vmlinux] version generation failed, symbol will not be versioned.
32 WARNING: EXPORT symbol "clear_page" [vmlinux] version generation failed, symbol will not be versioned.
32 WARNING: EXPORT symbol "__strncpy_from_user_nocheck_asm" [vmlinux] version generation failed, symbol will not be versioned.
The problem here is mainly the missing asm/asm-prototypes.h header file
that is supposed to include the prototypes for each symbol that is exported
from an assembler file.
A second problem is that the asm/uaccess.h header contains some but not
all the necessary declarations for the user access helpers.
Finally, the vdso build is broken once we add asm/asm-prototypes.h, so
we have to fix this at the same time by changing the vdso header. My
approach here is to just not look for exported symbols in the VDSO
assembler files, as the symbols cannot be exported anyway.
Fixes: 576a2f0c5c
("MIPS: Export memcpy & memset functions alongside their definitions")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: James Hogan <james.hogan@imgtec.com>
Cc: Maciej W. Rozycki <macro@imgtec.com>
Cc: linux-mips@linux-mips.org
Cc: linux-kernel@vger.kernel.org
Patchwork: https://patchwork.linux-mips.org/patch/15038/
Patchwork: https://patchwork.linux-mips.org/patch/15069/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
91 lines
2.1 KiB
ArmAsm
91 lines
2.1 KiB
ArmAsm
/*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*
|
|
* Copyright (c) 1996, 1998, 1999, 2004 by Ralf Baechle
|
|
* Copyright (c) 1999 Silicon Graphics, Inc.
|
|
*/
|
|
#include <asm/asm.h>
|
|
#include <asm/asm-offsets.h>
|
|
#include <asm/export.h>
|
|
#include <asm/regdef.h>
|
|
|
|
#define EX(insn,reg,addr,handler) \
|
|
9: insn reg, addr; \
|
|
.section __ex_table,"a"; \
|
|
PTR 9b, handler; \
|
|
.previous
|
|
|
|
/*
|
|
* Return the size of a string including the ending NUL character up to a
|
|
* maximum of a1 or 0 in case of error.
|
|
*
|
|
* Note: for performance reasons we deliberately accept that a user may
|
|
* make strlen_user and strnlen_user access the first few KSEG0
|
|
* bytes. There's nothing secret there. On 64-bit accessing beyond
|
|
* the maximum is a tad hairier ...
|
|
*/
|
|
.macro __BUILD_STRNLEN_ASM func
|
|
LEAF(__strnlen_\func\()_asm)
|
|
LONG_L v0, TI_ADDR_LIMIT($28) # pointer ok?
|
|
and v0, a0
|
|
bnez v0, .Lfault\@
|
|
|
|
FEXPORT(__strnlen_\func\()_nocheck_asm)
|
|
move v0, a0
|
|
PTR_ADDU a1, a0 # stop pointer
|
|
1:
|
|
#ifdef CONFIG_CPU_DADDI_WORKAROUNDS
|
|
.set noat
|
|
li AT, 1
|
|
#endif
|
|
beq v0, a1, 1f # limit reached?
|
|
.ifeqs "\func", "kernel"
|
|
EX(lb, t0, (v0), .Lfault\@)
|
|
.else
|
|
EX(lbe, t0, (v0), .Lfault\@)
|
|
.endif
|
|
.set noreorder
|
|
bnez t0, 1b
|
|
1:
|
|
#ifndef CONFIG_CPU_DADDI_WORKAROUNDS
|
|
PTR_ADDIU v0, 1
|
|
#else
|
|
PTR_ADDU v0, AT
|
|
.set at
|
|
#endif
|
|
.set reorder
|
|
PTR_SUBU v0, a0
|
|
jr ra
|
|
END(__strnlen_\func\()_asm)
|
|
|
|
.Lfault\@:
|
|
move v0, zero
|
|
jr ra
|
|
.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
|
|
EXPORT_SYMBOL(__strnlen_user_asm)
|
|
EXPORT_SYMBOL(__strnlen_user_nocheck_asm)
|
|
#endif
|
|
|
|
__BUILD_STRNLEN_ASM kernel
|
|
EXPORT_SYMBOL(__strnlen_kernel_asm)
|
|
EXPORT_SYMBOL(__strnlen_kernel_nocheck_asm)
|
|
|
|
#ifdef CONFIG_EVA
|
|
|
|
.set push
|
|
.set eva
|
|
__BUILD_STRNLEN_ASM user
|
|
.set pop
|
|
EXPORT_SYMBOL(__strnlen_user_asm)
|
|
EXPORT_SYMBOL(__strnlen_user_nocheck_asm)
|
|
#endif
|