Merge pull request #1753 from schani/feature-yet-more-sgen-improvements
[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 } MonoProfileFlags;
35
36 typedef enum {
37         MONO_PROFILE_OK,
38         MONO_PROFILE_FAILED
39 } MonoProfileResult;
40
41 typedef enum {
42         MONO_GC_EVENT_START,
43         MONO_GC_EVENT_MARK_START,
44         MONO_GC_EVENT_MARK_END,
45         MONO_GC_EVENT_RECLAIM_START,
46         MONO_GC_EVENT_RECLAIM_END,
47         MONO_GC_EVENT_END,
48         MONO_GC_EVENT_PRE_STOP_WORLD,
49         MONO_GC_EVENT_POST_STOP_WORLD,
50         MONO_GC_EVENT_PRE_START_WORLD,
51         MONO_GC_EVENT_POST_START_WORLD
52 } MonoGCEvent;
53
54 /* coverage info */
55 typedef struct {
56         MonoMethod *method;
57         int iloffset;
58         int counter;
59         const char *filename;
60         int line;
61         int col;
62 } MonoProfileCoverageEntry;
63
64 /* executable code buffer info */
65 typedef enum {
66         MONO_PROFILER_CODE_BUFFER_UNKNOWN,
67         MONO_PROFILER_CODE_BUFFER_METHOD,
68         MONO_PROFILER_CODE_BUFFER_METHOD_TRAMPOLINE,
69         MONO_PROFILER_CODE_BUFFER_UNBOX_TRAMPOLINE,
70         MONO_PROFILER_CODE_BUFFER_IMT_TRAMPOLINE,
71         MONO_PROFILER_CODE_BUFFER_GENERICS_TRAMPOLINE,
72         MONO_PROFILER_CODE_BUFFER_SPECIFIC_TRAMPOLINE,
73         MONO_PROFILER_CODE_BUFFER_HELPER,
74         MONO_PROFILER_CODE_BUFFER_MONITOR,
75         MONO_PROFILER_CODE_BUFFER_DELEGATE_INVOKE,
76         MONO_PROFILER_CODE_BUFFER_EXCEPTION_HANDLING,
77         MONO_PROFILER_CODE_BUFFER_LAST
78 } MonoProfilerCodeBufferType;
79
80 typedef struct _MonoProfiler MonoProfiler;
81
82 typedef enum {
83         MONO_PROFILER_MONITOR_CONTENTION = 1,
84         MONO_PROFILER_MONITOR_DONE = 2,
85         MONO_PROFILER_MONITOR_FAIL = 3
86 } MonoProfilerMonitorEvent;
87
88 typedef enum {
89         MONO_PROFILER_CALL_CHAIN_NONE = 0,
90         MONO_PROFILER_CALL_CHAIN_NATIVE = 1,
91         MONO_PROFILER_CALL_CHAIN_GLIBC = 2,
92         MONO_PROFILER_CALL_CHAIN_MANAGED = 3,
93         MONO_PROFILER_CALL_CHAIN_INVALID = 4
94 } MonoProfilerCallChainStrategy;
95
96 typedef enum {
97         MONO_PROFILER_GC_HANDLE_CREATED,
98         MONO_PROFILER_GC_HANDLE_DESTROYED
99 } MonoProfileGCHandleEvent;
100
101 typedef enum {
102         MONO_PROFILE_GC_ROOT_PINNING  = 1 << 8,
103         MONO_PROFILE_GC_ROOT_WEAKREF  = 2 << 8,
104         MONO_PROFILE_GC_ROOT_INTERIOR = 4 << 8,
105         /* the above are flags, the type is in the low 2 bytes */
106         MONO_PROFILE_GC_ROOT_STACK = 0,
107         MONO_PROFILE_GC_ROOT_FINALIZER = 1,
108         MONO_PROFILE_GC_ROOT_HANDLE = 2,
109         MONO_PROFILE_GC_ROOT_OTHER = 3,
110         MONO_PROFILE_GC_ROOT_MISC = 4, /* could be stack, handle, etc. */
111         MONO_PROFILE_GC_ROOT_TYPEMASK = 0xff
112 } MonoProfileGCRootType;
113
114 /*
115  * Functions that the runtime will call on the profiler.
116  */
117
118 typedef void (*MonoProfileFunc) (MonoProfiler *prof);
119
120 typedef void (*MonoProfileAppDomainFunc) (MonoProfiler *prof, MonoDomain   *domain);
121 typedef void (*MonoProfileMethodFunc)   (MonoProfiler *prof, MonoMethod   *method);
122 typedef void (*MonoProfileClassFunc)    (MonoProfiler *prof, MonoClass    *klass);
123 typedef void (*MonoProfileModuleFunc)   (MonoProfiler *prof, MonoImage    *module);
124 typedef void (*MonoProfileAssemblyFunc) (MonoProfiler *prof, MonoAssembly *assembly);
125 typedef void (*MonoProfileMonitorFunc)  (MonoProfiler *prof, MonoObject *obj, MonoProfilerMonitorEvent event);
126
127 typedef void (*MonoProfileExceptionFunc) (MonoProfiler *prof, MonoObject *object);
128 typedef void (*MonoProfileExceptionClauseFunc) (MonoProfiler *prof, MonoMethod *method, int clause_type, int clause_num);
129
130 typedef void (*MonoProfileAppDomainResult)(MonoProfiler *prof, MonoDomain   *domain,   int result);
131 typedef void (*MonoProfileMethodResult)   (MonoProfiler *prof, MonoMethod   *method,   int result);
132 typedef void (*MonoProfileJitResult)      (MonoProfiler *prof, MonoMethod   *method,   MonoJitInfo* jinfo,   int result);
133 typedef void (*MonoProfileClassResult)    (MonoProfiler *prof, MonoClass    *klass,    int result);
134 typedef void (*MonoProfileModuleResult)   (MonoProfiler *prof, MonoImage    *module,   int result);
135 typedef void (*MonoProfileAssemblyResult) (MonoProfiler *prof, MonoAssembly *assembly, int result);
136
137 typedef void (*MonoProfileMethodInline)   (MonoProfiler *prof, MonoMethod   *parent, MonoMethod *child, int *ok);
138
139 typedef void (*MonoProfileThreadFunc)     (MonoProfiler *prof, uintptr_t tid);
140 typedef void (*MonoProfileThreadNameFunc) (MonoProfiler *prof, uintptr_t tid, const char *name);
141 typedef void (*MonoProfileAllocFunc)      (MonoProfiler *prof, MonoObject *obj, MonoClass *klass);
142 typedef void (*MonoProfileStatFunc)       (MonoProfiler *prof, mono_byte *ip, void *context);
143 typedef void (*MonoProfileStatCallChainFunc) (MonoProfiler *prof, int call_chain_depth, mono_byte **ip, void *context);
144 typedef void (*MonoProfileGCFunc)         (MonoProfiler *prof, MonoGCEvent event, int generation);
145 typedef void (*MonoProfileGCMoveFunc)     (MonoProfiler *prof, void **objects, int num);
146 typedef void (*MonoProfileGCResizeFunc)   (MonoProfiler *prof, int64_t new_size);
147 typedef void (*MonoProfileGCHandleFunc)   (MonoProfiler *prof, int op, int type, uintptr_t handle, MonoObject *obj);
148 typedef void (*MonoProfileGCRootFunc)     (MonoProfiler *prof, int num_roots, void **objects, int *root_types, uintptr_t *extra_info);
149
150 typedef void (*MonoProfileIomapFunc) (MonoProfiler *prof, const char *report, const char *pathname, const char *new_pathname);
151
152 typedef mono_bool (*MonoProfileCoverageFilterFunc)   (MonoProfiler *prof, MonoMethod *method);
153
154 typedef void (*MonoProfileCoverageFunc)   (MonoProfiler *prof, const MonoProfileCoverageEntry *entry);
155
156 typedef void (*MonoProfilerCodeChunkNew) (MonoProfiler *prof, void* chunk, int size);
157 typedef void (*MonoProfilerCodeChunkDestroy) (MonoProfiler *prof, void* chunk);
158 typedef void (*MonoProfilerCodeBufferNew) (MonoProfiler *prof, void* buffer, int size, MonoProfilerCodeBufferType type, void *data);
159
160 /*
161  * Function the profiler may call.
162  */
163 MONO_API void mono_profiler_install       (MonoProfiler *prof, MonoProfileFunc shutdown_callback);
164 MONO_API void mono_profiler_set_events    (MonoProfileFlags events);
165
166 MONO_API MonoProfileFlags mono_profiler_get_events (void);
167
168 MONO_API void mono_profiler_install_appdomain   (MonoProfileAppDomainFunc start_load, MonoProfileAppDomainResult end_load,
169                                         MonoProfileAppDomainFunc start_unload, MonoProfileAppDomainFunc end_unload);
170 MONO_API void mono_profiler_install_assembly    (MonoProfileAssemblyFunc start_load, MonoProfileAssemblyResult end_load,
171                                         MonoProfileAssemblyFunc start_unload, MonoProfileAssemblyFunc end_unload);
172 MONO_API void mono_profiler_install_module      (MonoProfileModuleFunc start_load, MonoProfileModuleResult end_load,
173                                         MonoProfileModuleFunc start_unload, MonoProfileModuleFunc end_unload);
174 MONO_API void mono_profiler_install_class       (MonoProfileClassFunc start_load, MonoProfileClassResult end_load,
175                                         MonoProfileClassFunc start_unload, MonoProfileClassFunc end_unload);
176
177 MONO_API void mono_profiler_install_jit_compile (MonoProfileMethodFunc start, MonoProfileMethodResult end);
178 MONO_API void mono_profiler_install_jit_end (MonoProfileJitResult end);
179 MONO_API void mono_profiler_install_method_free (MonoProfileMethodFunc callback);
180 MONO_API void mono_profiler_install_method_invoke (MonoProfileMethodFunc start, MonoProfileMethodFunc end);
181 MONO_API void mono_profiler_install_enter_leave (MonoProfileMethodFunc enter, MonoProfileMethodFunc fleave);
182 MONO_API void mono_profiler_install_thread      (MonoProfileThreadFunc start, MonoProfileThreadFunc end);
183 MONO_API void mono_profiler_install_thread_name (MonoProfileThreadNameFunc thread_name_cb);
184 MONO_API void mono_profiler_install_transition  (MonoProfileMethodResult callback);
185 MONO_API void mono_profiler_install_allocation  (MonoProfileAllocFunc callback);
186 MONO_API void mono_profiler_install_monitor     (MonoProfileMonitorFunc callback);
187 MONO_API void mono_profiler_install_statistical (MonoProfileStatFunc callback);
188 MONO_API void mono_profiler_install_statistical_call_chain (MonoProfileStatCallChainFunc callback, int call_chain_depth, MonoProfilerCallChainStrategy call_chain_strategy);
189 MONO_API void mono_profiler_install_exception   (MonoProfileExceptionFunc throw_callback, MonoProfileMethodFunc exc_method_leave, MonoProfileExceptionClauseFunc clause_callback);
190 MONO_API void mono_profiler_install_coverage_filter (MonoProfileCoverageFilterFunc callback);
191 MONO_API void mono_profiler_coverage_get  (MonoProfiler *prof, MonoMethod *method, MonoProfileCoverageFunc func);
192 MONO_API void mono_profiler_install_gc    (MonoProfileGCFunc callback, MonoProfileGCResizeFunc heap_resize_callback);
193 MONO_API void mono_profiler_install_gc_moves    (MonoProfileGCMoveFunc callback);
194 MONO_API void mono_profiler_install_gc_roots    (MonoProfileGCHandleFunc handle_callback, MonoProfileGCRootFunc roots_callback);
195 MONO_API void mono_profiler_install_runtime_initialized (MonoProfileFunc runtime_initialized_callback);
196
197 MONO_API void mono_profiler_install_code_chunk_new (MonoProfilerCodeChunkNew callback);
198 MONO_API void mono_profiler_install_code_chunk_destroy (MonoProfilerCodeChunkDestroy callback);
199 MONO_API void mono_profiler_install_code_buffer_new (MonoProfilerCodeBufferNew callback);
200
201 MONO_API void mono_profiler_install_iomap (MonoProfileIomapFunc callback);
202
203 MONO_API void mono_profiler_load             (const char *desc);
204
205 typedef enum {
206         /* Elapsed time is tracked by user+kernel time of the process - this is the default*/
207         MONO_PROFILER_STAT_MODE_PROCESS = 0,
208         /* Elapsed time is tracked by wallclock time */
209         MONO_PROFILER_STAT_MODE_REAL = 1,
210 } MonoProfileSamplingMode;
211
212 MONO_API void mono_profiler_set_statistical_mode (MonoProfileSamplingMode mode, int64_t sampling_frequency_is_us);
213
214 MONO_END_DECLS
215
216 #endif /* __MONO_PROFILER_H__ */
217