xref: /openbsd-src/gnu/llvm/compiler-rt/lib/memprof/memprof_stack.cpp (revision d89ec533011f513df1010f142a111086a0785f09)
1*d89ec533Spatrick //===-- memprof_stack.cpp ------------------------------------------------===//
2*d89ec533Spatrick //
3*d89ec533Spatrick // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*d89ec533Spatrick // See https://llvm.org/LICENSE.txt for license information.
5*d89ec533Spatrick // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*d89ec533Spatrick //
7*d89ec533Spatrick //===----------------------------------------------------------------------===//
8*d89ec533Spatrick //
9*d89ec533Spatrick // This file is a part of MemProfiler, a memory profiler.
10*d89ec533Spatrick //
11*d89ec533Spatrick // Code for MemProf stack trace.
12*d89ec533Spatrick //===----------------------------------------------------------------------===//
13*d89ec533Spatrick #include "memprof_stack.h"
14*d89ec533Spatrick #include "memprof_internal.h"
15*d89ec533Spatrick #include "sanitizer_common/sanitizer_atomic.h"
16*d89ec533Spatrick 
17*d89ec533Spatrick namespace __memprof {
18*d89ec533Spatrick 
19*d89ec533Spatrick static atomic_uint32_t malloc_context_size;
20*d89ec533Spatrick 
SetMallocContextSize(u32 size)21*d89ec533Spatrick void SetMallocContextSize(u32 size) {
22*d89ec533Spatrick   atomic_store(&malloc_context_size, size, memory_order_release);
23*d89ec533Spatrick }
24*d89ec533Spatrick 
GetMallocContextSize()25*d89ec533Spatrick u32 GetMallocContextSize() {
26*d89ec533Spatrick   return atomic_load(&malloc_context_size, memory_order_acquire);
27*d89ec533Spatrick }
28*d89ec533Spatrick 
29*d89ec533Spatrick } // namespace __memprof
30*d89ec533Spatrick 
UnwindImpl(uptr pc,uptr bp,void * context,bool request_fast,u32 max_depth)31*d89ec533Spatrick void __sanitizer::BufferedStackTrace::UnwindImpl(uptr pc, uptr bp,
32*d89ec533Spatrick                                                  void *context,
33*d89ec533Spatrick                                                  bool request_fast,
34*d89ec533Spatrick                                                  u32 max_depth) {
35*d89ec533Spatrick   using namespace __memprof;
36*d89ec533Spatrick   size = 0;
37*d89ec533Spatrick   if (UNLIKELY(!memprof_inited))
38*d89ec533Spatrick     return;
39*d89ec533Spatrick   request_fast = StackTrace::WillUseFastUnwind(request_fast);
40*d89ec533Spatrick   MemprofThread *t = GetCurrentThread();
41*d89ec533Spatrick   if (request_fast) {
42*d89ec533Spatrick     if (t) {
43*d89ec533Spatrick       Unwind(max_depth, pc, bp, nullptr, t->stack_top(), t->stack_bottom(),
44*d89ec533Spatrick              true);
45*d89ec533Spatrick     }
46*d89ec533Spatrick     return;
47*d89ec533Spatrick   }
48*d89ec533Spatrick   Unwind(max_depth, pc, bp, context, 0, 0, false);
49*d89ec533Spatrick }
50*d89ec533Spatrick 
51*d89ec533Spatrick // ------------------ Interface -------------- {{{1
52*d89ec533Spatrick 
53*d89ec533Spatrick extern "C" {
54*d89ec533Spatrick SANITIZER_INTERFACE_ATTRIBUTE
__sanitizer_print_stack_trace()55*d89ec533Spatrick void __sanitizer_print_stack_trace() {
56*d89ec533Spatrick   using namespace __memprof;
57*d89ec533Spatrick   PRINT_CURRENT_STACK();
58*d89ec533Spatrick }
59*d89ec533Spatrick } // extern "C"
60