X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmetadata%2Fdomain-internals.h;h=51d1e4666e46a8edea2f9f63a9faccdfc850a334;hb=bf484297f1e88a8906894e6e0bf4bcd10ba43802;hp=9243003afeb1375da0fbdfe29ea71f26ef18413a;hpb=0a7104f724973c28dc8e3d7e064592d2874d7f78;p=mono.git diff --git a/mono/metadata/domain-internals.h b/mono/metadata/domain-internals.h index 9243003afeb..51d1e4666e4 100644 --- a/mono/metadata/domain-internals.h +++ b/mono/metadata/domain-internals.h @@ -31,9 +31,34 @@ typedef struct { int loader_optimization; MonoBoolean disallow_binding_redirects; MonoBoolean disallow_code_downloads; + MonoObject *activation_arguments; /* it is System.Object in 1.x, ActivationArguments in 2.0 */ + MonoObject *domain_initializer; + MonoArray *domain_initializer_args; + MonoObject *application_trust; /* it is System.Object in 1.x, ApplicationTrust in 2.0 */ + MonoBoolean disallow_appbase_probe; + MonoArray *configuration_bytes; } MonoAppDomainSetup; -typedef GArray MonoJitInfoTable; +typedef struct _MonoJitInfoTable MonoJitInfoTable; +typedef struct _MonoJitInfoTableChunk MonoJitInfoTableChunk; + +#define MONO_JIT_INFO_TABLE_CHUNK_SIZE 64 + +struct _MonoJitInfoTableChunk +{ + int refcount; + volatile int num_elements; + volatile gint8 *last_code_end; + MonoJitInfo * volatile data [MONO_JIT_INFO_TABLE_CHUNK_SIZE]; +}; + +struct _MonoJitInfoTable +{ + int num_chunks; + MonoJitInfoTableChunk *chunks [MONO_ZERO_LEN_ARRAY]; +}; + +typedef GArray MonoAotModuleInfoTable; typedef struct { guint32 flags; @@ -47,6 +72,14 @@ typedef struct { } data; } MonoJitExceptionInfo; +/* + * Will contain information on the generic type arguments in the + * future. For now, all arguments are always reference types. + */ +typedef struct { + int dummy; +} MonoGenericSharingContext; + struct _MonoJitInfo { /* NOTE: These first two elements (method and next_jit_code_hash) must be in the same order and at the @@ -57,7 +90,7 @@ struct _MonoJitInfo { gpointer code_start; guint32 used_regs; int code_size; - guint32 num_clauses:24; + guint32 num_clauses:16; /* Whenever the code is domain neutral or 'shared' */ gboolean domain_neutral:1; gboolean cas_inited:1; @@ -67,7 +100,9 @@ struct _MonoJitInfo { gboolean cas_method_assert:1; gboolean cas_method_deny:1; gboolean cas_method_permitonly:1; + gboolean has_generic_sharing_context:1; MonoJitExceptionInfo clauses [MONO_ZERO_LEN_ARRAY]; + /* There is an optional MonoGenericSharingContext* after the clauses */ }; typedef struct { @@ -121,6 +156,7 @@ struct _MonoDomain { guint32 state; /* Needed by Thread:GetDomainID() */ gint32 domain_id; + gint32 shadow_serial; GSList *domain_assemblies; MonoAssembly *entry_assembly; char *friendly_name; @@ -130,9 +166,12 @@ struct _MonoDomain { MonoInternalHashTable jit_code_hash; /* maps MonoMethod -> MonoJitDynamicMethodInfo */ GHashTable *dynamic_code_hash; - MonoJitInfoTable *jit_info_table; + MonoJitInfoTable * + volatile jit_info_table; /* Used when loading assemblies */ gchar **search_path; + gchar *private_bin_path; + /* Used by remoting proxies */ MonoMethod *create_proxy_for_type_method; MonoMethod *private_invoke_method; @@ -143,8 +182,6 @@ struct _MonoDomain { GHashTable *jump_trampoline_hash; GHashTable *jit_trampoline_hash; GHashTable *delegate_trampoline_hash; - GHashTable *delegate_invoke_impl_with_target_hash; - GHashTable *delegate_invoke_impl_no_target_hash; /* * This must be a GHashTable, since these objects can't be finalized * if the hashtable contains a GC visible reference to them. @@ -152,6 +189,8 @@ struct _MonoDomain { GHashTable *finalizable_objects_hash; /* Used when accessing 'domain_assemblies' */ CRITICAL_SECTION assemblies_lock; + + GHashTable *shared_generics_hash; }; typedef struct { @@ -185,6 +224,19 @@ mono_jit_info_table_remove (MonoDomain *domain, MonoJitInfo *ji) MONO_INTERNAL; void mono_jit_info_add_aot_module (MonoImage *image, gpointer start, gpointer end) MONO_INTERNAL; +MonoGenericSharingContext* +mono_jit_info_get_generic_sharing_context (MonoJitInfo *ji) MONO_INTERNAL; + +void +mono_jit_info_set_generic_sharing_context (MonoJitInfo *ji, MonoGenericSharingContext *gsctx) MONO_INTERNAL; + +MonoJitInfo* +mono_domain_lookup_shared_generic (MonoDomain *domain, MonoMethod *method) MONO_INTERNAL; + +void +mono_domain_register_shared_generic (MonoDomain *domain, MonoMethod *method, MonoJitInfo *jit_info) MONO_INTERNAL; + + /* * Installs a new function which is used to return a MonoJitInfo for a method inside * an AOT module. @@ -302,4 +354,12 @@ MonoImage *mono_assembly_open_from_bundle (const char *filename, void mono_domain_add_class_static_data (MonoDomain *domain, MonoClass *klass, gpointer data, guint32 *bitmap); +MonoReflectionAssembly * +mono_try_assembly_resolve (MonoDomain *domain, MonoString *fname, gboolean refonly) MONO_INTERNAL; + +MonoAssembly* mono_assembly_load_full_nosearch (MonoAssemblyName *aname, + const char *basedir, + MonoImageOpenStatus *status, + gboolean refonly) MONO_INTERNAL; + #endif /* __MONO_METADATA_DOMAIN_INTERNALS_H__ */