merge 99630:99762
[mono.git] / mono / metadata / mono-debug-debugger.h
index 45f1c69f34afc8a06c7656255bd58562e1e5d5f6..fa2d46c68276ea95312d4e1316498826c3337c93 100644 (file)
@@ -1,27 +1,21 @@
 /*
- * This header is only installed for use by the debugger:
- * the structures and the API declared here are not supported.
+ * This is a private header file.
+ * The API in here is undocumented and may only be used by the JIT to
+ * communicate with the debugger.
  */
 
 #ifndef __MONO_DEBUG_DEBUGGER_H__
 #define __MONO_DEBUG_DEBUGGER_H__
 
-#if !defined _IN_THE_MONO_DEBUGGER
-#error "<mono/metadata/mono-debug-debugger.h> is a private header file only intended to be used by the debugger."
-#endif
-
 #include <glib.h>
 #include <mono/metadata/debug-helpers.h>
 #include <mono/metadata/debug-mono-symfile.h>
+#include <mono/utils/mono-codeman.h>
 #include <mono/io-layer/io-layer.h>
 
-typedef struct _MonoDebuggerBreakpointInfo     MonoDebuggerBreakpointInfo;
-
 typedef enum {
        MONO_DEBUGGER_EVENT_INITIALIZE_MANAGED_CODE     = 1,
-       MONO_DEBUGGER_EVENT_ADD_MODULE,
-       MONO_DEBUGGER_EVENT_RELOAD_SYMTABS,
-       MONO_DEBUGGER_EVENT_METHOD_COMPILED,
+       MONO_DEBUGGER_EVENT_INITIALIZE_CORLIB,
        MONO_DEBUGGER_EVENT_JIT_BREAKPOINT,
        MONO_DEBUGGER_EVENT_INITIALIZE_THREAD_MANAGER,
        MONO_DEBUGGER_EVENT_ACQUIRE_GLOBAL_THREAD_LOCK,
@@ -29,41 +23,35 @@ typedef enum {
        MONO_DEBUGGER_EVENT_WRAPPER_MAIN,
        MONO_DEBUGGER_EVENT_MAIN_EXITED,
        MONO_DEBUGGER_EVENT_UNHANDLED_EXCEPTION,
-       MONO_DEBUGGER_EVENT_THREAD_CREATED,
-       MONO_DEBUGGER_EVENT_THREAD_ABORT,
        MONO_DEBUGGER_EVENT_THROW_EXCEPTION,
        MONO_DEBUGGER_EVENT_HANDLE_EXCEPTION,
-       MONO_DEBUGGER_EVENT_REACHED_MAIN
+       MONO_DEBUGGER_EVENT_THREAD_CREATED,
+       MONO_DEBUGGER_EVENT_THREAD_CLEANUP,
+       MONO_DEBUGGER_EVENT_GC_THREAD_CREATED,
+       MONO_DEBUGGER_EVENT_GC_THREAD_EXITED,
+       MONO_DEBUGGER_EVENT_REACHED_MAIN,
+       MONO_DEBUGGER_EVENT_FINALIZE_MANAGED_CODE,
+       MONO_DEBUGGER_EVENT_LOAD_MODULE,
+       MONO_DEBUGGER_EVENT_UNLOAD_MODULE,
+       MONO_DEBUGGER_EVENT_DOMAIN_CREATE,
+       MONO_DEBUGGER_EVENT_DOMAIN_UNLOAD,
+       MONO_DEBUGGER_EVENT_CLASS_INITIALIZED,
+
+       /* Extended per-thread notifications */
+       MONO_DEBUGGER_EVENT_TRAMPOLINE                  = 256,
 } MonoDebuggerEvent;
 
-struct _MonoDebuggerBreakpointInfo {
-       guint32 index;
-       MonoMethodDesc *desc;
-};
-
 extern void (*mono_debugger_event_handler) (MonoDebuggerEvent event, guint64 data, guint64 arg);
 
-void            mono_debugger_initialize                  (gboolean use_debugger);
-void            mono_debugger_cleanup                     (void);
-
-void            mono_debugger_lock                        (void);
-void            mono_debugger_unlock                      (void);
-void            mono_debugger_event                       (MonoDebuggerEvent event, guint64 data, guint64 arg);
-
-void            mono_debugger_add_symbol_file             (MonoDebugHandle *handle);
-void            mono_debugger_start_add_type              (MonoDebugHandle *symfile, MonoClass *klass);
-
-int             mono_debugger_insert_breakpoint_full      (MonoMethodDesc *desc);
-int             mono_debugger_remove_breakpoint           (int breakpoint_id);
-void            mono_debugger_breakpoint_callback         (MonoMethod *method, guint32 idx);
+void            mono_debugger_initialize                    (gboolean use_debugger);
+void            mono_debugger_cleanup                       (void);
 
-void            mono_debugger_create_notification_function(gpointer notification_address);
+void            mono_debugger_lock                          (void);
+void            mono_debugger_unlock                        (void);
+void            mono_debugger_event                         (MonoDebuggerEvent event, guint64 data, guint64 arg);
 
-MonoObject     *mono_debugger_runtime_invoke              (MonoMethod *method, void *obj,
-                                                          void **params, MonoObject **exc);
-
-gboolean        mono_debugger_lookup_type                 (const gchar *type_name);
-gint32          mono_debugger_lookup_assembly             (const gchar *name);
+MonoObject     *mono_debugger_runtime_invoke                (MonoMethod *method, void *obj,
+                                                            void **params, MonoObject **exc);
 
 void *
 mono_vtable_get_static_field_data (MonoVTable *vt);
@@ -71,4 +59,23 @@ mono_vtable_get_static_field_data (MonoVTable *vt);
 gchar *
 mono_debugger_check_runtime_version (const char *filename);
 
+void
+mono_debugger_class_initialized (MonoClass *klass);
+
+MonoDebugMethodAddressList *
+mono_debugger_insert_method_breakpoint (MonoMethod *method, guint64 idx);
+
+int
+mono_debugger_remove_method_breakpoint (guint64 index);
+
+void
+mono_debugger_check_breakpoints (MonoMethod *method, MonoDebugMethodAddress *debug_info);
+
+MonoClass *
+mono_debugger_register_class_init_callback (MonoImage *image, const gchar *full_name,
+                                           guint32 token, guint32 index);
+
+void
+mono_debugger_remove_class_init_callback (int index);
+
 #endif /* __MONO_DEBUG_DEBUGGER_H__ */