[PATCH 02/11] objtool: Only include valid definitions depending on source file type
Yuxuan Luo
yuxuan.luo at canonical.com
Wed Apr 17 23:53:52 UTC 2024
From: Julien Thierry <jthierry at redhat.com>
Header include/linux/objtool.h contains both C and assembly definition that
are visible regardless of the file including them.
Place definition under conditional __ASSEMBLY__.
Reviewed-by: Miroslav Benes <mbenes at suse.cz>
Signed-off-by: Julien Thierry <jthierry at redhat.com>
Signed-off-by: Josh Poimboeuf <jpoimboe at redhat.com>
(cherry picked from commit 5567c6c39f3404e4492c18c0c1abff5556684f6e)
CVE-2024-2201
Signed-off-by: Yuxuan Luo <yuxuan.luo at canonical.com>
---
include/linux/frame.h | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/include/linux/frame.h b/include/linux/frame.h
index 303cda600e56a..d946adb5de178 100644
--- a/include/linux/frame.h
+++ b/include/linux/frame.h
@@ -3,6 +3,8 @@
#define _LINUX_FRAME_H
#ifdef CONFIG_STACK_VALIDATION
+
+#ifndef __ASSEMBLY__
/*
* This macro marks the given function's stack frame as "non-standard", which
* tells objtool to ignore the function when doing stack metadata validation.
@@ -15,6 +17,8 @@
static void __used __section(.discard.func_stack_frame_non_standard) \
*__func_stack_frame_non_standard_##func = func
+#else /* __ASSEMBLY__ */
+
/*
* This macro indicates that the following intra-function call is valid.
* Any non-annotated intra-function call will cause objtool to issue a warning.
@@ -25,6 +29,8 @@
.long 999b; \
.popsection;
+#endif /* __ASSEMBLY__ */
+
#else /* !CONFIG_STACK_VALIDATION */
#define STACK_FRAME_NON_STANDARD(func)
--
2.34.1
More information about the kernel-team
mailing list