1 //===-- tsan_stack_trace.cpp ----------------------------------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 // This file is a part of ThreadSanitizer (TSan), a race detector.
11 //===----------------------------------------------------------------------===//
12 #include "tsan_stack_trace.h"
14 #include "tsan_mman.h"
18 VarSizeStackTrace::VarSizeStackTrace()
19 : StackTrace(nullptr, 0), trace_buffer(nullptr) {}
21 VarSizeStackTrace::~VarSizeStackTrace() {
25 void VarSizeStackTrace::ResizeBuffer(uptr new_size
) {
27 internal_free(trace_buffer
);
31 ? (uptr
*)internal_alloc(MBlockStackTrace
,
32 new_size
* sizeof(trace_buffer
[0]))
38 void VarSizeStackTrace::Init(const uptr
*pcs
, uptr cnt
, uptr extra_top_pc
) {
39 ResizeBuffer(cnt
+ !!extra_top_pc
);
40 internal_memcpy(trace_buffer
, pcs
, cnt
* sizeof(trace_buffer
[0]));
42 trace_buffer
[cnt
] = extra_top_pc
;
45 void VarSizeStackTrace::ReverseOrder() {
46 for (u32 i
= 0; i
< (size
>> 1); i
++)
47 Swap(trace_buffer
[i
], trace_buffer
[size
- 1 - i
]);
53 void __sanitizer::BufferedStackTrace::UnwindImpl(
54 uptr pc
, uptr bp
, void *context
, bool request_fast
, u32 max_depth
) {
57 if (StackTrace::WillUseFastUnwind(request_fast
)) {
58 GetThreadStackTopAndBottom(false, &top
, &bottom
);
59 Unwind(max_depth
, pc
, bp
, nullptr, top
, bottom
, true);
61 Unwind(max_depth
, pc
, 0, context
, 0, 0, false);
63 #endif // SANITIZER_GO