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