grammar updates
[mono.git] / mono / metadata / mono-debug-debugger.h
index 2bba1eb71a86915e6435a195fe7bba381671d39e..f6ab2eb838003232b6d706164f047d0fb7e8de4c 100644 (file)
@@ -4,31 +4,95 @@
 #include <glib.h>
 #include <mono/metadata/debug-helpers.h>
 #include <mono/metadata/debug-mono-symfile.h>
+#include <mono/io-layer/io-layer.h>
 
 typedef struct _MonoDebuggerBreakpointInfo     MonoDebuggerBreakpointInfo;
+typedef struct _MonoDebuggerBuiltinTypeInfo    MonoDebuggerBuiltinTypeInfo;
+typedef struct _MonoDebuggerBuiltinTypes       MonoDebuggerBuiltinTypes;
 typedef struct _MonoDebuggerSymbolTable                MonoDebuggerSymbolTable;
 typedef struct _MonoDebuggerSymbolFile         MonoDebuggerSymbolFile;
 typedef struct _MonoDebuggerSymbolFilePriv     MonoDebuggerSymbolFilePriv;
 typedef struct _MonoDebuggerRangeInfo          MonoDebuggerRangeInfo;
 typedef struct _MonoDebuggerClassInfo          MonoDebuggerClassInfo;
+typedef struct _MonoDebuggerIOLayer            MonoDebuggerIOLayer;
 
 typedef enum {
        MONO_DEBUGGER_EVENT_TYPE_ADDED,
        MONO_DEBUGGER_EVENT_METHOD_ADDED,
-       MONO_DEBUGGER_EVENT_BREAKPOINT_TRAMPOLINE
+       MONO_DEBUGGER_EVENT_BREAKPOINT
 } MonoDebuggerEvent;
 
+typedef enum {
+       MONO_DEBUGGER_TYPE_KIND_UNKNOWN = 1,
+       MONO_DEBUGGER_TYPE_KIND_FUNDAMENTAL,
+       MONO_DEBUGGER_TYPE_KIND_STRING,
+       MONO_DEBUGGER_TYPE_KIND_SZARRAY,
+       MONO_DEBUGGER_TYPE_KIND_ARRAY,
+       MONO_DEBUGGER_TYPE_KIND_POINTER,
+       MONO_DEBUGGER_TYPE_KIND_ENUM,
+       MONO_DEBUGGER_TYPE_KIND_OBJECT,
+       MONO_DEBUGGER_TYPE_KIND_STRUCT,
+       MONO_DEBUGGER_TYPE_KIND_CLASS,
+       MONO_DEBUGGER_TYPE_KIND_CLASS_INFO
+} MonoDebuggerTypeKind;
+
 struct _MonoDebuggerBreakpointInfo {
        guint32 index;
-       gboolean use_trampoline;
        MonoMethodDesc *desc;
 };
 
+struct _MonoDebuggerBuiltinTypeInfo
+{
+       MonoClass *klass;
+       MonoDebuggerClassInfo *cinfo;
+       guint32 type_info;
+       guint32 class_info;
+       guint8 *type_data;
+};
+
+struct _MonoDebuggerBuiltinTypes {
+       guint32 total_size;
+       guint32 type_info_size;
+       MonoDebuggerBuiltinTypeInfo *object_type;
+       MonoDebuggerBuiltinTypeInfo *byte_type;
+       MonoDebuggerBuiltinTypeInfo *void_type;
+       MonoDebuggerBuiltinTypeInfo *boolean_type;
+       MonoDebuggerBuiltinTypeInfo *sbyte_type;
+       MonoDebuggerBuiltinTypeInfo *int16_type;
+       MonoDebuggerBuiltinTypeInfo *uint16_type;
+       MonoDebuggerBuiltinTypeInfo *int32_type;
+       MonoDebuggerBuiltinTypeInfo *uint32_type;
+       MonoDebuggerBuiltinTypeInfo *int_type;
+       MonoDebuggerBuiltinTypeInfo *uint_type;
+       MonoDebuggerBuiltinTypeInfo *int64_type;
+       MonoDebuggerBuiltinTypeInfo *uint64_type;
+       MonoDebuggerBuiltinTypeInfo *single_type;
+       MonoDebuggerBuiltinTypeInfo *double_type;
+       MonoDebuggerBuiltinTypeInfo *char_type;
+       MonoDebuggerBuiltinTypeInfo *string_type;
+       MonoDebuggerBuiltinTypeInfo *enum_type;
+       MonoDebuggerBuiltinTypeInfo *array_type;
+       MonoDebuggerBuiltinTypeInfo *exception_type;
+};
+
 struct _MonoDebuggerSymbolTable {
        guint64 magic;
        guint32 version;
        guint32 total_size;
 
+       /*
+        * Corlib and builtin types.
+        */
+       MonoDomain *domain;
+       MonoDebuggerSymbolFile *corlib;
+       MonoDebuggerBuiltinTypes *builtin_types;
+
+       /*
+        * The symbol files.
+        */
+       guint32 num_symbol_files;
+       MonoDebuggerSymbolFile **symbol_files;
+
        /*
         * Type table.
         * This is intentionally not a GPtrArray to make it more easy to
@@ -62,17 +126,14 @@ struct _MonoDebuggerSymbolTable {
         */
        guint32 type_table_offset;
        guint32 type_table_start;
-
-       /*
-        * The symbol files.
-        */
-       guint32 num_symbol_files;
-       MonoDebuggerSymbolFile **symbol_files;
 };
 
 struct _MonoDebuggerSymbolFile {
+       guint32 index;
        MonoSymbolFile *symfile;
+       MonoImage *image;
        const char *image_file;
+       guint32 class_entry_size;
        /* Pointer to the malloced range table. */
        guint32 locked;
        guint32 generation;
@@ -81,7 +142,6 @@ struct _MonoDebuggerSymbolFile {
        guint32 num_range_entries;
        /* Pointer to the malloced class table. */
        MonoDebuggerClassInfo *class_table;
-       guint32 class_entry_size;
        guint32 num_class_entries;
        /* Private. */
        MonoDebuggerSymbolFilePriv *_priv;
@@ -104,27 +164,76 @@ struct _MonoDebuggerClassInfo {
 
 extern MonoDebuggerSymbolTable *mono_debugger_symbol_table;
 
-extern void (*mono_debugger_event_handler) (MonoDebuggerEvent event, gpointer data, gpointer data2);
+/*
+ * Address of the x86 trampoline code.  This is used by the debugger to check
+ * whether a method is a trampoline.
+ */
+extern guint8 *mono_generic_trampoline_code;
+
+#ifndef PLATFORM_WIN32
+
+/*
+ * Functions we export to the debugger.
+ */
+struct _MonoDebuggerIOLayer
+{
+       void (*InitializeCriticalSection) (WapiCriticalSection *section);
+       void (*DeleteCriticalSection) (WapiCriticalSection *section);
+       gboolean (*TryEnterCriticalSection) (WapiCriticalSection *section);
+       void (*EnterCriticalSection) (WapiCriticalSection *section);
+       void (*LeaveCriticalSection) (WapiCriticalSection *section);
+
+       guint32 (*WaitForSingleObject) (gpointer handle, guint32 timeout);
+       guint32 (*SignalObjectAndWait) (gpointer signal_handle, gpointer wait,
+                                       guint32 timeout, gboolean alertable);
+       guint32 (*WaitForMultipleObjects) (guint32 numobjects, gpointer *handles,
+                                          gboolean waitall, guint32 timeout);
+
+       gpointer (*CreateSemaphore) (WapiSecurityAttributes *security,
+                                    gint32 initial, gint32 max,
+                                    const guchar *name);
+       gboolean (*ReleaseSemaphore) (gpointer handle, gint32 count, gint32 *prevcount);
+
+       gpointer (*CreateThread) (WapiSecurityAttributes *security,
+                                 guint32 stacksize, WapiThreadStart start,
+                                 gpointer param, guint32 create, guint32 *tid);
+};
+
+extern MonoDebuggerIOLayer mono_debugger_io_layer;
+
+#endif
+
+extern void (*mono_debugger_event_handler) (MonoDebuggerEvent event, gpointer data, guint32 arg);
 
-void            mono_debugger_initialize              (void);
-void            mono_debugger_cleanup                 (void);
+void            mono_debugger_initialize                  (MonoDomain *domain);
+void            mono_debugger_cleanup                     (void);
 
-void            mono_debugger_lock                    (void);
-void            mono_debugger_unlock                  (void);
-void            mono_debugger_event                   (MonoDebuggerEvent event, gpointer data, gpointer data2);
+void            mono_debugger_lock                        (void);
+void            mono_debugger_unlock                      (void);
+void            mono_debugger_event                       (MonoDebuggerEvent event, gpointer data, guint32 arg);
 
-MonoDebuggerSymbolFile *mono_debugger_add_symbol_file (MonoSymbolFile *symfile);
-void            mono_debugger_add_type                (MonoDebuggerSymbolFile *symfile, MonoClass *klass);
-void            mono_debugger_add_method              (MonoDebuggerSymbolFile *symfile, MonoMethod *method);
+MonoDebuggerSymbolFile   *mono_debugger_add_symbol_file   (MonoDebugHandle *handle);
+void                      mono_debugger_add_type          (MonoDebuggerSymbolFile *symfile, MonoClass *klass);
+MonoDebuggerBuiltinTypes *mono_debugger_add_builtin_types (MonoDebuggerSymbolFile *symfile);
 
-int             mono_debugger_insert_breakpoint_full  (MonoMethodDesc *desc, gboolean use_trampoline);
-int             mono_debugger_remove_breakpoint       (int breakpoint_id);
-int             mono_debugger_insert_breakpoint       (const gchar *method_name, gboolean include_namespace);
-int             mono_debugger_method_has_breakpoint   (MonoMethod* method, gboolean use_trampoline);
-void            mono_debugger_trampoline_breakpoint_callback (void);
+void            mono_debugger_add_method                  (MonoDebuggerSymbolFile *symfile,
+                                                          MonoDebugMethodInfo *minfo,
+                                                          MonoDebugMethodJitInfo *jit);
+
+int             mono_debugger_insert_breakpoint_full      (MonoMethodDesc *desc);
+int             mono_debugger_remove_breakpoint           (int breakpoint_id);
+int             mono_debugger_insert_breakpoint           (const gchar *method_name, gboolean include_namespace);
+int             mono_debugger_method_has_breakpoint       (MonoMethod *method);
+void            mono_debugger_breakpoint_callback         (MonoMethod *method, guint32 idx);
 
 gpointer        mono_debugger_create_notification_function (gpointer *notification_address);
 
+MonoObject     *mono_debugger_runtime_invoke              (MonoMethod *method, void *obj,
+                                                          void **params, MonoObject **exc);
+
+guint32         mono_debugger_lookup_type                 (const gchar *type_name);
+
+
 MonoReflectionMethod *
 ves_icall_MonoDebugger_GetMethod (MonoReflectionAssembly *assembly, guint32 token);