2005-08-21 Zoltan Varga <vargaz@freemail.hu>
[mono.git] / mono / metadata / domain-internals.h
index ffb761ee2d5a78955e7cdab7ce59e1d58b03201e..6d451abe8474fd8358cea022cb9e6d40c7a032a9 100644 (file)
@@ -123,11 +123,14 @@ struct _MonoDomain {
        GHashTable         *class_init_trampoline_hash;
        GHashTable         *jump_trampoline_hash;
        GHashTable         *jit_trampoline_hash;
+       GHashTable         *delegate_trampoline_hash;
        /* 
         * This must be a GHashTable, since these objects can't be finalized
         * if the hashtable contains a GC visible reference to them.
         */
        GHashTable         *finalizable_objects_hash;
+       /* Used when accessing 'domain_assemblies' */
+       CRITICAL_SECTION    assemblies_lock;
 };
 
 typedef struct  {
@@ -143,6 +146,8 @@ typedef struct  {
 
 #define mono_domain_lock(domain)   EnterCriticalSection(&(domain)->lock)
 #define mono_domain_unlock(domain) LeaveCriticalSection(&(domain)->lock)
+#define mono_domain_assemblies_lock(domain)   EnterCriticalSection(&(domain)->assemblies_lock)
+#define mono_domain_assemblies_unlock(domain) LeaveCriticalSection(&(domain)->assemblies_lock)
 
 void
 mono_jit_info_table_add    (MonoDomain *domain, MonoJitInfo *ji);
@@ -150,6 +155,16 @@ mono_jit_info_table_add    (MonoDomain *domain, MonoJitInfo *ji);
 void
 mono_jit_info_table_remove (MonoDomain *domain, MonoJitInfo *ji);
 
+void
+mono_jit_info_add_aot_module (MonoImage *image, gpointer start, gpointer end);
+
+/* 
+ * Installs a new function which is used to return a MonoJitInfo for a method inside
+ * an AOT module.
+ */
+typedef MonoJitInfo *(*MonoJitInfoFindInAot)         (MonoDomain *domain, MonoImage *image, gpointer addr);
+void          mono_install_jit_info_find_in_aot (MonoJitInfoFindInAot func);
+
 MonoAppDomain *
 ves_icall_System_AppDomain_getCurDomain            (void);
 
@@ -168,7 +183,8 @@ MonoReflectionAssembly *
 ves_icall_System_AppDomain_LoadAssemblyRaw         (MonoAppDomain *ad,
                                                    MonoArray *raw_assembly, 
                                                    MonoArray *raw_symbol_store,
-                                                   MonoObject *evidence);
+                                                   MonoObject *evidence,
+                                                   MonoBoolean refonly);
 
 void
 ves_icall_System_AppDomain_SetData                 (MonoAppDomain *ad, 
@@ -182,15 +198,18 @@ MonoString *
 ves_icall_System_AppDomain_getFriendlyName         (MonoAppDomain *ad);
 
 MonoArray *
-ves_icall_System_AppDomain_GetAssemblies           (MonoAppDomain *ad);
+ves_icall_System_AppDomain_GetAssemblies           (MonoAppDomain *ad,
+                                                   MonoBoolean refonly);
 
 MonoReflectionAssembly *
-ves_icall_System_Reflection_Assembly_LoadFrom      (MonoString *fname);
+ves_icall_System_Reflection_Assembly_LoadFrom      (MonoString *fname,
+                                                   MonoBoolean refonly);
 
 MonoReflectionAssembly *
 ves_icall_System_AppDomain_LoadAssembly            (MonoAppDomain *ad, 
                                                    MonoString *assRef,
-                                                   MonoObject    *evidence);
+                                                   MonoObject    *evidence,
+                                                   MonoBoolean refonly);
 
 gboolean
 ves_icall_System_AppDomain_InternalIsFinalizingForUnload (gint32 domain_id);
@@ -240,4 +259,10 @@ mono_assembly_load_corlib (const MonoRuntimeInfo *runtime, MonoImageOpenStatus *
 const MonoRuntimeInfo*
 mono_get_runtime_info (void);
 
+gboolean
+mono_assembly_name_parse (const char *name, MonoAssemblyName *aname);
+
+void
+mono_assembly_name_free (MonoAssemblyName *aname);
+
 #endif /* __MONO_METADATA_DOMAIN_INTERNALS_H__ */