X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmetadata%2Fobject.h;h=2fe5331df56e4903162bdb229336c715cd4b2e32;hb=b50dc8d84850e0452a7a4d742ed0a0fa46fe491e;hp=33396bad7d5c4e0509608c15980af66c6f602f6f;hpb=a04730664e2fa1b5e6f2dc03256c6f69b31a53e7;p=mono.git diff --git a/mono/metadata/object.h b/mono/metadata/object.h index 33396bad7d5..2fe5331df56 100644 --- a/mono/metadata/object.h +++ b/mono/metadata/object.h @@ -3,6 +3,8 @@ #include +G_BEGIN_DECLS + typedef guchar MonoBoolean; typedef struct _MonoReflectionMethod MonoReflectionMethod; @@ -19,6 +21,7 @@ typedef struct _MonoThread MonoThread; typedef struct _MonoDynamicAssembly MonoDynamicAssembly; typedef struct _MonoDynamicImage MonoDynamicImage; typedef struct _MonoReflectionMethodBody MonoReflectionMethodBody; +typedef struct _MonoAppContext MonoAppContext; typedef struct { MonoVTable *vtable; @@ -53,8 +56,13 @@ typedef void (*MonoMainThreadFunc) (gpointer user_data); #define mono_object_class(obj) (((MonoObject*)(obj))->vtable->klass) #define mono_object_domain(obj) (((MonoObject*)(obj))->vtable->domain) +#define MONO_OBJECT_SETREF(obj,fieldname,value) do { \ + mono_gc_wbarrier_set_field ((MonoObject*)(obj), &((obj)->fieldname), (MonoObject*)value); \ + /*(obj)->fieldname = (value);*/ \ + } while (0) + #define mono_array_length(array) ((array)->max_length) -#define mono_array_addr(array,type,index) ((type*) mono_array_addr_with_size (array, sizeof (type), index)) +#define mono_array_addr(array,type,index) ((type*)(gpointer) mono_array_addr_with_size (array, sizeof (type), index)) #define mono_array_addr_with_size(array,size,index) ( ((char*)(array)->vector) + (size) * (index) ) #define mono_array_get(array,type,index) ( *(type*)mono_array_addr ((array), type, (index)) ) #define mono_array_set(array,type,index,value) \ @@ -62,6 +70,18 @@ typedef void (*MonoMainThreadFunc) (gpointer user_data); type *__p = (type *) mono_array_addr ((array), type, (index)); \ *__p = (value); \ } while (0) +#define mono_array_setref(array,index,value) \ + do { \ + gpointer *__p = (gpointer *) mono_array_addr ((array), gpointer, (index)); \ + mono_gc_wbarrier_set_arrayref ((array), __p, (MonoObject*)(value)); \ + /* *__p = (value);*/ \ + } while (0) +#define mono_array_memcpy_refs(dest,destidx,src,srcidx,count) \ + do { \ + gpointer *__p = (gpointer *) mono_array_addr ((dest), gpointer, (destidx)); \ + mono_gc_wbarrier_arrayref_copy ((dest), __p, (count)); \ + memmove (__p, mono_array_addr ((src), gpointer, (srcidx)), (count) * sizeof (gpointer)); \ + } while (0) #define mono_string_chars(s) ((gunichar2*)(s)->chars) #define mono_string_length(s) ((s)->length) @@ -79,9 +99,6 @@ mono_object_new_fast (MonoVTable *vtable); MonoObject * mono_object_new_alloc_specific (MonoVTable *vtable); -void* -mono_class_get_allocation_ftn (MonoVTable *vtable, gboolean *pass_size_in_words); - MonoObject * mono_object_new_from_token (MonoDomain *domain, MonoImage *image, guint32 token); @@ -131,9 +148,24 @@ mono_string_to_utf16 (MonoString *string_obj); MonoString * mono_string_from_utf16 (gunichar2 *data); +gboolean +mono_string_equal (MonoString *s1, MonoString *s2); + +guint +mono_string_hash (MonoString *s); + +int +mono_object_hash (MonoObject* obj); + MonoObject * mono_value_box (MonoDomain *domain, MonoClass *klass, gpointer val); +void +mono_value_copy (gpointer dest, gpointer src, MonoClass *klass); + +void +mono_value_copy_array (MonoArray *dest, int dest_idx, gpointer src, int count); + MonoDomain* mono_object_get_domain (MonoObject *obj); @@ -234,9 +266,6 @@ mono_compile_method (MonoMethod *method); MonoRemoteClass* mono_remote_class (MonoDomain *domain, MonoString *class_name, MonoClass *proxy_class); -void -mono_upgrade_remote_class (MonoDomain *domain, MonoRemoteClass *remote_class, MonoClass *klass); - /* accessors for fields and properties */ void mono_field_set_value (MonoObject *obj, MonoClassField *field, void *value); @@ -278,5 +307,14 @@ guint32 mono_gchandle_new_weakref (MonoObject *obj, gboolean track_resurrec MonoObject* mono_gchandle_get_target (guint32 gchandle); void mono_gchandle_free (guint32 gchandle); +/* GC write barriers support */ +void mono_gc_wbarrier_set_field (MonoObject *obj, gpointer field_ptr, MonoObject* value); +void mono_gc_wbarrier_set_arrayref (MonoArray *arr, gpointer slot_ptr, MonoObject* value); +void mono_gc_wbarrier_arrayref_copy (MonoArray *arr, gpointer slot_ptr, int count); +void mono_gc_wbarrier_generic_store (gpointer ptr, MonoObject* value); +void mono_gc_wbarrier_value_copy (gpointer dest, gpointer src, int count, MonoClass *klass); + +G_END_DECLS + #endif