X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmetadata%2Fprofiler-private.h;h=28b8e9723dec8031a61ee61516db8f0a4e31df4b;hb=42874b6479cf103ca2e044b95c27a2edbb21d75c;hp=c99529012ce53a3a9edf06edb053f7f1fc59e836;hpb=4eb352bcb3ef7a71dc9ab62c5cd2d5e7598619f7;p=mono.git diff --git a/mono/metadata/profiler-private.h b/mono/metadata/profiler-private.h index c99529012ce..e087be07eb6 100644 --- a/mono/metadata/profiler-private.h +++ b/mono/metadata/profiler-private.h @@ -1,57 +1,141 @@ +/* + * Licensed to the .NET Foundation under one or more agreements. + * The .NET Foundation licenses this file to you under the MIT license. + * See the LICENSE file in the project root for more information. + */ #ifndef __MONO_PROFILER_PRIVATE_H__ #define __MONO_PROFILER_PRIVATE_H__ +#define MONO_PROFILER_UNSTABLE_GC_ROOTS #include -#include "mono/utils/mono-compiler.h" - -extern MonoProfileFlags mono_profiler_events; - -enum { - MONO_PROFILE_START_LOAD, - MONO_PROFILE_END_LOAD, - MONO_PROFILE_START_UNLOAD, - MONO_PROFILE_END_UNLOAD +#include +#include +#include + +struct _MonoProfilerDesc { + MonoProfilerHandle next; + MonoProfiler *prof; + volatile gpointer coverage_filter; + volatile gpointer call_instrumentation_filter; + +#define _MONO_PROFILER_EVENT(name) \ + volatile gpointer name ## _cb; +#define MONO_PROFILER_EVENT_0(name, type) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_1(name, type, arg1_type, arg1_name) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_2(name, type, arg1_type, arg1_name, arg2_type, arg2_name) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_3(name, type, arg1_type, arg1_name, arg2_type, arg2_name, arg3_type, arg3_name) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_4(name, type, arg1_type, arg1_name, arg2_type, arg2_name, arg3_type, arg3_name, arg4_type, arg4_name) \ + _MONO_PROFILER_EVENT(name) +#include +#undef MONO_PROFILER_EVENT_0 +#undef MONO_PROFILER_EVENT_1 +#undef MONO_PROFILER_EVENT_2 +#undef MONO_PROFILER_EVENT_3 +#undef MONO_PROFILER_EVENT_4 +#undef _MONO_PROFILER_EVENT }; typedef struct { - int entries; - struct { - guchar* cil_code; - int count; - } data [1]; -} MonoProfileCoverageInfo; - -void mono_profiler_shutdown (void) MONO_INTERNAL; - -void mono_profiler_method_enter (MonoMethod *method) MONO_INTERNAL; -void mono_profiler_method_leave (MonoMethod *method) MONO_INTERNAL; -void mono_profiler_method_jit (MonoMethod *method) MONO_INTERNAL; -void mono_profiler_method_end_jit (MonoMethod *method, MonoJitInfo* jinfo, int result) MONO_INTERNAL; - -void mono_profiler_code_transition (MonoMethod *method, int result) MONO_INTERNAL; -void mono_profiler_allocation (MonoObject *obj, MonoClass *klass) MONO_INTERNAL; -void mono_profiler_stat_hit (guchar *ip, void *context) MONO_INTERNAL; -void mono_profiler_thread_start (gsize tid) MONO_INTERNAL; -void mono_profiler_thread_end (gsize tid) MONO_INTERNAL; - -void mono_profiler_assembly_event (MonoAssembly *assembly, int code) MONO_INTERNAL; -void mono_profiler_assembly_loaded (MonoAssembly *assembly, int result) MONO_INTERNAL; - -void mono_profiler_module_event (MonoImage *image, int code) MONO_INTERNAL; -void mono_profiler_module_loaded (MonoImage *image, int result) MONO_INTERNAL; - -void mono_profiler_class_event (MonoClass *klass, int code) MONO_INTERNAL; -void mono_profiler_class_loaded (MonoClass *klass, int result) MONO_INTERNAL; - -void mono_profiler_appdomain_event (MonoDomain *domain, int code) MONO_INTERNAL; -void mono_profiler_appdomain_loaded (MonoDomain *domain, int result) MONO_INTERNAL; - -MonoProfileCoverageInfo* mono_profiler_coverage_alloc (MonoMethod *method, int entries) MONO_INTERNAL; -void mono_profiler_coverage_free (MonoMethod *method) MONO_INTERNAL; - -void mono_profiler_gc_event (MonoGCEvent e, int generation) MONO_INTERNAL; -void mono_profiler_gc_heap_resize (gint64 new_size) MONO_INTERNAL; - -#endif /* __MONO_PROFILER_PRIVATE_H__ */ + gboolean startup_done; + MonoProfilerHandle profilers; + mono_lazy_init_t coverage_status; + mono_mutex_t coverage_mutex; + GHashTable *coverage_hash; + MonoProfilerHandle sampling_owner; + MonoSemType sampling_semaphore; + MonoProfilerSampleMode sample_mode; + guint32 sample_freq; + gboolean allocations; + +#define _MONO_PROFILER_EVENT(name) \ + volatile gint32 name ## _count; +#define MONO_PROFILER_EVENT_0(name, type) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_1(name, type, arg1_type, arg1_name) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_2(name, type, arg1_type, arg1_name, arg2_type, arg2_name) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_3(name, type, arg1_type, arg1_name, arg2_type, arg2_name, arg3_type, arg3_name) \ + _MONO_PROFILER_EVENT(name) +#define MONO_PROFILER_EVENT_4(name, type, arg1_type, arg1_name, arg2_type, arg2_name, arg3_type, arg3_name, arg4_type, arg4_name) \ + _MONO_PROFILER_EVENT(name) +#include +#undef MONO_PROFILER_EVENT_0 +#undef MONO_PROFILER_EVENT_1 +#undef MONO_PROFILER_EVENT_2 +#undef MONO_PROFILER_EVENT_3 +#undef MONO_PROFILER_EVENT_4 +#undef _MONO_PROFILER_EVENT +} MonoProfilerState; + +extern MonoProfilerState mono_profiler_state; +typedef struct { + guint32 entries; + struct { + guchar *cil_code; + guint32 count; + } data [1]; +} MonoProfilerCoverageInfo; + +void mono_profiler_started (void); +void mono_profiler_cleanup (void); + +static inline gboolean +mono_profiler_installed (void) +{ + return !!mono_profiler_state.profilers; +} + +MonoProfilerCoverageInfo *mono_profiler_coverage_alloc (MonoMethod *method, guint32 entries); +void mono_profiler_coverage_free (MonoMethod *method); + +gboolean mono_profiler_should_instrument_method (MonoMethod *method, gboolean entry); + +gboolean mono_profiler_sampling_enabled (void); +void mono_profiler_sampling_thread_post (void); +void mono_profiler_sampling_thread_wait (void); + +static inline gboolean +mono_profiler_allocations_enabled (void) +{ + return mono_profiler_state.allocations; +} + +#define _MONO_PROFILER_EVENT(name, ...) \ + void mono_profiler_raise_ ## name (__VA_ARGS__); +#define MONO_PROFILER_EVENT_0(name, type) \ + _MONO_PROFILER_EVENT(name, void) +#define MONO_PROFILER_EVENT_1(name, type, arg1_type, arg1_name) \ + _MONO_PROFILER_EVENT(name, arg1_type arg1_name) +#define MONO_PROFILER_EVENT_2(name, type, arg1_type, arg1_name, arg2_type, arg2_name) \ + _MONO_PROFILER_EVENT(name, arg1_type arg1_name, arg2_type arg2_name) +#define MONO_PROFILER_EVENT_3(name, type, arg1_type, arg1_name, arg2_type, arg2_name, arg3_type, arg3_name) \ + _MONO_PROFILER_EVENT(name, arg1_type arg1_name, arg2_type arg2_name, arg3_type arg3_name) +#define MONO_PROFILER_EVENT_4(name, type, arg1_type, arg1_name, arg2_type, arg2_name, arg3_type, arg3_name, arg4_type, arg4_name) \ + _MONO_PROFILER_EVENT(name, arg1_type arg1_name, arg2_type arg2_name, arg3_type arg3_name, arg4_type arg4_name) +#include +#undef MONO_PROFILER_EVENT_0 +#undef MONO_PROFILER_EVENT_1 +#undef MONO_PROFILER_EVENT_2 +#undef MONO_PROFILER_EVENT_3 +#undef MONO_PROFILER_EVENT_4 +#undef _MONO_PROFILER_EVENT + +// These are the macros the rest of the runtime should use. + +#define MONO_PROFILER_ENABLED(name) \ + G_UNLIKELY (mono_profiler_state.name ## _count) + +#define MONO_PROFILER_RAISE(name, args) \ + do { \ + if (MONO_PROFILER_ENABLED (name)) \ + mono_profiler_raise_ ## name args; \ + } while (0) + +#endif // __MONO_PROFILER_PRIVATE_H__