summaryrefslogtreecommitdiffstats
path: root/build/config/sanitizers/BUILD.gn
diff options
context:
space:
mode:
Diffstat (limited to 'build/config/sanitizers/BUILD.gn')
-rw-r--r--build/config/sanitizers/BUILD.gn127
1 files changed, 77 insertions, 50 deletions
diff --git a/build/config/sanitizers/BUILD.gn b/build/config/sanitizers/BUILD.gn
index 55882f8..d0edf5f 100644
--- a/build/config/sanitizers/BUILD.gn
+++ b/build/config/sanitizers/BUILD.gn
@@ -10,7 +10,14 @@ import("//build/config/sanitizers/sanitizers.gni")
# |is_asan|, |is_lsan|, |is_tsan|, |is_msan| and |use_custom_libcxx| are false.
group("deps") {
if (using_sanitizer) {
- public_configs = [ ":sanitizer_options_link_helper" ]
+ public_configs = [
+ ":sanitizer_options_link_helper",
+
+ # Even when a target removes default_sanitizer_flags, it may be depending
+ # on a library that did not remove default_sanitizer_flags. Thus, we need
+ # to add the ldflags here as well as in default_sanitizer_flags.
+ ":default_sanitizer_ldflags",
+ ]
deps = [
":options_sources",
]
@@ -26,24 +33,6 @@ group("deps") {
config("sanitizer_options_link_helper") {
ldflags = [ "-Wl,-u_sanitizer_options_link_helper" ]
- if (is_asan) {
- ldflags += [ "-fsanitize=address" ]
- }
- if (is_lsan) {
- ldflags += [ "-fsanitize=leak" ]
- }
- if (is_tsan) {
- ldflags += [ "-fsanitize=thread" ]
- }
- if (is_msan) {
- ldflags += [ "-fsanitize=memory" ]
- }
- if (is_ubsan) {
- ldflags += [ "-fsanitize=undefined" ]
- }
- if (is_ubsan_vptr) {
- ldflags += [ "-fsanitize=vptr" ]
- }
}
source_set("options_sources") {
@@ -74,16 +63,83 @@ source_set("options_sources") {
}
}
+# Applies linker flags necessary when either :deps or :default_sanitizer_flags
+# are used.
+config("default_sanitizer_ldflags") {
+ visibility = [
+ ":default_sanitizer_flags",
+ ":deps",
+ ]
+
+ if (is_posix) {
+ ldflags = []
+ if (is_asan) {
+ ldflags += [ "-fsanitize=address" ]
+ }
+ if (is_lsan) {
+ ldflags += [ "-fsanitize=leak" ]
+ }
+ if (is_tsan) {
+ ldflags += [ "-fsanitize=thread" ]
+ }
+ if (is_msan) {
+ ldflags += [ "-fsanitize=memory" ]
+ }
+ if (is_ubsan) {
+ ldflags += [ "-fsanitize=undefined" ]
+ }
+ if (is_ubsan_vptr) {
+ ldflags += [ "-fsanitize=vptr" ]
+ }
+ if (is_cfi && !is_nacl) {
+ ldflags += [
+ "-flto",
+ "-fsanitize=cfi-vcall",
+ "-fsanitize=cfi-derived-cast",
+ "-fsanitize=cfi-unrelated-cast",
+ ]
+
+ # Apply a lower LTO optimization level as the default is too slow.
+ if (is_linux) {
+ ldflags += [ "-Wl,-plugin-opt,O1" ]
+ } else if (is_mac) {
+ ldflags += [ "-Wl,-mllvm,-O1" ]
+ }
+
+ # Work-around for http://openradar.appspot.com/20356002
+ if (is_mac) {
+ ldflags += [ "-Wl,-all_load" ]
+ }
+
+ # Without this flag, LTO produces a .text section that is larger
+ # than the maximum call displacement, preventing the linker from
+ # relocating calls (http://llvm.org/PR22999).
+ if (current_cpu == "arm") {
+ ldflags += [ "-Wl,-plugin-opt,-function-sections" ]
+ }
+
+ if (use_cfi_diag) {
+ ldflags += [
+ "-fno-sanitize-trap=cfi",
+ "-fsanitize-recover=cfi",
+ ]
+ }
+ }
+ }
+}
+
# This config is applied by default to all targets. It sets the compiler flags
# for sanitizer usage, or, if no sanitizer is set, does nothing.
#
# This needs to be in a separate config so that targets can opt out of
-# sanitizers if they desire.
+# sanitizers (by removing the config) if they desire. Even if a target
+# removes this config, executables & shared libraries should still depend on
+# :deps if any of their dependencies have not opted out of sanitizers.
config("default_sanitizer_flags") {
cflags = []
cflags_cc = []
- ldflags = []
defines = []
+ configs = [ ":default_sanitizer_ldflags" ]
# Only works on Posix-like platforms.
# FIXME: this is not true, remove the conditional.
@@ -190,41 +246,12 @@ config("default_sanitizer_flags") {
"-fsanitize=cfi-unrelated-cast",
"-fsanitize-blacklist=$cfi_blacklist_path",
]
- ldflags += [
- "-flto",
- "-fsanitize=cfi-vcall",
- "-fsanitize=cfi-derived-cast",
- "-fsanitize=cfi-unrelated-cast",
- ]
-
- # Apply a lower LTO optimization level as the default is too slow.
- if (is_linux) {
- ldflags += [ "-Wl,-plugin-opt,O1" ]
- } else if (is_mac) {
- ldflags += [ "-Wl,-mllvm,-O1" ]
- }
-
- # Work-around for http://openradar.appspot.com/20356002
- if (is_mac) {
- ldflags += [ "-Wl,-all_load" ]
- }
-
- # Without this flag, LTO produces a .text section that is larger
- # than the maximum call displacement, preventing the linker from
- # relocating calls (http://llvm.org/PR22999).
- if (current_cpu == "arm") {
- ldflags += [ "-Wl,-plugin-opt,-function-sections" ]
- }
if (use_cfi_diag) {
cflags += [
"-fno-sanitize-trap=cfi",
"-fsanitize-recover=cfi",
]
- ldflags += [
- "-fno-sanitize-trap=cfi",
- "-fsanitize-recover=cfi",
- ]
} else {
defines += [ "CFI_ENFORCEMENT" ]
}