annotate libsanitizer/tsan/tsan_stack_trace.cpp @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 //===-- tsan_stack_trace.cpp ----------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 // This file is a part of ThreadSanitizer (TSan), a race detector.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 //===----------------------------------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 #include "tsan_stack_trace.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 #include "tsan_rtl.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 #include "tsan_mman.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 namespace __tsan {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 VarSizeStackTrace::VarSizeStackTrace()
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 : StackTrace(nullptr, 0), trace_buffer(nullptr) {}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 VarSizeStackTrace::~VarSizeStackTrace() {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 ResizeBuffer(0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 void VarSizeStackTrace::ResizeBuffer(uptr new_size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26 if (trace_buffer) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 internal_free(trace_buffer);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 trace_buffer =
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 (new_size > 0)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 ? (uptr *)internal_alloc(MBlockStackTrace,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 new_size * sizeof(trace_buffer[0]))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 : nullptr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 trace = trace_buffer;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 size = new_size;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 void VarSizeStackTrace::Init(const uptr *pcs, uptr cnt, uptr extra_top_pc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 ResizeBuffer(cnt + !!extra_top_pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 internal_memcpy(trace_buffer, pcs, cnt * sizeof(trace_buffer[0]));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 if (extra_top_pc)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42 trace_buffer[cnt] = extra_top_pc;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 void VarSizeStackTrace::ReverseOrder() {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 for (u32 i = 0; i < (size >> 1); i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 Swap(trace_buffer[i], trace_buffer[size - 1 - i]);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 } // namespace __tsan
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 #if !SANITIZER_GO
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 void __sanitizer::BufferedStackTrace::UnwindImpl(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 uptr pc, uptr bp, void *context, bool request_fast, u32 max_depth) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 uptr top = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 uptr bottom = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57 if (StackTrace::WillUseFastUnwind(request_fast)) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58 GetThreadStackTopAndBottom(false, &top, &bottom);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 Unwind(max_depth, pc, bp, nullptr, top, bottom, true);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60 } else
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 Unwind(max_depth, pc, 0, context, 0, 0, false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63 #endif // SANITIZER_GO