-<h1>Profiling</h1>
-
-<h4><a name="api:mono_profiler_allocation">mono_profiler_allocation</a></h4>
-<h4><a name="api:mono_profiler_appdomain_event">mono_profiler_appdomain_event</a></h4>
-<h4><a name="api:mono_profiler_appdomain_loaded">mono_profiler_appdomain_loaded</a></h4>
-<h4><a name="api:mono_profiler_assembly_event">mono_profiler_assembly_event</a></h4>
-<h4><a name="api:mono_profiler_assembly_loaded">mono_profiler_assembly_loaded</a></h4>
-<h4><a name="api:mono_profiler_class_event">mono_profiler_class_event</a></h4>
-<h4><a name="api:mono_profiler_class_loaded">mono_profiler_class_loaded</a></h4>
-<h4><a name="api:mono_profiler_code_transition">mono_profiler_code_transition</a></h4>
-<h4><a name="api:mono_profiler_coverage_alloc">mono_profiler_coverage_alloc</a></h4>
-<h4><a name="api:mono_profiler_coverage_free">mono_profiler_coverage_free</a></h4>
-<h4><a name="api:mono_profiler_coverage_get">mono_profiler_coverage_get</a></h4>
-<h4><a name="api:mono_profiler_get_events">mono_profiler_get_events</a></h4>
+<h1>Profiling Interface</h1>
+
+<h3>Profiler Operation</h3>
+
+ <p>The following methods can be used by dynamic profiler
+ methods to monitor different aspects of the program.
+
+ <p>A custom profiler will have one public method defined in
+ the shared library which is the entry point that Mono calls at
+ startup, it has the following signature:
+
+ <pre>
+ void mono_profiler_startup (const char *desc)
+ </pre>
+
+ <p>Where "desc" is the set of arguments that were passed from
+ the command line. This routine will call
+ <tt>mono_profiler_install</tt> to activate the profiler and
+ will install one or more filters (one of the various
+ <tt>mono_profiler_install_</tt> functions).
+
+ <p>In addition, a profiler developer will typically call
+ <tt>mono_profiler_set_events</tt> to register which kinds of
+ traces should be enabled, these can be an OR-ed combination of
+ the following:
+
+ <pre>
+ MONO_PROFILE_NONE
+ MONO_PROFILE_APPDOMAIN_EVENTS
+ MONO_PROFILE_ASSEMBLY_EVENTS
+ MONO_PROFILE_MODULE_EVENTS
+ MONO_PROFILE_CLASS_EVENTS
+ MONO_PROFILE_JIT_COMPILATION
+ MONO_PROFILE_INLINING
+ MONO_PROFILE_EXCEPTIONS
+ MONO_PROFILE_ALLOCATIONS
+ MONO_PROFILE_GC
+ MONO_PROFILE_THREADS
+ MONO_PROFILE_REMOTING
+ MONO_PROFILE_TRANSITIONS
+ MONO_PROFILE_ENTER_LEAVE
+ MONO_PROFILE_COVERAGE
+ MONO_PROFILE_INS_COVERAGE
+ MONO_PROFILE_STATISTICAL
+ </pre>
+
+ <p>Developers can change the set of monitored events at
+ runtime by calling <tt>mono_profiler_set_events</tt>.
+
+<h4><a name="api:mono_profiler_install">mono_profiler_install</a></h4>
<h4><a name="api:mono_profiler_install_allocation">mono_profiler_install_allocation</a></h4>
<h4><a name="api:mono_profiler_install_appdomain">mono_profiler_install_appdomain</a></h4>
<h4><a name="api:mono_profiler_install_assembly">mono_profiler_install_assembly</a></h4>
<h4><a name="api:mono_profiler_install_enter_leave">mono_profiler_install_enter_leave</a></h4>
<h4><a name="api:mono_profiler_install_jit_compile">mono_profiler_install_jit_compile</a></h4>
<h4><a name="api:mono_profiler_install_module">mono_profiler_install_module</a></h4>
-<h4><a name="api:mono_profiler_install">mono_profiler_install</a></h4>
<h4><a name="api:mono_profiler_install_thread">mono_profiler_install_thread</a></h4>
<h4><a name="api:mono_profiler_install_transition">mono_profiler_install_transition</a></h4>
-<h4><a name="api:mono_profiler_load">mono_profiler_load</a></h4>
-<h4><a name="api:mono_profiler_method_end_jit">mono_profiler_method_end_jit</a></h4>
-<h4><a name="api:mono_profiler_method_enter">mono_profiler_method_enter</a></h4>
-<h4><a name="api:mono_profiler_method_jit">mono_profiler_method_jit</a></h4>
-<h4><a name="api:mono_profiler_method_leave">mono_profiler_method_leave</a></h4>
-<h4><a name="api:mono_profiler_module_event">mono_profiler_module_event</a></h4>
-<h4><a name="api:mono_profiler_module_loaded">mono_profiler_module_loaded</a></h4>
-<h4><a name="api:mono_profiler_set_events">mono_profiler_set_events</a></h4>
-<h4><a name="api:mono_profiler_shutdown">mono_profiler_shutdown</a></h4>
-<h4><a name="api:mono_profiler_startup">mono_profiler_startup</a></h4>
-<h4><a name="api:mono_profiler_thread_end">mono_profiler_thread_end</a></h4>
-<h4><a name="api:mono_profiler_thread_start">mono_profiler_thread_start</a></h4>
-<h4><a name="api:mono_profiler_gc_event">mono_profiler_gc_event</a></h4>
-<h4><a name="api:mono_profiler_gc_heap_resize">mono_profiler_gc_heap_resize</a></h4>
<h4><a name="api:mono_profiler_install_gc">mono_profiler_install_gc</a></h4>
<h4><a name="api:mono_profiler_install_statistical">mono_profiler_install_statistical</a></h4>
-<h4><a name="api:mono_profiler_stat_hit">mono_profiler_stat_hit</a></h4>
-<h4><a name="api:mono_profiler_gc_event">mono_profiler_gc_event</a></h4>
-<h4><a name="api:mono_profiler_gc_heap_resize">mono_profiler_gc_heap_resize</a></h4>
-<h4><a name="api:mono_profiler_stat_hit">mono_profiler_stat_hit</a></h4>
+<h4><a name="api:mono_profiler_set_events">mono_profiler_set_events</a></h4>
+<h4><a name="api:mono_profiler_get_events">mono_profiler_get_events</a></h4>
+<h3>Coverage</h3>
+
+ <p>To support profiling modules that need to do code coverage
+ analysis, the following routines is provided:
+
+<h4><a name="api:mono_profiler_coverage_get">mono_profiler_coverage_get</a></h4>
-<h4><a name="api:mono_profiler_install_gc">mono_profiler_install_gc</a></h4>
-<h4><a name="api:mono_profiler_install_statistical">mono_profiler_install_statistical</a></h4>