-
Notifications
You must be signed in to change notification settings - Fork 3.8k
/
mono-stack-unwinding.h
126 lines (113 loc) · 3.39 KB
/
mono-stack-unwinding.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/**
* \file
* Copyright 2008-2010 Novell, Inc.
* Copyright 2011 Xamarin Inc.
* Licensed under the MIT license. See LICENSE file in the project root for full license information.
*/
#ifndef __MONO_MONO_STACK_UNWINDING_H__
#define __MONO_MONO_STACK_UNWINDING_H__
#include <mono/metadata/appdomain.h>
#include <mono/metadata/metadata.h>
#include <mono/utils/mono-context.h>
/*
* Possible frame types returned by the stack walker.
*/
typedef enum {
/* Normal managed frames */
FRAME_TYPE_MANAGED = 0,
/* Pseudo frame marking the start of a method invocation done by the soft debugger */
FRAME_TYPE_DEBUGGER_INVOKE = 1,
/* Frame for transitioning to native code */
FRAME_TYPE_MANAGED_TO_NATIVE = 2,
FRAME_TYPE_TRAMPOLINE = 3,
/* Interpreter frame */
FRAME_TYPE_INTERP = 4,
/* Frame for transitioning from interpreter to managed code */
FRAME_TYPE_INTERP_TO_MANAGED = 5,
/* same, but with MonoContext */
FRAME_TYPE_INTERP_TO_MANAGED_WITH_CTX = 6,
FRAME_TYPE_NUM = 7
} MonoStackFrameType;
typedef enum {
MONO_UNWIND_NONE = 0x0,
MONO_UNWIND_LOOKUP_IL_OFFSET = 0x1,
/* NOT signal safe */
MONO_UNWIND_LOOKUP_ACTUAL_METHOD = 0x2,
/*
* Store the locations where caller-saved registers are saved on the stack in
* frame->reg_locations. The pointer is only valid during the call to the unwind
* callback.
*/
MONO_UNWIND_REG_LOCATIONS = 0x4,
MONO_UNWIND_DEFAULT = MONO_UNWIND_LOOKUP_ACTUAL_METHOD,
MONO_UNWIND_SIGNAL_SAFE = MONO_UNWIND_NONE,
MONO_UNWIND_LOOKUP_ALL = MONO_UNWIND_LOOKUP_IL_OFFSET | MONO_UNWIND_LOOKUP_ACTUAL_METHOD,
} MonoUnwindOptions;
typedef struct {
MonoStackFrameType type;
/*
* For FRAME_TYPE_MANAGED, otherwise NULL.
*/
MonoJitInfo *ji;
/*
* Same as ji->method.
* Not valid if ASYNC_CONTEXT is true.
*/
MonoMethod *method;
/*
* If ji->method is a gshared method, this is the actual method instance.
* This is only filled if lookup for actual method was requested (MONO_UNWIND_LOOKUP_ACTUAL_METHOD)
* Not valid if ASYNC_CONTEXT is true.
*/
MonoMethod *actual_method;
/* The domain containing the code executed by this frame */
MonoDomain *domain;
/* Whenever method is a user level method */
gboolean managed;
/*
* Whenever this frame was loaded in async context.
*/
gboolean async_context;
int native_offset;
/*
* IL offset of this frame.
* Only available if the runtime have debugging enabled (--debug switch) and
* il offset resultion was requested (MONO_UNWIND_LOOKUP_IL_OFFSET)
*/
int il_offset;
/* For FRAME_TYPE_INTERP_EXIT */
gpointer interp_exit_data;
/* For FRAME_TYPE_INTERP */
gpointer interp_frame;
/*
* A stack address associated with the frame which can be used
* to compare frames.
* This is needed because ctx is not changed when unwinding through
* interpreter frames, it still refers to the last native interpreter
* frame.
*/
gpointer frame_addr;
/* The next fields are only useful for the jit */
gpointer lmf;
guint32 unwind_info_len;
guint8 *unwind_info;
host_mgreg_t **reg_locations;
} MonoStackFrameInfo;
/*Index into MonoThreadState::unwind_data. */
enum {
MONO_UNWIND_DATA_DOMAIN,
MONO_UNWIND_DATA_LMF,
MONO_UNWIND_DATA_JIT_TLS,
};
/*
* This structs holds all information needed to unwind the stack
* of a thread.
*/
typedef struct {
MonoContext ctx;
gpointer unwind_data [3]; /*right now: domain, lmf and jit_tls*/
gboolean valid;
void *gc_stackdata;
int gc_stackdata_size;
} MonoThreadUnwindState;
#endif