Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a88a54a6 authored by Andrey Ryabinin's avatar Andrey Ryabinin Committed by Rishabh Bhatnagar
Browse files

arm64: lib: use C string functions with KASAN enabled

ARM64 has asm implementation of memchr(), memcmp(), str[r]chr(),
str[n]cmp(), str[n]len().  KASAN don't see memory accesses in asm code,
thus it can potentially miss many bugs.

Ifdef out __HAVE_ARCH_* defines of these functions when KASAN is enabled,
so the generic implementations from lib/string.c will be used.

We can't just remove the asm functions because efistub uses them.  And we
can't have two non-weak functions either, so declare the asm functions as
weak.

Change-Id: Id6dd5b621c05d2e269d99900af151368780b51f0
Link: http://lkml.kernel.org/r/20180920135631.23833-2-aryabinin@virtuozzo.com


Signed-off-by: default avatarAndrey Ryabinin <aryabinin@virtuozzo.com>
Reported-by: default avatarKyeongdon Kim <kyeongdon.kim@lge.com>
Cc: Alexander Potapenko <glider@google.com>
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Dmitry Vyukov <dvyukov@google.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Git-Repo: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git


Git-Commit: 19a2ca0fb560fd7be7b5293c6b652c6d6078dcde
Signed-off-by: default avatarRishabh Bhatnagar <rishabhb@codeaurora.org>
parent 43a79b1e
Loading
Loading
Loading
Loading
+8 −6
Original line number Original line Diff line number Diff line
@@ -16,6 +16,7 @@
#ifndef __ASM_STRING_H
#ifndef __ASM_STRING_H
#define __ASM_STRING_H
#define __ASM_STRING_H


#ifndef CONFIG_KASAN
#define __HAVE_ARCH_STRRCHR
#define __HAVE_ARCH_STRRCHR
extern char *strrchr(const char *, int c);
extern char *strrchr(const char *, int c);


@@ -34,6 +35,13 @@ extern __kernel_size_t strlen(const char *);
#define __HAVE_ARCH_STRNLEN
#define __HAVE_ARCH_STRNLEN
extern __kernel_size_t strnlen(const char *, __kernel_size_t);
extern __kernel_size_t strnlen(const char *, __kernel_size_t);


#define __HAVE_ARCH_MEMCMP
extern int memcmp(const void *, const void *, size_t);

#define __HAVE_ARCH_MEMCHR
extern void *memchr(const void *, int, __kernel_size_t);
#endif

#define __HAVE_ARCH_MEMCPY
#define __HAVE_ARCH_MEMCPY
extern void *memcpy(void *, const void *, __kernel_size_t);
extern void *memcpy(void *, const void *, __kernel_size_t);
extern void *__memcpy(void *, const void *, __kernel_size_t);
extern void *__memcpy(void *, const void *, __kernel_size_t);
@@ -42,16 +50,10 @@ extern void *__memcpy(void *, const void *, __kernel_size_t);
extern void *memmove(void *, const void *, __kernel_size_t);
extern void *memmove(void *, const void *, __kernel_size_t);
extern void *__memmove(void *, const void *, __kernel_size_t);
extern void *__memmove(void *, const void *, __kernel_size_t);


#define __HAVE_ARCH_MEMCHR
extern void *memchr(const void *, int, __kernel_size_t);

#define __HAVE_ARCH_MEMSET
#define __HAVE_ARCH_MEMSET
extern void *memset(void *, int, __kernel_size_t);
extern void *memset(void *, int, __kernel_size_t);
extern void *__memset(void *, int, __kernel_size_t);
extern void *__memset(void *, int, __kernel_size_t);


#define __HAVE_ARCH_MEMCMP
extern int memcmp(const void *, const void *, size_t);

#ifdef CONFIG_ARCH_HAS_UACCESS_FLUSHCACHE
#ifdef CONFIG_ARCH_HAS_UACCESS_FLUSHCACHE
#define __HAVE_ARCH_MEMCPY_FLUSHCACHE
#define __HAVE_ARCH_MEMCPY_FLUSHCACHE
void memcpy_flushcache(void *dst, const void *src, size_t cnt);
void memcpy_flushcache(void *dst, const void *src, size_t cnt);
+5 −2
Original line number Original line Diff line number Diff line
@@ -45,20 +45,23 @@ EXPORT_SYMBOL(__arch_copy_in_user);
EXPORT_SYMBOL(memstart_addr);
EXPORT_SYMBOL(memstart_addr);


	/* string / mem functions */
	/* string / mem functions */
#ifndef CONFIG_KASAN
EXPORT_SYMBOL(strchr);
EXPORT_SYMBOL(strchr);
EXPORT_SYMBOL(strrchr);
EXPORT_SYMBOL(strrchr);
EXPORT_SYMBOL(strcmp);
EXPORT_SYMBOL(strcmp);
EXPORT_SYMBOL(strncmp);
EXPORT_SYMBOL(strncmp);
EXPORT_SYMBOL(strlen);
EXPORT_SYMBOL(strlen);
EXPORT_SYMBOL(strnlen);
EXPORT_SYMBOL(strnlen);
EXPORT_SYMBOL(memcmp);
EXPORT_SYMBOL(memchr);
#endif

EXPORT_SYMBOL(memset);
EXPORT_SYMBOL(memset);
EXPORT_SYMBOL(memcpy);
EXPORT_SYMBOL(memcpy);
EXPORT_SYMBOL(memmove);
EXPORT_SYMBOL(memmove);
EXPORT_SYMBOL(__memset);
EXPORT_SYMBOL(__memset);
EXPORT_SYMBOL(__memcpy);
EXPORT_SYMBOL(__memcpy);
EXPORT_SYMBOL(__memmove);
EXPORT_SYMBOL(__memmove);
EXPORT_SYMBOL(memchr);
EXPORT_SYMBOL(memcmp);


	/* atomic bitops */
	/* atomic bitops */
EXPORT_SYMBOL(set_bit);
EXPORT_SYMBOL(set_bit);
+1 −1
Original line number Original line Diff line number Diff line
@@ -30,7 +30,7 @@
 * Returns:
 * Returns:
 *	x0 - address of first occurrence of 'c' or 0
 *	x0 - address of first occurrence of 'c' or 0
 */
 */
ENTRY(memchr)
WEAK(memchr)
	and	w1, w1, #0xff
	and	w1, w1, #0xff
1:	subs	x2, x2, #1
1:	subs	x2, x2, #1
	b.mi	2f
	b.mi	2f
+1 −1
Original line number Original line Diff line number Diff line
@@ -58,7 +58,7 @@ pos .req x11
limit_wd	.req	x12
limit_wd	.req	x12
mask		.req	x13
mask		.req	x13


ENTRY(memcmp)
WEAK(memcmp)
	cbz	limit, .Lret0
	cbz	limit, .Lret0
	eor	tmp1, src1, src2
	eor	tmp1, src1, src2
	tst	tmp1, #7
	tst	tmp1, #7
+1 −1
Original line number Original line Diff line number Diff line
@@ -29,7 +29,7 @@
 * Returns:
 * Returns:
 *	x0 - address of first occurrence of 'c' or 0
 *	x0 - address of first occurrence of 'c' or 0
 */
 */
ENTRY(strchr)
WEAK(strchr)
	and	w1, w1, #0xff
	and	w1, w1, #0xff
1:	ldrb	w2, [x0], #1
1:	ldrb	w2, [x0], #1
	cmp	w2, w1
	cmp	w2, w1
Loading