X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmetadata%2Fsgen-minor-scan-object.h;h=cd660cc9de277aaa4bae2e781b2edc1e47103a9b;hb=9ac4b5b7a7062fd0b3d26e3bd0c9d426be904fc3;hp=47c9be9fa31d806c6ede98976659ae3360827f4a;hpb=107e44e461ae22e5fcee195146d753d8e59e8bc8;p=mono.git diff --git a/mono/metadata/sgen-minor-scan-object.h b/mono/metadata/sgen-minor-scan-object.h index 47c9be9fa31..cd660cc9de2 100644 --- a/mono/metadata/sgen-minor-scan-object.h +++ b/mono/metadata/sgen-minor-scan-object.h @@ -19,71 +19,26 @@ * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ -extern long long stat_scan_object_called_nursery; +extern guint64 stat_scan_object_called_nursery; #if defined(SGEN_SIMPLE_NURSERY) #define SERIAL_SCAN_OBJECT simple_nursery_serial_scan_object #define SERIAL_SCAN_VTYPE simple_nursery_serial_scan_vtype -#define PARALLEL_SCAN_OBJECT simple_nursery_parallel_scan_object -#define PARALLEL_SCAN_VTYPE simple_nursery_parallel_scan_vtype #elif defined (SGEN_SPLIT_NURSERY) #define SERIAL_SCAN_OBJECT split_nursery_serial_scan_object #define SERIAL_SCAN_VTYPE split_nursery_serial_scan_vtype -#define PARALLEL_SCAN_OBJECT split_nursery_parallel_scan_object -#define PARALLEL_SCAN_VTYPE split_nursery_parallel_scan_vtype #else #error "Please define GC_CONF_NAME" #endif -#undef HANDLE_PTR -#define HANDLE_PTR(ptr,obj) do { \ - void *__old = *(ptr); \ - void *__copy; \ - if (__old) { \ - PARALLEL_COPY_OBJECT ((ptr), queue); \ - __copy = *(ptr); \ - SGEN_COND_LOG (9, __old != __copy, "Overwrote field at %p with %p (was: %p)", (ptr), *(ptr), __old); \ - if (G_UNLIKELY (sgen_ptr_in_nursery (__copy) && !sgen_ptr_in_nursery ((ptr)))) \ - sgen_add_to_global_remset ((ptr)); \ - } \ - } while (0) - -/* - * Scan the object pointed to by @start for references to - * other objects between @from_start and @from_end and copy - * them to the gray_objects area. - */ -static void -PARALLEL_SCAN_OBJECT (char *start, SgenGrayQueue *queue) -{ -#include "sgen-scan-object.h" - - HEAVY_STAT (++stat_scan_object_called_nursery); -} - -/* - * scan_vtype: - * - * Scan the valuetype pointed to by START, described by DESC for references to - * other objects between @from_start and @from_end and copy them to the gray_objects area. - * Returns a pointer to the end of the object. - */ -static void -PARALLEL_SCAN_VTYPE (char *start, mword desc, SgenGrayQueue *queue) -{ - /* The descriptors include info about the MonoObject header as well */ - start -= sizeof (MonoObject); - -#define SCAN_OBJECT_NOVTABLE -#include "sgen-scan-object.h" -} - #undef HANDLE_PTR /* Global remsets are handled in SERIAL_COPY_OBJECT_FROM_OBJ */ #define HANDLE_PTR(ptr,obj) do { \ void *__old = *(ptr); \ + SGEN_OBJECT_LAYOUT_STATISTICS_MARK_BITMAP ((obj), (ptr)); \ + binary_protocol_scan_process_reference ((obj), (ptr), __old); \ if (__old) { \ SERIAL_COPY_OBJECT_FROM_OBJ ((ptr), queue); \ SGEN_COND_LOG (9, __old != *(ptr), "Overwrote field at %p with %p (was: %p)", (ptr), *(ptr), __old); \ @@ -91,26 +46,39 @@ PARALLEL_SCAN_VTYPE (char *start, mword desc, SgenGrayQueue *queue) } while (0) static void -SERIAL_SCAN_OBJECT (char *start, SgenGrayQueue *queue) +SERIAL_SCAN_OBJECT (char *start, mword desc, SgenGrayQueue *queue) { + SGEN_OBJECT_LAYOUT_STATISTICS_DECLARE_BITMAP; + +#ifdef HEAVY_STATISTICS + sgen_descriptor_count_scanned_object (desc); +#endif + + SGEN_ASSERT (9, sgen_get_current_collection_generation () == GENERATION_NURSERY, "Must not use minor scan during major collection."); + +#define SCAN_OBJECT_PROTOCOL #include "sgen-scan-object.h" + SGEN_OBJECT_LAYOUT_STATISTICS_COMMIT_BITMAP; HEAVY_STAT (++stat_scan_object_called_nursery); } static void -SERIAL_SCAN_VTYPE (char *start, mword desc, SgenGrayQueue *queue) +SERIAL_SCAN_VTYPE (char *start, mword desc, SgenGrayQueue *queue BINARY_PROTOCOL_ARG (size_t size)) { + SGEN_OBJECT_LAYOUT_STATISTICS_DECLARE_BITMAP; + + SGEN_ASSERT (9, sgen_get_current_collection_generation () == GENERATION_NURSERY, "Must not use minor scan during major collection."); + /* The descriptors include info about the MonoObject header as well */ start -= sizeof (MonoObject); #define SCAN_OBJECT_NOVTABLE +#define SCAN_OBJECT_PROTOCOL #include "sgen-scan-object.h" } #define FILL_MINOR_COLLECTOR_SCAN_OBJECT(collector) do { \ - (collector)->parallel_ops.scan_object = PARALLEL_SCAN_OBJECT; \ - (collector)->parallel_ops.scan_vtype = PARALLEL_SCAN_VTYPE; \ (collector)->serial_ops.scan_object = SERIAL_SCAN_OBJECT; \ (collector)->serial_ops.scan_vtype = SERIAL_SCAN_VTYPE; \ } while (0)