diff options
author | Arjan van de Ven <arjan@infradead.org> | 2009-09-30 07:05:23 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-10-01 05:31:04 -0400 |
commit | 4a3127693001c61a21d1ce680db6340623f52e93 (patch) | |
tree | 380f5f64098926e8b3f64785580cfdac1b8b3b96 /include | |
parent | ff60fab71bb3b4fdbf8caf57ff3739ffd0887396 (diff) |
x86: Turn the copy_from_user check into an (optional) compile time warning
A previous patch added the buffer size check to copy_from_user().
One of the things learned from analyzing the result of the previous
patch is that in general, gcc is really good at proving that the
code contains sufficient security checks to not need to do a
runtime check. But that for those cases where gcc could not prove
this, there was a relatively high percentage of real security
issues.
This patch turns the case of "gcc cannot prove" into a compile time
warning, as long as a sufficiently new gcc is in use that supports
this. The objective is that these warnings will trigger developers
checking new cases out before a security hole enters a linux kernel
release.
Signed-off-by: Arjan van de Ven <arjan@linux.intel.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: James Morris <jmorris@namei.org>
Cc: Jan Beulich <jbeulich@novell.com>
LKML-Reference: <20090930130523.348ae6c4@infradead.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/compiler-gcc4.h | 3 | ||||
-rw-r--r-- | include/linux/compiler.h | 4 |
2 files changed, 7 insertions, 0 deletions
diff --git a/include/linux/compiler-gcc4.h b/include/linux/compiler-gcc4.h index a3aef5d55dba..f1709c1f9eae 100644 --- a/include/linux/compiler-gcc4.h +++ b/include/linux/compiler-gcc4.h | |||
@@ -39,3 +39,6 @@ | |||
39 | #endif | 39 | #endif |
40 | 40 | ||
41 | #define __compiletime_object_size(obj) __builtin_object_size(obj, 0) | 41 | #define __compiletime_object_size(obj) __builtin_object_size(obj, 0) |
42 | #if __GNUC_MINOR__ >= 4 | ||
43 | #define __compiletime_warning(message) __attribute__((warning(message))) | ||
44 | #endif | ||
diff --git a/include/linux/compiler.h b/include/linux/compiler.h index 8e54108688f9..950356311f12 100644 --- a/include/linux/compiler.h +++ b/include/linux/compiler.h | |||
@@ -270,6 +270,10 @@ void ftrace_likely_update(struct ftrace_branch_data *f, int val, int expect); | |||
270 | #ifndef __compiletime_object_size | 270 | #ifndef __compiletime_object_size |
271 | # define __compiletime_object_size(obj) -1 | 271 | # define __compiletime_object_size(obj) -1 |
272 | #endif | 272 | #endif |
273 | #ifndef __compiletime_warning | ||
274 | # define __compiletime_warning(message) | ||
275 | #endif | ||
276 | |||
273 | /* | 277 | /* |
274 | * Prevent the compiler from merging or refetching accesses. The compiler | 278 | * Prevent the compiler from merging or refetching accesses. The compiler |
275 | * is also forbidden from reordering successive instances of ACCESS_ONCE(), | 279 | * is also forbidden from reordering successive instances of ACCESS_ONCE(), |