HPCToolkit
backtrace.h
Go to the documentation of this file.
1 // -*-Mode: C++;-*- // technically C99
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 #ifndef hpcrun_backtrace_h
48 #define hpcrun_backtrace_h
49 
50 //***************************************************************************
51 // file: backtrace.h
52 //
53 // purpose:
54 // an interface for performing stack unwinding
55 //
56 //***************************************************************************
57 
58 
59 //***************************************************************************
60 // system include files
61 //***************************************************************************
62 
63 #include <stddef.h>
64 #include <stdint.h>
65 #include <stdbool.h>
66 #include <ucontext.h>
67 
68 //***************************************************************************
69 // local include files
70 //***************************************************************************
71 
75 #include <hpcrun/frame.h>
76 
77 //
78 // backtrace_t type is a struct holding begin, end, current ptrs
79 // to frames
80 //
81 
82 typedef struct backtrace_t {
83  size_t size; // size of backtrace
84  size_t len; // # of frames used
85  frame_t* beg; // base memory chunk
86  frame_t* end; // the last available slot
87  frame_t* cur; // current insertion position
88 } backtrace_t;
89 
90 typedef struct bt_iter_t {
93 } bt_iter_t;
94 
95 //***************************************************************************
96 // interface functions
97 //***************************************************************************
98 
99 typedef bool bt_fn(backtrace_t* bt, ucontext_t* context);
100 typedef void* bt_fn_arg;
101 typedef void (*bt_mut_fn)(backtrace_t* bt, bt_fn_arg arg);
102 
103 bool hpcrun_backtrace_std(backtrace_t* bt, ucontext_t* context);
104 
105 frame_t* hpcrun_skip_chords(frame_t* bt_outer, frame_t* bt_inner,
106  int skip);
107 
108 void hpcrun_bt_dump(frame_t* unwind, const char* tag);
109 
110 void hpcrun_bt_init(backtrace_t* bt, size_t size);
111 
112 bool hpcrun_backtrace_std(backtrace_t* bt, ucontext_t* context);
113 
115  ucontext_t* context, int skipInner);
116 
118  ucontext_t* context, int skipInner);
119 
120 #endif // hpcrun_backtrace_h
void hpcrun_bt_init(backtrace_t *bt, size_t size)
Definition: backtrace.c:142
backtrace_t * bt
Definition: backtrace.h:92
frame_t * hpcrun_skip_chords(frame_t *bt_outer, frame_t *bt_inner, int skip)
Definition: backtrace.c:152
size_t len
Definition: backtrace.h:84
frame_t * beg
Definition: backtrace.h:85
frame_t * end
Definition: backtrace.h:86
void * bt_fn_arg
Definition: backtrace.h:100
struct backtrace_t backtrace_t
bool hpcrun_backtrace_std(backtrace_t *bt, ucontext_t *context)
frame_t * cur
Definition: backtrace.h:91
struct bt_iter_t bt_iter_t
void hpcrun_bt_dump(frame_t *unwind, const char *tag)
Definition: backtrace.c:90
void(* bt_mut_fn)(backtrace_t *bt, bt_fn_arg arg)
Definition: backtrace.h:101
bool hpcrun_generate_backtrace(backtrace_info_t *bt, ucontext_t *context, int skipInner)
Definition: backtrace.c:307
size_t size
Definition: backtrace.h:83
bool hpcrun_generate_backtrace_no_trampoline(backtrace_info_t *bt, ucontext_t *context, int skipInner)
Definition: backtrace.c:178
Definition: frame.h:58
frame_t * cur
Definition: backtrace.h:87
bool bt_fn(backtrace_t *bt, ucontext_t *context)
Definition: backtrace.h:99