1 #include <mono/metadata/profiler.h>
4 * Bare bones profiler. Compile with:
6 * linux : gcc -shared -o mono-profiler-sample.so sample.c `pkg-config --cflags --libs mono`
7 * mac : gcc sample.c -o mono-profiler-sample.dylib -Dmono_free=free -lz `pkg-config --cflags mono-2` -undefined suppress -flat_namespace
9 * Install the binary where the dynamic loader can find it. eg /usr/lib etc
11 * mono --profile=sample your_application.exe
13 * Note if you name a profiler with more than 8 characters (eg sample6789) appears to not work
16 struct _MonoProfiler
{
20 /* called at the end of the program */
22 sample_shutdown (MonoProfiler
*prof
)
24 g_print ("total number of calls: %d\n", prof
->ncalls
);
28 sample_method_enter (MonoProfiler
*prof
, MonoMethod
*method
)
34 sample_method_leave (MonoProfiler
*prof
, MonoMethod
*method
)
40 mono_profiler_startup (const char *desc
)
44 prof
= g_new0 (MonoProfiler
, 1);
46 mono_profiler_install (prof
, sample_shutdown
);
48 mono_profiler_install_enter_leave (sample_method_enter
, sample_method_leave
);
50 mono_profiler_set_events (MONO_PROFILE_ENTER_LEAVE
);