All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2 1/3] compiler.h: define __no_initialize
@ 2020-03-02 13:04 ` glider
  0 siblings, 0 replies; 52+ messages in thread
From: glider @ 2020-03-02 13:04 UTC (permalink / raw)
  To: tkjos, keescook, gregkh, arve, mingo
  Cc: dvyukov, jannh, devel, peterz, linux-kernel, Alexander Potapenko

For CONFIG_INIT_STACK_ALL it's sometimes handy to disable
force-initialization for a local variable, if it is known to be initialized
later on before the first use. This can be done by using the
__no_initialize macro.

__no_initialize should be applied carefully, as future changes to
the code around the local variable may introduce paths on which the
variable remains uninitialized before the use.

Signed-off-by: Alexander Potapenko <glider@google.com>

---

v2:
 - changed __do_not_initialize to __no_initialize as requested by Kees
   Cook
---
 include/linux/compiler-clang.h | 10 ++++++++++
 include/linux/compiler_types.h |  4 ++++
 2 files changed, 14 insertions(+)

diff --git a/include/linux/compiler-clang.h b/include/linux/compiler-clang.h
index 333a6695a918c..27f774b27b061 100644
--- a/include/linux/compiler-clang.h
+++ b/include/linux/compiler-clang.h
@@ -24,6 +24,16 @@
 #define __no_sanitize_address
 #endif
 
+/*
+ * Disable initialization of a local variable when building with
+ * CONFIG_INIT_STACK_ALL.
+ */
+#ifdef CONFIG_INIT_STACK_ALL
+#define __no_initialize __attribute__((uninitialized))
+#else
+#define __no_initialize
+#endif
+
 /*
  * Not all versions of clang implement the the type-generic versions
  * of the builtin overflow checkers. Fortunately, clang implements
diff --git a/include/linux/compiler_types.h b/include/linux/compiler_types.h
index 72393a8c1a6c5..0208699c855af 100644
--- a/include/linux/compiler_types.h
+++ b/include/linux/compiler_types.h
@@ -216,6 +216,10 @@ struct ftrace_likely_data {
 # define __no_fgcse
 #endif
 
+#ifndef __no_initialize
+#define __no_initialize
+#endif
+
 /* Are two types/vars the same type (ignoring qualifiers)? */
 #define __same_type(a, b) __builtin_types_compatible_p(typeof(a), typeof(b))
 
-- 
2.25.0.265.gbab2e86ba0-goog


^ permalink raw reply related	[flat|nested] 52+ messages in thread

end of thread, other threads:[~2020-03-06  2:29 UTC | newest]

Thread overview: 52+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-03-02 13:04 [PATCH v2 1/3] compiler.h: define __no_initialize glider
2020-03-02 13:04 ` glider
2020-03-02 13:04 ` [PATCH v2 2/3] binder: do not initialize locals passed to copy_from_user() glider
2020-03-02 13:04   ` glider
2020-03-02 13:09   ` Joe Perches
2020-03-02 13:09     ` Joe Perches
2020-03-02 13:25     ` Alexander Potapenko
2020-03-02 13:25       ` Alexander Potapenko
2020-03-02 13:52       ` Dan Carpenter
2020-03-02 13:52         ` Dan Carpenter
2020-03-02 13:58       ` Joe Perches
2020-03-02 13:58         ` Joe Perches
2020-03-02 18:17         ` Alexander Potapenko
2020-03-02 18:17           ` Alexander Potapenko
2020-03-02 18:31           ` Jann Horn
2020-03-02 18:31             ` Jann Horn
2020-03-05  9:03             ` Rasmus Villemoes
2020-03-05  9:03               ` Rasmus Villemoes
2020-03-05 12:45               ` Jann Horn
2020-03-05 12:45                 ` Jann Horn
2020-03-06  2:29               ` Al Viro
2020-03-06  2:29                 ` Al Viro
2020-03-02 18:50           ` Joe Perches
2020-03-02 18:50             ` Joe Perches
2020-03-03  9:14             ` Alexander Potapenko
2020-03-03  9:14               ` Alexander Potapenko
2020-03-03  9:38               ` Dan Carpenter
2020-03-03  9:38                 ` Dan Carpenter
2020-03-03 13:56                 ` Joe Perches
2020-03-03 13:56                   ` Joe Perches
2020-03-03 14:15                   ` Dan Carpenter
2020-03-03 14:15                     ` Dan Carpenter
2020-03-04 18:13                 ` Kees Cook
2020-03-04 18:13                   ` Kees Cook
2020-03-05  8:07                   ` Dan Carpenter
2020-03-05  8:07                     ` Dan Carpenter
2020-03-05  8:26                     ` Kees Cook
2020-03-05  8:26                       ` Kees Cook
2020-03-05  8:33                       ` Alexander Potapenko
2020-03-05  8:33                         ` Alexander Potapenko
2020-03-02 17:38   ` Greg KH
2020-03-02 17:38     ` Greg KH
2020-03-02 18:28     ` Alexander Potapenko
2020-03-02 18:28       ` Alexander Potapenko
2020-03-02 13:04 ` [PATCH v2 3/3] sched/wait: avoid double initialization in ___wait_event() glider
2020-03-02 13:04   ` glider
2020-03-02 16:56   ` Todd Kjos
2020-03-02 16:56     ` Todd Kjos
2020-03-02 18:03     ` Alexander Potapenko
2020-03-02 18:03       ` Alexander Potapenko
2020-03-02 18:39       ` Greg Kroah-Hartman
2020-03-02 18:39         ` Greg Kroah-Hartman

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.