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