diff options
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/asan.c | 11 |
2 files changed, 16 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index d79749e..7aebebc 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2017-01-13 Maxim Ostapenko <m.ostapenko@samsung.com> + + PR sanitizer/78887 + * asan.c (asan_needs_odr_indicator_p): Don't emit ODR indicators + if -fsanitize=kernel-address is present. + 2017-01-13 Richard Biener <rguenther@suse.de> * tree-pretty-print.c (dump_generic_node): Dump INTEGER_CSTs @@ -2360,7 +2360,16 @@ create_odr_indicator (tree decl, tree type) static bool asan_needs_odr_indicator_p (tree decl) { - return !DECL_ARTIFICIAL (decl) && !DECL_WEAK (decl) && TREE_PUBLIC (decl); + /* Don't emit ODR indicators for kernel because: + a) Kernel is written in C thus doesn't need ODR indicators. + b) Some kernel code may have assumptions about symbols containing specific + patterns in their names. Since ODR indicators contain original names + of symbols they are emitted for, these assumptions would be broken for + ODR indicator symbols. */ + return (!(flag_sanitize & SANITIZE_KERNEL_ADDRESS) + && !DECL_ARTIFICIAL (decl) + && !DECL_WEAK (decl) + && TREE_PUBLIC (decl)); } /* Append description of a single global DECL into vector V. |