HPCToolkit
unwind-cfg.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 unwind_cfg_h
48 #define unwind_cfg_h
49 
50 //************************* System Include Files ****************************
51 
52 //*************************** User Include Files ****************************
53 
54 //*************************** Forward Declarations **************************
55 
56 #define HPC_UNW_LITE 0
57 #define HPC_UNW_MSG 1
58 
59 //***************************************************************************
60 
61 // HPC_UNW_LITE: When this is set, we assume unwinding must work in a
62 // very restricted environment such as a SEGV handler. Performance is
63 // not critical. This is a useful starting point for abstracting the
64 // unwinder into a library.
65 //
66 // - We must avoid dynamic allocation which rules out the use of
67 // hpcrun_malloc. This implies we cannot use 'build_intervals()' to
68 // build all the intervals for a routine. Nor can we use the interval
69 // splay tree to store the intervals across invocations of hpcrun_unw_step().
70 // Therefore we must use intervals in a special way and pass them
71 // around as objects rather than pointers. This last requirement
72 // means that the platform-independent unwind cursor needs to store
73 // the whole platform-specific interval information.
74 //
75 // - We cannot use libmonitor to test for stack bottom.
76 //
77 // - We cannot use the fnbounds server
78 //
79 // - We cannot rely on a SEGV handler to correct unwinding mistakes
80 //
81 // - We may wish to avoid the 'pmsg' message printing library
82 
83 
84 #if (HPC_UNW_LITE)
85 # define HPC_IF_UNW_LITE(x) x
86 # define HPC_IFNO_UNW_LITE(x) /* remove */
87 #else
88 # define HPC_IF_UNW_LITE(x) /* remove */
89 # define HPC_IFNO_UNW_LITE(x) x
90 #endif
91 
92 
93 //***************************************************************************
94 
95 #endif // unwind_cfg_h