Commit dde709d1 authored by Vasily Gorbik's avatar Vasily Gorbik Committed by Martin Schwidefsky

compiler: introduce __no_sanitize_address_or_inline

Due to conflict between kasan instrumentation and inlining
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=67368 functions which are
defined as inline could not be called from functions defined with
__no_sanitize_address.

Introduce __no_sanitize_address_or_inline which would expand to
__no_sanitize_address when the kernel is built with kasan support and
to inline otherwise. This helps to avoid disabling kasan
instrumentation for entire files.
Reviewed-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent d58106c3
...@@ -208,6 +208,12 @@ ...@@ -208,6 +208,12 @@
* Conflicts with inlining: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=67368 * Conflicts with inlining: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=67368
*/ */
#define __no_sanitize_address __attribute__((no_sanitize_address)) #define __no_sanitize_address __attribute__((no_sanitize_address))
#ifdef CONFIG_KASAN
#define __no_sanitize_address_or_inline \
__no_sanitize_address __maybe_unused notrace
#else
#define __no_sanitize_address_or_inline inline
#endif
#endif #endif
#if GCC_VERSION >= 50100 #if GCC_VERSION >= 50100
...@@ -225,6 +231,7 @@ ...@@ -225,6 +231,7 @@
#if !defined(__no_sanitize_address) #if !defined(__no_sanitize_address)
#define __no_sanitize_address #define __no_sanitize_address
#define __no_sanitize_address_or_inline inline
#endif #endif
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment