From: Maxim Ostapenko Date: Fri, 13 Jan 2017 10:08:50 +0000 (+0000) Subject: re PR sanitizer/78887 (Failure to build aarch64 allmodconfig Linux kernel 4.9) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0acd830b7e91e5b2d0e20fd0f5770544fd5f16ab;p=gcc.git re PR sanitizer/78887 (Failure to build aarch64 allmodconfig Linux kernel 4.9) PR sanitizer/78887 * asan.c (asan_needs_odr_indicator_p): Don't emit ODR indicators if -fsanitize=kernel-address is present. From-SVN: r244402 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index d79749ecefe..7aebebcbe00 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2017-01-13 Maxim Ostapenko + + 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 * tree-pretty-print.c (dump_generic_node): Dump INTEGER_CSTs diff --git a/gcc/asan.c b/gcc/asan.c index bc7ebc8f28a..74500448a12 100644 --- a/gcc/asan.c +++ b/gcc/asan.c @@ -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.