mono_thread_info_attach (&dummy);
}
+void
+mono_gc_base_cleanup (void)
+{
+}
+
void
mono_gc_collect (int generation)
{
{
}
+void
+mono_gc_enable_alloc_events (void)
+{
+}
+
int
-mono_gc_register_root (char *start, size_t size, void *descr)
+mono_gc_register_root (char *start, size_t size, void *descr, MonoGCRootSource source, const char *msg)
{
return TRUE;
}
}
void*
-mono_gc_alloc_fixed (size_t size, void *descr)
+mono_gc_alloc_fixed (size_t size, void *descr, MonoGCRootSource source, const char *msg)
{
return g_malloc0 (size);
}
g_free (addr);
}
+void *
+mono_gc_alloc_obj (MonoVTable *vtable, size_t size)
+{
+ MonoObject *obj = calloc (1, size);
+
+ obj->vtable = vtable;
+
+ return obj;
+}
+
+void *
+mono_gc_alloc_vector (MonoVTable *vtable, size_t size, uintptr_t max_length)
+{
+ MonoArray *obj = calloc (1, size);
+
+ obj->obj.vtable = vtable;
+ obj->max_length = max_length;
+
+ return obj;
+}
+
+void *
+mono_gc_alloc_array (MonoVTable *vtable, size_t size, uintptr_t max_length, uintptr_t bounds_size)
+{
+ MonoArray *obj = calloc (1, size);
+
+ obj->obj.vtable = vtable;
+ obj->max_length = max_length;
+
+ if (bounds_size)
+ obj->bounds = (MonoArrayBounds *) ((char *) obj + size - bounds_size);
+
+ return obj;
+}
+
+void *
+mono_gc_alloc_string (MonoVTable *vtable, size_t size, gint32 len)
+{
+ MonoString *obj = calloc (1, size);
+
+ obj->object.vtable = vtable;
+ obj->length = len;
+ obj->chars [len] = 0;
+
+ return obj;
+}
+
void
mono_gc_wbarrier_set_field (MonoObject *obj, gpointer field_ptr, MonoObject* value)
{
}
MonoMethod*
-mono_gc_get_managed_allocator_by_type (int atype)
+mono_gc_get_managed_allocator_by_type (int atype, gboolean slowpath)
{
return NULL;
}
return TRUE;
}
+gboolean
+mono_gc_is_null (void)
+{
+ return TRUE;
+}
+
#endif