blob: 01e2ea2de9d759ece06a7af5c726061c1853d5e7 [file] [log] [blame]
Austin Schuhd57edc42019-09-21 17:52:38 -07001#
2# Copyright 2017 The Abseil Authors.
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# https://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15#
16
17#load("@rules_cc//cc:defs.bzl", "cc_library", "cc_test")
18load(
19 "//absl:copts/configure_copts.bzl",
20 "ABSL_DEFAULT_COPTS",
21 "ABSL_DEFAULT_LINKOPTS",
22 "ABSL_TEST_COPTS",
23)
24
25package(
26 default_visibility = ["//visibility:public"],
27)
28
29licenses(["notice"]) # Apache 2.0
30
31cc_library(
32 name = "stacktrace",
33 srcs = [
34 "stacktrace.cc",
35 ],
36 hdrs = ["stacktrace.h"],
37 copts = ABSL_DEFAULT_COPTS,
38 linkopts = ABSL_DEFAULT_LINKOPTS,
39 deps = [
40 ":debugging_internal",
41 "//absl/base:core_headers",
42 ],
43)
44
45cc_library(
46 name = "symbolize",
47 srcs = [
48 "symbolize.cc",
49 "symbolize_elf.inc",
50 "symbolize_unimplemented.inc",
51 "symbolize_win32.inc",
52 ],
53 hdrs = [
54 "internal/symbolize.h",
55 "symbolize.h",
56 ],
57 copts = ABSL_DEFAULT_COPTS,
58 linkopts = ABSL_DEFAULT_LINKOPTS,
59 deps = [
60 ":debugging_internal",
61 ":demangle_internal",
62 "//absl/base",
63 "//absl/base:core_headers",
64 "//absl/base:dynamic_annotations",
65 "//absl/base:malloc_internal",
66 "//absl/base:raw_logging_internal",
67 ],
68)
69
70cc_test(
71 name = "symbolize_test",
72 srcs = ["symbolize_test.cc"],
73 copts = ABSL_TEST_COPTS,
74 linkopts = ABSL_DEFAULT_LINKOPTS,
75 deps = [
76 ":stack_consumption",
77 ":symbolize",
78 "//absl/base",
79 "//absl/base:core_headers",
80 "//absl/base:raw_logging_internal",
81 "//absl/memory",
82 "@com_google_googletest//:gtest",
83 ],
84)
85
86cc_library(
87 name = "examine_stack",
88 srcs = [
89 "internal/examine_stack.cc",
90 ],
91 hdrs = [
92 "internal/examine_stack.h",
93 ],
94 copts = ABSL_DEFAULT_COPTS,
95 linkopts = ABSL_DEFAULT_LINKOPTS,
96 visibility = ["//visibility:private"],
97 deps = [
98 ":stacktrace",
99 ":symbolize",
100 "//absl/base:core_headers",
101 "//absl/base:raw_logging_internal",
102 ],
103)
104
105cc_library(
106 name = "failure_signal_handler",
107 srcs = ["failure_signal_handler.cc"],
108 hdrs = ["failure_signal_handler.h"],
109 copts = ABSL_DEFAULT_COPTS,
110 linkopts = ABSL_DEFAULT_LINKOPTS,
111 deps = [
112 ":examine_stack",
113 ":stacktrace",
114 "//absl/base",
115 "//absl/base:config",
116 "//absl/base:core_headers",
117 "//absl/base:raw_logging_internal",
118 ],
119)
120
121cc_test(
122 name = "failure_signal_handler_test",
123 srcs = ["failure_signal_handler_test.cc"],
124 copts = ABSL_TEST_COPTS,
125 linkopts = select({
126 "//absl:windows": [],
127 "//conditions:default": ["-pthread"],
128 }) + ABSL_DEFAULT_LINKOPTS,
129 deps = [
130 ":failure_signal_handler",
131 ":stacktrace",
132 ":symbolize",
133 "//absl/base:raw_logging_internal",
134 "//absl/strings",
135 "@com_google_googletest//:gtest",
136 ],
137)
138
139cc_library(
140 name = "debugging_internal",
141 srcs = [
142 "internal/address_is_readable.cc",
143 "internal/elf_mem_image.cc",
144 "internal/vdso_support.cc",
145 ],
146 hdrs = [
147 "internal/address_is_readable.h",
148 "internal/elf_mem_image.h",
149 "internal/stacktrace_aarch64-inl.inc",
150 "internal/stacktrace_arm-inl.inc",
151 "internal/stacktrace_config.h",
152 "internal/stacktrace_generic-inl.inc",
153 "internal/stacktrace_powerpc-inl.inc",
154 "internal/stacktrace_unimplemented-inl.inc",
155 "internal/stacktrace_win32-inl.inc",
156 "internal/stacktrace_x86-inl.inc",
157 "internal/vdso_support.h",
158 ],
159 copts = ABSL_DEFAULT_COPTS,
160 linkopts = ABSL_DEFAULT_LINKOPTS,
161 deps = [
162 "//absl/base:core_headers",
163 "//absl/base:dynamic_annotations",
164 "//absl/base:raw_logging_internal",
165 ],
166)
167
168cc_library(
169 name = "demangle_internal",
170 srcs = ["internal/demangle.cc"],
171 hdrs = ["internal/demangle.h"],
172 copts = ABSL_DEFAULT_COPTS,
173 deps = [
174 "//absl/base",
175 "//absl/base:core_headers",
176 ],
177)
178
179cc_test(
180 name = "demangle_test",
181 srcs = ["internal/demangle_test.cc"],
182 copts = ABSL_TEST_COPTS,
183 linkopts = ABSL_DEFAULT_LINKOPTS,
184 deps = [
185 ":demangle_internal",
186 ":stack_consumption",
187 "//absl/base:core_headers",
188 "//absl/base:raw_logging_internal",
189 "//absl/memory",
190 "@com_google_googletest//:gtest_main",
191 ],
192)
193
194cc_library(
195 name = "leak_check",
196 srcs = ["leak_check.cc"],
197 hdrs = ["leak_check.h"],
198 linkopts = ABSL_DEFAULT_LINKOPTS,
199 deps = ["//absl/base:core_headers"],
200)
201
202# Adding a dependency to leak_check_disable will disable
203# sanitizer leak checking (asan/lsan) in a test without
204# the need to mess around with build features.
205cc_library(
206 name = "leak_check_disable",
207 srcs = ["leak_check_disable.cc"],
208 linkopts = ABSL_DEFAULT_LINKOPTS,
209 linkstatic = 1,
210 alwayslink = 1,
211)
212
213# These targets exists for use in tests only, explicitly configuring the
214# LEAK_SANITIZER macro. It must be linked with -fsanitize=leak for lsan.
215ABSL_LSAN_LINKOPTS = select({
216 "//absl:llvm_compiler": ["-fsanitize=leak"],
217 "//conditions:default": [],
218})
219
220cc_library(
221 name = "leak_check_api_enabled_for_testing",
222 testonly = 1,
223 srcs = ["leak_check.cc"],
224 hdrs = ["leak_check.h"],
225 copts = select({
226 "//absl:llvm_compiler": ["-DLEAK_SANITIZER"],
227 "//conditions:default": [],
228 }),
229 linkopts = ABSL_DEFAULT_LINKOPTS,
230 visibility = ["//visibility:private"],
231)
232
233cc_library(
234 name = "leak_check_api_disabled_for_testing",
235 testonly = 1,
236 srcs = ["leak_check.cc"],
237 hdrs = ["leak_check.h"],
238 copts = ["-ULEAK_SANITIZER"],
239 linkopts = ABSL_DEFAULT_LINKOPTS,
240 visibility = ["//visibility:private"],
241)
242
243cc_test(
244 name = "leak_check_test",
245 srcs = ["leak_check_test.cc"],
246 copts = select({
247 "//absl:llvm_compiler": ["-DABSL_EXPECT_LEAK_SANITIZER"],
248 "//conditions:default": [],
249 }),
250 linkopts = ABSL_LSAN_LINKOPTS + ABSL_DEFAULT_LINKOPTS,
251 tags = ["notsan"],
252 deps = [
253 ":leak_check_api_enabled_for_testing",
254 "//absl/base",
255 "@com_google_googletest//:gtest_main",
256 ],
257)
258
259cc_test(
260 name = "leak_check_no_lsan_test",
261 srcs = ["leak_check_test.cc"],
262 copts = ["-UABSL_EXPECT_LEAK_SANITIZER"],
263 linkopts = ABSL_DEFAULT_LINKOPTS,
264 tags = ["noasan"],
265 deps = [
266 ":leak_check_api_disabled_for_testing",
267 "//absl/base", # for raw_logging
268 "@com_google_googletest//:gtest_main",
269 ],
270)
271
272# Test that leak checking is skipped when lsan is enabled but
273# ":leak_check_disable" is linked in.
274#
275# This test should fail in the absence of a dependency on ":leak_check_disable"
276cc_test(
277 name = "disabled_leak_check_test",
278 srcs = ["leak_check_fail_test.cc"],
279 linkopts = ABSL_LSAN_LINKOPTS + ABSL_DEFAULT_LINKOPTS,
280 tags = ["notsan"],
281 deps = [
282 ":leak_check_api_enabled_for_testing",
283 ":leak_check_disable",
284 "//absl/base",
285 "@com_google_googletest//:gtest_main",
286 ],
287)
288
289cc_library(
290 name = "stack_consumption",
291 testonly = 1,
292 srcs = ["internal/stack_consumption.cc"],
293 hdrs = ["internal/stack_consumption.h"],
294 copts = ABSL_DEFAULT_COPTS,
295 linkopts = ABSL_DEFAULT_LINKOPTS,
296 visibility = ["//visibility:private"],
297 deps = [
298 "//absl/base:core_headers",
299 "//absl/base:raw_logging_internal",
300 ],
301)
302
303cc_test(
304 name = "stack_consumption_test",
305 srcs = ["internal/stack_consumption_test.cc"],
306 copts = ABSL_TEST_COPTS,
307 linkopts = ABSL_DEFAULT_LINKOPTS,
308 deps = [
309 ":stack_consumption",
310 "//absl/base:core_headers",
311 "//absl/base:raw_logging_internal",
312 "@com_google_googletest//:gtest_main",
313 ],
314)