X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmetadata%2Fsgen-mono.c;h=efa0e892eccf3bd312a72915c482e115c8fad163;hb=ac229973136cd80c6ff5c7fee05a63b24e1bcad3;hp=8f86228dce17bece01892b1e24934f67aa7af264;hpb=0b7588ee2e8732c22dce914662d36be388def54d;p=mono.git diff --git a/mono/metadata/sgen-mono.c b/mono/metadata/sgen-mono.c index 8f86228dce1..efa0e892ecc 100644 --- a/mono/metadata/sgen-mono.c +++ b/mono/metadata/sgen-mono.c @@ -37,6 +37,7 @@ #include "metadata/handle.h" #include "utils/mono-memory-model.h" #include "utils/mono-logger-internals.h" +#include "sgen/sgen-thread-pool.h" #ifdef HEAVY_STATISTICS static guint64 stat_wbarrier_set_arrayref = 0; @@ -1198,14 +1199,12 @@ create_allocator (int atype, gboolean slowpath) /* catch */ clause->flags = MONO_EXCEPTION_CLAUSE_NONE; clause->try_len = mono_mb_get_pos (mb) - clause->try_offset; - clause->data.catch_class = mono_class_from_name (mono_defaults.corlib, + clause->data.catch_class = mono_class_load_from_name (mono_defaults.corlib, "System", "OverflowException"); - g_assert (clause->data.catch_class); clause->handler_offset = mono_mb_get_label (mb); - oom_exc_class = mono_class_from_name (mono_defaults.corlib, + oom_exc_class = mono_class_load_from_name (mono_defaults.corlib, "System", "OutOfMemoryException"); - g_assert (oom_exc_class); ctor = mono_class_get_method_from_name (oom_exc_class, ".ctor", 0); g_assert (ctor); @@ -1390,12 +1389,13 @@ create_allocator (int atype, gboolean slowpath) info->d.alloc.gc_name = "sgen"; info->d.alloc.alloc_type = atype; - res = mono_mb_create (mb, csig, 8, info); - mono_mb_free (mb); #ifndef DISABLE_JIT - mono_method_get_header (res)->init_locals = FALSE; + mb->init_locals = FALSE; #endif + res = mono_mb_create (mb, csig, 8, info); + mono_mb_free (mb); + return res; } @@ -1592,7 +1592,7 @@ find_next_card (guint8 *card_data, guint8 *end) #define ARRAY_OBJ_INDEX(ptr,array,elem_size) (((char*)(ptr) - ((char*)(array) + G_STRUCT_OFFSET (MonoArray, vector))) / (elem_size)) gboolean -sgen_client_cardtable_scan_object (GCObject *obj, mword block_obj_size, guint8 *cards, gboolean mod_union, ScanCopyContext ctx) +sgen_client_cardtable_scan_object (GCObject *obj, mword block_obj_size, guint8 *cards, ScanCopyContext ctx) { MonoVTable *vt = SGEN_LOAD_VTABLE (obj); MonoClass *klass = vt->klass; @@ -1672,20 +1672,11 @@ LOOP_HEAD: for (; elem < card_end; elem += elem_size) scan_vtype_func (obj, elem, desc, ctx.queue BINARY_PROTOCOL_ARG (elem_size)); } else { - CopyOrMarkObjectFunc copy_func = ctx.ops->copy_or_mark_object; + ScanPtrFieldFunc scan_ptr_field_func = ctx.ops->scan_ptr_field; HEAVY_STAT (++los_array_cards); - for (; elem < card_end; elem += SIZEOF_VOID_P) { - GCObject *new_; - gpointer old = *(gpointer*)elem; - if ((mod_union && old) || G_UNLIKELY (sgen_ptr_in_nursery (old))) { - HEAVY_STAT (++los_array_remsets); - copy_func ((GCObject**)elem, ctx.queue); - new_ = *(GCObject **)elem; - if (G_UNLIKELY (sgen_ptr_in_nursery (new_))) - sgen_add_to_global_remset (elem, new_); - } - } + for (; elem < card_end; elem += SIZEOF_VOID_P) + scan_ptr_field_func (obj, (GCObject**)elem, ctx.queue); } binary_protocol_card_scan (first_elem, elem - first_elem); @@ -2343,8 +2334,6 @@ mono_gc_scan_object (void *obj, void *gc_data) void sgen_client_scan_thread_data (void *start_nursery, void *end_nursery, gboolean precise, ScanCopyContext ctx) { - SgenThreadInfo *info; - scan_area_arg_start = start_nursery; scan_area_arg_end = end_nursery; @@ -2398,7 +2387,7 @@ sgen_client_scan_thread_data (void *start_nursery, void *end_nursery, gboolean p } } } - } END_FOREACH_THREAD + } FOREACH_THREAD_END } /* @@ -2990,6 +2979,7 @@ mono_gc_base_init (void) void mono_gc_base_cleanup (void) { + sgen_thread_pool_shutdown (); } gboolean