do not check order sequence if option /order was not used
[mono.git] / mono / metadata / mono-debug.h
1 /*
2  * This header is only installed for use by the debugger:
3  * the structures and the API declared here are not supported.
4  */
5
6 #ifndef __MONO_DEBUG_H__
7 #define __MONO_DEBUG_H__
8
9 #include <mono/utils/mono-publib.h>
10 #include <mono/metadata/image.h>
11 #include <mono/metadata/appdomain.h>
12
13 MONO_BEGIN_DECLS
14
15 typedef struct _MonoSymbolTable                 MonoSymbolTable;
16 typedef struct _MonoDebugDataTable              MonoDebugDataTable;
17
18 typedef struct _MonoSymbolFile                  MonoSymbolFile;
19
20 typedef struct _MonoDebugHandle                 MonoDebugHandle;
21
22 typedef struct _MonoDebugLineNumberEntry        MonoDebugLineNumberEntry;
23
24 typedef struct _MonoDebugVarInfo                MonoDebugVarInfo;
25 typedef struct _MonoDebugMethodJitInfo          MonoDebugMethodJitInfo;
26 typedef struct _MonoDebugMethodAddress          MonoDebugMethodAddress;
27 typedef struct _MonoDebugMethodAddressList      MonoDebugMethodAddressList;
28 typedef struct _MonoDebugClassEntry             MonoDebugClassEntry;
29
30 typedef struct _MonoDebugMethodInfo             MonoDebugMethodInfo;
31 typedef struct _MonoDebugLocalsInfo             MonoDebugLocalsInfo;
32 typedef struct _MonoDebugSourceLocation         MonoDebugSourceLocation;
33
34 typedef struct _MonoDebugList                   MonoDebugList;
35
36 typedef enum {
37         MONO_DEBUG_FORMAT_NONE,
38         MONO_DEBUG_FORMAT_MONO,
39         MONO_DEBUG_FORMAT_DEBUGGER
40 } MonoDebugFormat;
41
42 /*
43  * NOTE:
44  * We intentionally do not use GList here since the debugger needs to know about
45  * the layout of the fields.
46 */
47 struct _MonoDebugList {
48         MonoDebugList *next;
49         const void* data;
50 };
51
52 struct _MonoSymbolTable {
53         uint64_t magic;
54         uint32_t version;
55         uint32_t total_size;
56
57         /*
58          * Corlib and metadata info.
59          */
60         MonoDebugHandle *corlib;
61         MonoDebugDataTable *global_data_table;
62         MonoDebugList *data_tables;
63
64         /*
65          * The symbol files.
66          */
67         MonoDebugList *symbol_files;
68 };
69
70 struct _MonoDebugHandle {
71         uint32_t index;
72         char *image_file;
73         MonoImage *image;
74         MonoDebugDataTable *type_table;
75         MonoSymbolFile *symfile;
76 };
77
78 struct _MonoDebugMethodJitInfo {
79         const mono_byte *code_start;
80         uint32_t code_size;
81         uint32_t prologue_end;
82         uint32_t epilogue_begin;
83         const mono_byte *wrapper_addr;
84         uint32_t num_line_numbers;
85         MonoDebugLineNumberEntry *line_numbers;
86         uint32_t num_params;
87         MonoDebugVarInfo *this_var;
88         MonoDebugVarInfo *params;
89         uint32_t num_locals;
90         MonoDebugVarInfo *locals;
91 };
92
93 struct _MonoDebugMethodAddressList {
94         uint32_t size;
95         uint32_t count;
96         mono_byte data [MONO_ZERO_LEN_ARRAY];
97 };
98
99 struct _MonoDebugSourceLocation {
100         char *source_file;
101         uint32_t row, column;
102         uint32_t il_offset;
103 };
104
105 /*
106  * These bits of the MonoDebugLocalInfo's "index" field are flags specifying
107  * where the variable is actually stored.
108  *
109  * See relocate_variable() in debug-symfile.c for more info.
110  */
111 #define MONO_DEBUG_VAR_ADDRESS_MODE_FLAGS               0xf0000000
112
113 /* The variable is in register "index". */
114 #define MONO_DEBUG_VAR_ADDRESS_MODE_REGISTER            0
115
116 /* The variable is at offset "offset" from register "index". */
117 #define MONO_DEBUG_VAR_ADDRESS_MODE_REGOFFSET           0x10000000
118
119 /* The variable is in the two registers "offset" and "index". */
120 #define MONO_DEBUG_VAR_ADDRESS_MODE_TWO_REGISTERS       0x20000000
121
122 /* The variable is dead. */
123 #define MONO_DEBUG_VAR_ADDRESS_MODE_DEAD                0x30000000
124
125 struct _MonoDebugVarInfo {
126         uint32_t index;
127         uint32_t offset;
128         uint32_t size;
129         uint32_t begin_scope;
130         uint32_t end_scope;
131         MonoType *type;
132 };
133
134 #define MONO_DEBUGGER_MAJOR_VERSION                     81
135 #define MONO_DEBUGGER_MINOR_VERSION                     6
136 #define MONO_DEBUGGER_MAGIC                             0x7aff65af4253d427ULL
137
138 extern MonoSymbolTable *mono_symbol_table;
139 extern MonoDebugFormat mono_debug_format;
140 extern int32_t mono_debug_debugger_version;
141 extern int32_t _mono_debug_using_mono_debugger;
142
143 void mono_debug_list_add (MonoDebugList **list, const void* data);
144 void mono_debug_list_remove (MonoDebugList **list, const void* data);
145
146 void mono_debug_init (MonoDebugFormat format);
147 void mono_debug_open_image_from_memory (MonoImage *image, const mono_byte *raw_contents, int size);
148 void mono_debug_cleanup (void);
149
150 void mono_debug_close_image (MonoImage *image);
151
152 void mono_debug_domain_unload (MonoDomain *domain);
153 void mono_debug_domain_create (MonoDomain *domain);
154
155 mono_bool mono_debug_using_mono_debugger (void);
156
157 MonoDebugMethodAddress *
158 mono_debug_add_method (MonoMethod *method, MonoDebugMethodJitInfo *jit, MonoDomain *domain);
159
160 void
161 mono_debug_remove_method (MonoMethod *method, MonoDomain *domain);
162
163 MonoDebugMethodInfo *
164 mono_debug_lookup_method (MonoMethod *method);
165
166 MonoDebugMethodAddressList *
167 mono_debug_lookup_method_addresses (MonoMethod *method);
168
169 MonoDebugMethodJitInfo*
170 mono_debug_find_method (MonoMethod *method, MonoDomain *domain);
171
172 void
173 mono_debug_free_method_jit_info (MonoDebugMethodJitInfo *jit);
174
175
176 void
177 mono_debug_add_delegate_trampoline (void* code, int size);
178
179 MonoDebugLocalsInfo*
180 mono_debug_lookup_locals (MonoMethod *method);
181
182 /*
183  * Line number support.
184  */
185
186 MonoDebugSourceLocation *
187 mono_debug_lookup_source_location (MonoMethod *method, uint32_t address, MonoDomain *domain);
188
189 int32_t
190 mono_debug_il_offset_from_address (MonoMethod *method, MonoDomain *domain, uint32_t native_offset);
191
192 void
193 mono_debug_free_source_location (MonoDebugSourceLocation *location);
194
195 char *
196 mono_debug_print_stack_frame (MonoMethod *method, uint32_t native_offset, MonoDomain *domain);
197
198 /*
199  * Mono Debugger support functions
200  *
201  * These methods are used by the JIT while running inside the Mono Debugger.
202  */
203
204 int             mono_debugger_method_has_breakpoint       (MonoMethod *method);
205 int             mono_debugger_insert_breakpoint           (const char *method_name, mono_bool include_namespace);
206
207 void mono_set_is_debugger_attached (mono_bool attached);
208 mono_bool mono_is_debugger_attached (void);
209
210 MONO_END_DECLS
211
212 #endif /* __MONO_DEBUG_H__ */