3 * GC implementation using malloc: will leak everything, just for testing.
5 * Copyright 2001-2003 Ximian, Inc (http://www.ximian.com)
6 * Copyright 2004-2011 Novell, Inc (http://www.novell.com)
7 * Copyright 2011 Xamarin, Inc (http://www.xamarin.com)
8 * Licensed under the MIT license. See LICENSE file in the project root for full license information.
13 #include <mono/metadata/mono-gc.h>
14 #include <mono/metadata/gc-internals.h>
15 #include <mono/metadata/runtime.h>
16 #include <mono/metadata/w32handle.h>
17 #include <mono/metadata/abi-details.h>
18 #include <mono/utils/atomic.h>
19 #include <mono/utils/mono-threads.h>
20 #include <mono/utils/mono-counters.h>
21 #include <mono/metadata/null-gc-handles.h>
25 static gboolean gc_inited
= FALSE
;
28 mono_gc_base_init (void)
33 mono_counters_init ();
36 mono_w32handle_init ();
39 mono_thread_callbacks_init ();
40 mono_thread_info_init (sizeof (MonoThreadInfo
));
42 mono_thread_info_attach ();
44 null_gc_handles_init ();
50 mono_gc_base_cleanup (void)
55 mono_gc_collect (int generation
)
60 mono_gc_max_generation (void)
66 mono_gc_get_generation (MonoObject
*object
)
72 mono_gc_collection_count (int generation
)
78 mono_gc_add_memory_pressure (gint64 value
)
82 /* maybe track the size, not important, though */
84 mono_gc_get_used_size (void)
90 mono_gc_get_heap_size (void)
96 mono_gc_is_gc_thread (void)
102 mono_gc_walk_heap (int flags
, MonoGCReferences callback
, void *data
)
108 mono_object_is_alive (MonoObject
* o
)
114 mono_gc_register_root (char *start
, size_t size
, void *descr
, MonoGCRootSource source
, void *key
, const char *msg
)
120 mono_gc_register_root_wbarrier (char *start
, size_t size
, MonoGCDescriptor descr
, MonoGCRootSource source
, void *key
, const char *msg
)
127 mono_gc_deregister_root (char* addr
)
132 mono_gc_make_descr_for_string (gsize
*bitmap
, int numbits
)
138 mono_gc_make_descr_for_object (gsize
*bitmap
, int numbits
, size_t obj_size
)
144 mono_gc_make_descr_for_array (int vector
, gsize
*elem_bitmap
, int numbits
, size_t elem_size
)
150 mono_gc_make_descr_from_bitmap (gsize
*bitmap
, int numbits
)
156 mono_gc_make_vector_descr (void)
162 mono_gc_make_root_descr_all_refs (int numbits
)
168 mono_gc_alloc_fixed (size_t size
, void *descr
, MonoGCRootSource source
, void *key
, const char *msg
)
170 return (MonoObject
*)g_malloc0 (size
);
174 mono_gc_alloc_fixed_no_descriptor (size_t size
, MonoGCRootSource source
, void *key
, const char *msg
)
176 return mono_gc_alloc_fixed (size
, NULL
, source
, key
, msg
);
180 mono_gc_free_fixed (void* addr
)
186 mono_gc_alloc_obj (MonoVTable
*vtable
, size_t size
)
188 MonoObject
*obj
= g_calloc (1, size
);
190 obj
->vtable
= vtable
;
196 mono_gc_alloc_vector (MonoVTable
*vtable
, size_t size
, uintptr_t max_length
)
198 MonoArray
*obj
= g_calloc (1, size
);
200 obj
->obj
.vtable
= vtable
;
201 obj
->max_length
= max_length
;
207 mono_gc_alloc_array (MonoVTable
*vtable
, size_t size
, uintptr_t max_length
, uintptr_t bounds_size
)
209 MonoArray
*obj
= g_calloc (1, size
);
211 obj
->obj
.vtable
= vtable
;
212 obj
->max_length
= max_length
;
215 obj
->bounds
= (MonoArrayBounds
*) ((char *) obj
+ size
- bounds_size
);
221 mono_gc_alloc_string (MonoVTable
*vtable
, size_t size
, gint32 len
)
223 MonoString
*obj
= g_calloc (1, size
);
225 obj
->object
.vtable
= vtable
;
227 obj
->chars
[len
] = 0;
233 mono_gc_alloc_mature (MonoVTable
*vtable
, size_t size
)
235 return mono_gc_alloc_obj (vtable
, size
);
239 mono_gc_alloc_pinned_obj (MonoVTable
*vtable
, size_t size
)
241 return mono_gc_alloc_obj (vtable
, size
);
245 mono_gc_wbarrier_set_field_internal (MonoObject
*obj
, gpointer field_ptr
, MonoObject
* value
)
247 *(void**)field_ptr
= value
;
251 mono_gc_wbarrier_set_arrayref_internal (MonoArray
*arr
, gpointer slot_ptr
, MonoObject
* value
)
253 *(void**)slot_ptr
= value
;
257 mono_gc_wbarrier_arrayref_copy_internal (gpointer dest_ptr
, gpointer src_ptr
, int count
)
259 mono_gc_memmove_aligned (dest_ptr
, src_ptr
, count
* sizeof (gpointer
));
263 mono_gc_wbarrier_generic_store_internal (gpointer ptr
, MonoObject
* value
)
265 *(void**)ptr
= value
;
269 mono_gc_wbarrier_generic_store_atomic_internal (gpointer ptr
, MonoObject
*value
)
271 mono_atomic_store_ptr (ptr
, value
);
275 mono_gc_wbarrier_generic_nostore_internal (gpointer ptr
)
280 mono_gc_wbarrier_value_copy_internal (gpointer dest
, gpointer src
, int count
, MonoClass
*klass
)
282 mono_gc_memmove_atomic (dest
, src
, count
* mono_class_value_size (klass
, NULL
));
286 mono_gc_wbarrier_object_copy_internal (MonoObject
* obj
, MonoObject
*src
)
288 /* do not copy the sync state */
289 mono_gc_memmove_aligned (mono_object_get_data (obj
), (char*)src
+ MONO_ABI_SIZEOF (MonoObject
),
290 mono_object_class (obj
)->instance_size
- MONO_ABI_SIZEOF (MonoObject
));
294 mono_gc_is_critical_method (MonoMethod
*method
)
300 mono_gc_thread_attach (MonoThreadInfo
* info
)
302 info
->handle_stack
= mono_handle_stack_alloc ();
307 mono_gc_thread_detach_with_lock (MonoThreadInfo
*p
)
309 mono_handle_stack_free (p
->handle_stack
);
313 mono_gc_thread_in_critical_region (MonoThreadInfo
*info
)
319 mono_gc_get_aligned_size_for_allocator (int size
)
325 mono_gc_get_managed_allocator (MonoClass
*klass
, gboolean for_box
, gboolean known_instance_size
)
331 mono_gc_get_managed_array_allocator (MonoClass
*klass
)
337 mono_gc_get_managed_allocator_by_type (int atype
, ManagedAllocatorVariant variant
)
343 mono_gc_get_managed_allocator_types (void)
349 mono_gc_get_gc_name (void)
355 mono_gc_clear_domain (MonoDomain
*domain
)
360 mono_gc_suspend_finalizers (void)
365 mono_gc_get_suspend_signal (void)
371 mono_gc_get_restart_signal (void)
377 mono_gc_get_specific_write_barrier (gboolean is_concurrent
)
379 g_assert_not_reached ();
384 mono_gc_get_write_barrier (void)
386 g_assert_not_reached ();
391 mono_gc_invoke_with_gc_lock (MonoGCLockedCallbackFunc func
, void *data
)
397 mono_gc_get_description (void)
399 return g_strdup (DEFAULT_GC_NAME
);
403 mono_gc_set_desktop_mode (void)
408 mono_gc_is_moving (void)
414 mono_gc_is_disabled (void)
420 mono_gc_wbarrier_range_copy (gpointer _dest
, gconstpointer _src
, int size
)
422 g_assert_not_reached ();
425 MonoRangeCopyFunction
426 mono_gc_get_range_copy_func (void)
428 return &mono_gc_wbarrier_range_copy
;
432 mono_gc_get_card_table (int *shift_bits
, gpointer
*card_mask
)
434 g_assert_not_reached ();
439 mono_gc_get_target_card_table (int *shift_bits
, target_mgreg_t
*card_mask
)
447 mono_gc_card_table_nursery_check (void)
449 g_assert_not_reached ();
454 mono_gc_get_nursery (int *shift_bits
, size_t *size
)
460 mono_gc_precise_stack_mark_enabled (void)
466 mono_gc_get_logfile (void)
472 mono_gc_params_set (const char* options
)
477 mono_gc_debug_set (const char* options
)
482 mono_gc_conservatively_scan_area (void *start
, void *end
)
484 g_assert_not_reached ();
488 mono_gc_scan_object (void *obj
, void *gc_data
)
490 g_assert_not_reached ();
495 mono_gc_get_bitmap_for_descr (void *descr
, int *numbits
)
497 g_assert_not_reached ();
502 mono_gc_set_gc_callbacks (MonoGCCallbacks
*callbacks
)
507 mono_gc_set_stack_end (void *stack_end
)
512 mono_gc_get_los_limit (void)
518 mono_gc_user_markers_supported (void)
524 mono_gc_make_root_descr_user (MonoGCRootMarkFunc marker
)
526 g_assert_not_reached ();
532 mono_gc_pthread_create (pthread_t
*new_thread
, const pthread_attr_t
*attr
, void *(*start_routine
)(void *), void *arg
)
534 return pthread_create (new_thread
, attr
, start_routine
, arg
);
539 mono_gc_skip_thread_changing (gboolean skip
)
541 // No STW, nothing needs to be done.
545 mono_gc_skip_thread_changed (gboolean skip
)
550 BOOL APIENTRY
mono_gc_dllmain (HMODULE module_handle
, DWORD reason
, LPVOID reserved
)
557 mono_gc_get_vtable (MonoObject
*obj
)
559 // No pointer tagging.
564 mono_gc_get_vtable_bits (MonoClass
*klass
)
570 mono_gc_register_altstack (gpointer stack
, gint32 stack_size
, gpointer altstack
, gint32 altstack_size
)
575 mono_gc_is_null (void)
581 mono_gc_invoke_finalizers (void)
587 mono_gc_pending_finalizers (void)
593 mono_gc_ephemeron_array_add (MonoObject
*obj
)
600 MONO_EMPTY_SOURCE_FILE (null_gc
);
601 #endif /* HAVE_NULL_GC */