[profiler] Acquire the exclusive buffer lock after the suspend lock.
[mono.git] / mono / metadata / profiler.h
1 #ifndef __MONO_PROFILER_H__
2 #define __MONO_PROFILER_H__
3
4 #include <mono/metadata/object.h>
5 #include <mono/metadata/appdomain.h>
6
7 MONO_BEGIN_DECLS
8
9 #define MONO_PROFILER_MAX_STAT_CALL_CHAIN_DEPTH 128
10
11 typedef enum {
12         MONO_PROFILE_NONE = 0,
13         MONO_PROFILE_APPDOMAIN_EVENTS = 1 << 0,
14         MONO_PROFILE_ASSEMBLY_EVENTS  = 1 << 1,
15         MONO_PROFILE_MODULE_EVENTS    = 1 << 2,
16         MONO_PROFILE_CLASS_EVENTS     = 1 << 3,
17         MONO_PROFILE_JIT_COMPILATION  = 1 << 4,
18         MONO_PROFILE_INLINING         = 1 << 5,
19         MONO_PROFILE_EXCEPTIONS       = 1 << 6,
20         MONO_PROFILE_ALLOCATIONS      = 1 << 7,
21         MONO_PROFILE_GC               = 1 << 8,
22         MONO_PROFILE_THREADS          = 1 << 9,
23         MONO_PROFILE_REMOTING         = 1 << 10,
24         MONO_PROFILE_TRANSITIONS      = 1 << 11,
25         MONO_PROFILE_ENTER_LEAVE      = 1 << 12,
26         MONO_PROFILE_COVERAGE         = 1 << 13,
27         MONO_PROFILE_INS_COVERAGE     = 1 << 14,
28         MONO_PROFILE_STATISTICAL      = 1 << 15,
29         MONO_PROFILE_METHOD_EVENTS    = 1 << 16,
30         MONO_PROFILE_MONITOR_EVENTS   = 1 << 17,
31         MONO_PROFILE_IOMAP_EVENTS     = 1 << 18, /* this should likely be removed, too */
32         MONO_PROFILE_GC_MOVES         = 1 << 19,
33         MONO_PROFILE_GC_ROOTS         = 1 << 20,
34         MONO_PROFILE_CONTEXT_EVENTS   = 1 << 21
35 } MonoProfileFlags;
36
37 typedef enum {
38         MONO_PROFILE_OK,
39         MONO_PROFILE_FAILED
40 } MonoProfileResult;
41
42 // Keep somewhat in sync with libgc/include/gc.h:enum GC_EventType
43 typedef enum {
44         MONO_GC_EVENT_START,
45         MONO_GC_EVENT_MARK_START,
46         MONO_GC_EVENT_MARK_END,
47         MONO_GC_EVENT_RECLAIM_START,
48         MONO_GC_EVENT_RECLAIM_END,
49         MONO_GC_EVENT_END,
50         /*
51          * This is the actual arrival order of the following events:
52          *
53          * MONO_GC_EVENT_PRE_STOP_WORLD
54          * MONO_GC_EVENT_PRE_STOP_WORLD_LOCKED
55          * MONO_GC_EVENT_POST_STOP_WORLD
56          * MONO_GC_EVENT_PRE_START_WORLD
57          * MONO_GC_EVENT_POST_START_WORLD_UNLOCKED
58          * MONO_GC_EVENT_POST_START_WORLD
59          *
60          * The LOCKED and UNLOCKED events guarantee that, by the time they arrive,
61          * the GC and suspend locks will both have been acquired and released,
62          * respectively.
63          */
64         MONO_GC_EVENT_PRE_STOP_WORLD,
65         MONO_GC_EVENT_POST_STOP_WORLD,
66         MONO_GC_EVENT_PRE_START_WORLD,
67         MONO_GC_EVENT_POST_START_WORLD,
68         MONO_GC_EVENT_PRE_STOP_WORLD_LOCKED,
69         MONO_GC_EVENT_POST_START_WORLD_UNLOCKED
70 } MonoGCEvent;
71
72 /* coverage info */
73 typedef struct {
74         MonoMethod *method;
75         int iloffset;
76         int counter;
77         const char *filename;
78         int line;
79         int col;
80 } MonoProfileCoverageEntry;
81
82 /* executable code buffer info */
83 typedef enum {
84         MONO_PROFILER_CODE_BUFFER_UNKNOWN,
85         MONO_PROFILER_CODE_BUFFER_METHOD,
86         MONO_PROFILER_CODE_BUFFER_METHOD_TRAMPOLINE,
87         MONO_PROFILER_CODE_BUFFER_UNBOX_TRAMPOLINE,
88         MONO_PROFILER_CODE_BUFFER_IMT_TRAMPOLINE,
89         MONO_PROFILER_CODE_BUFFER_GENERICS_TRAMPOLINE,
90         MONO_PROFILER_CODE_BUFFER_SPECIFIC_TRAMPOLINE,
91         MONO_PROFILER_CODE_BUFFER_HELPER,
92         MONO_PROFILER_CODE_BUFFER_MONITOR,
93         MONO_PROFILER_CODE_BUFFER_DELEGATE_INVOKE,
94         MONO_PROFILER_CODE_BUFFER_EXCEPTION_HANDLING,
95         MONO_PROFILER_CODE_BUFFER_LAST
96 } MonoProfilerCodeBufferType;
97
98 typedef struct _MonoProfiler MonoProfiler;
99
100 typedef enum {
101         MONO_PROFILER_MONITOR_CONTENTION = 1,
102         MONO_PROFILER_MONITOR_DONE = 2,
103         MONO_PROFILER_MONITOR_FAIL = 3
104 } MonoProfilerMonitorEvent;
105
106 typedef enum {
107         MONO_PROFILER_CALL_CHAIN_NONE = 0,
108         MONO_PROFILER_CALL_CHAIN_NATIVE = 1,
109         MONO_PROFILER_CALL_CHAIN_GLIBC = 2,
110         MONO_PROFILER_CALL_CHAIN_MANAGED = 3,
111         MONO_PROFILER_CALL_CHAIN_INVALID = 4
112 } MonoProfilerCallChainStrategy;
113
114 typedef enum {
115         MONO_PROFILER_GC_HANDLE_CREATED,
116         MONO_PROFILER_GC_HANDLE_DESTROYED
117 } MonoProfileGCHandleEvent;
118
119 typedef enum {
120         MONO_PROFILE_GC_ROOT_PINNING  = 1 << 8,
121         MONO_PROFILE_GC_ROOT_WEAKREF  = 2 << 8,
122         MONO_PROFILE_GC_ROOT_INTERIOR = 4 << 8,
123         /* the above are flags, the type is in the low 2 bytes */
124         MONO_PROFILE_GC_ROOT_STACK = 0,
125         MONO_PROFILE_GC_ROOT_FINALIZER = 1,
126         MONO_PROFILE_GC_ROOT_HANDLE = 2,
127         MONO_PROFILE_GC_ROOT_OTHER = 3,
128         MONO_PROFILE_GC_ROOT_MISC = 4, /* could be stack, handle, etc. */
129         MONO_PROFILE_GC_ROOT_TYPEMASK = 0xff
130 } MonoProfileGCRootType;
131
132 /*
133  * Functions that the runtime will call on the profiler.
134  */
135
136 typedef void (*MonoProfileFunc) (MonoProfiler *prof);
137
138 typedef void (*MonoProfileAppDomainFunc) (MonoProfiler *prof, MonoDomain   *domain);
139 typedef void (*MonoProfileContextFunc)   (MonoProfiler *prof, MonoAppContext *context);
140 typedef void (*MonoProfileMethodFunc)   (MonoProfiler *prof, MonoMethod   *method);
141 typedef void (*MonoProfileClassFunc)    (MonoProfiler *prof, MonoClass    *klass);
142 typedef void (*MonoProfileModuleFunc)   (MonoProfiler *prof, MonoImage    *module);
143 typedef void (*MonoProfileAssemblyFunc) (MonoProfiler *prof, MonoAssembly *assembly);
144 typedef void (*MonoProfileMonitorFunc)  (MonoProfiler *prof, MonoObject *obj, MonoProfilerMonitorEvent event);
145
146 typedef void (*MonoProfileExceptionFunc) (MonoProfiler *prof, MonoObject *object);
147 typedef void (*MonoProfileExceptionClauseFunc) (MonoProfiler *prof, MonoMethod *method, int clause_type, int clause_num);
148
149 typedef void (*MonoProfileAppDomainResult)(MonoProfiler *prof, MonoDomain   *domain,   int result);
150 typedef void (*MonoProfileAppDomainFriendlyNameFunc) (MonoProfiler *prof, MonoDomain *domain, const char *name);
151 typedef void (*MonoProfileMethodResult)   (MonoProfiler *prof, MonoMethod   *method,   int result);
152 typedef void (*MonoProfileJitResult)      (MonoProfiler *prof, MonoMethod   *method,   MonoJitInfo* jinfo,   int result);
153 typedef void (*MonoProfileClassResult)    (MonoProfiler *prof, MonoClass    *klass,    int result);
154 typedef void (*MonoProfileModuleResult)   (MonoProfiler *prof, MonoImage    *module,   int result);
155 typedef void (*MonoProfileAssemblyResult) (MonoProfiler *prof, MonoAssembly *assembly, int result);
156
157 typedef void (*MonoProfileMethodInline)   (MonoProfiler *prof, MonoMethod   *parent, MonoMethod *child, int *ok);
158
159 typedef void (*MonoProfileThreadFunc)     (MonoProfiler *prof, uintptr_t tid);
160 typedef void (*MonoProfileThreadNameFunc) (MonoProfiler *prof, uintptr_t tid, const char *name);
161 typedef void (*MonoProfileAllocFunc)      (MonoProfiler *prof, MonoObject *obj, MonoClass *klass);
162 typedef void (*MonoProfileStatFunc)       (MonoProfiler *prof, mono_byte *ip, void *context);
163 typedef void (*MonoProfileStatCallChainFunc) (MonoProfiler *prof, int call_chain_depth, mono_byte **ip, void *context);
164 typedef void (*MonoProfileGCFunc)         (MonoProfiler *prof, MonoGCEvent event, int generation);
165 typedef void (*MonoProfileGCMoveFunc)     (MonoProfiler *prof, void **objects, int num);
166 typedef void (*MonoProfileGCResizeFunc)   (MonoProfiler *prof, int64_t new_size);
167 typedef void (*MonoProfileGCHandleFunc)   (MonoProfiler *prof, int op, int type, uintptr_t handle, MonoObject *obj);
168 typedef void (*MonoProfileGCRootFunc)     (MonoProfiler *prof, int num_roots, void **objects, int *root_types, uintptr_t *extra_info);
169
170 typedef void (*MonoProfileIomapFunc) (MonoProfiler *prof, const char *report, const char *pathname, const char *new_pathname);
171
172 typedef mono_bool (*MonoProfileCoverageFilterFunc)   (MonoProfiler *prof, MonoMethod *method);
173
174 typedef void (*MonoProfileCoverageFunc)   (MonoProfiler *prof, const MonoProfileCoverageEntry *entry);
175
176 typedef void (*MonoProfilerCodeChunkNew) (MonoProfiler *prof, void* chunk, int size);
177 typedef void (*MonoProfilerCodeChunkDestroy) (MonoProfiler *prof, void* chunk);
178 typedef void (*MonoProfilerCodeBufferNew) (MonoProfiler *prof, void* buffer, int size, MonoProfilerCodeBufferType type, void *data);
179
180 /*
181  * Function the profiler may call.
182  */
183 MONO_API void mono_profiler_install       (MonoProfiler *prof, MonoProfileFunc shutdown_callback);
184 MONO_API void mono_profiler_set_events    (MonoProfileFlags events);
185
186 MONO_API MonoProfileFlags mono_profiler_get_events (void);
187
188 MONO_API void mono_profiler_install_appdomain   (MonoProfileAppDomainFunc start_load, MonoProfileAppDomainResult end_load,
189                                         MonoProfileAppDomainFunc start_unload, MonoProfileAppDomainFunc end_unload);
190 MONO_API void mono_profiler_install_appdomain_name (MonoProfileAppDomainFriendlyNameFunc domain_name_cb);
191 MONO_API void mono_profiler_install_context     (MonoProfileContextFunc load, MonoProfileContextFunc unload);
192 MONO_API void mono_profiler_install_assembly    (MonoProfileAssemblyFunc start_load, MonoProfileAssemblyResult end_load,
193                                         MonoProfileAssemblyFunc start_unload, MonoProfileAssemblyFunc end_unload);
194 MONO_API void mono_profiler_install_module      (MonoProfileModuleFunc start_load, MonoProfileModuleResult end_load,
195                                         MonoProfileModuleFunc start_unload, MonoProfileModuleFunc end_unload);
196 MONO_API void mono_profiler_install_class       (MonoProfileClassFunc start_load, MonoProfileClassResult end_load,
197                                         MonoProfileClassFunc start_unload, MonoProfileClassFunc end_unload);
198
199 MONO_API void mono_profiler_install_jit_compile (MonoProfileMethodFunc start, MonoProfileMethodResult end);
200 MONO_API void mono_profiler_install_jit_end (MonoProfileJitResult end);
201 MONO_API void mono_profiler_install_method_free (MonoProfileMethodFunc callback);
202 MONO_API void mono_profiler_install_method_invoke (MonoProfileMethodFunc start, MonoProfileMethodFunc end);
203 MONO_API void mono_profiler_install_enter_leave (MonoProfileMethodFunc enter, MonoProfileMethodFunc fleave);
204 MONO_API void mono_profiler_install_thread      (MonoProfileThreadFunc start, MonoProfileThreadFunc end);
205 MONO_API void mono_profiler_install_thread_name (MonoProfileThreadNameFunc thread_name_cb);
206 MONO_API void mono_profiler_install_transition  (MonoProfileMethodResult callback);
207 MONO_API void mono_profiler_install_allocation  (MonoProfileAllocFunc callback);
208 MONO_API void mono_profiler_install_monitor     (MonoProfileMonitorFunc callback);
209 MONO_API void mono_profiler_install_statistical (MonoProfileStatFunc callback);
210 MONO_API void mono_profiler_install_statistical_call_chain (MonoProfileStatCallChainFunc callback, int call_chain_depth, MonoProfilerCallChainStrategy call_chain_strategy);
211 MONO_API void mono_profiler_install_exception   (MonoProfileExceptionFunc throw_callback, MonoProfileMethodFunc exc_method_leave, MonoProfileExceptionClauseFunc clause_callback);
212 MONO_API void mono_profiler_install_coverage_filter (MonoProfileCoverageFilterFunc callback);
213 MONO_API void mono_profiler_coverage_get  (MonoProfiler *prof, MonoMethod *method, MonoProfileCoverageFunc func);
214 MONO_API void mono_profiler_install_gc    (MonoProfileGCFunc callback, MonoProfileGCResizeFunc heap_resize_callback);
215 MONO_API void mono_profiler_install_gc_moves    (MonoProfileGCMoveFunc callback);
216 MONO_API void mono_profiler_install_gc_roots    (MonoProfileGCHandleFunc handle_callback, MonoProfileGCRootFunc roots_callback);
217 MONO_API void mono_profiler_install_runtime_initialized (MonoProfileFunc runtime_initialized_callback);
218
219 MONO_API void mono_profiler_install_code_chunk_new (MonoProfilerCodeChunkNew callback);
220 MONO_API void mono_profiler_install_code_chunk_destroy (MonoProfilerCodeChunkDestroy callback);
221 MONO_API void mono_profiler_install_code_buffer_new (MonoProfilerCodeBufferNew callback);
222
223 MONO_API void mono_profiler_install_iomap (MonoProfileIomapFunc callback);
224
225 MONO_API void mono_profiler_load             (const char *desc);
226
227 typedef enum {
228         /* Elapsed time is tracked by user+kernel time of the process - this is the default*/
229         MONO_PROFILER_STAT_MODE_PROCESS = 0,
230         /* Elapsed time is tracked by wallclock time */
231         MONO_PROFILER_STAT_MODE_REAL = 1,
232 } MonoProfileSamplingMode;
233
234 MONO_API void mono_profiler_set_statistical_mode (MonoProfileSamplingMode mode, int64_t sampling_frequency_hz);
235
236 MONO_END_DECLS
237
238 #endif /* __MONO_PROFILER_H__ */
239