Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/libgc
diff options
context:
space:
mode:
authorRodrigo Kumpera <kumpera@gmail.com>2014-03-14 02:47:26 +0400
committerRodrigo Kumpera <kumpera@gmail.com>2014-03-14 02:47:26 +0400
commitecf3c6499ab8b39f123d2e69f09e42508336b7ae (patch)
tree284f83361ba3b32596f24f0db7693e9a2d496c60 /libgc
parent5dc84a1dcff4c94e0e7b072348a826e8ea061955 (diff)
[boehm] Fix memory management for toggleref.
Replace GC_free with GC_INTERNAL_FREE. The former might take the GC lock and deadlock us. Replace GC_INTERNAL_MALLOC with GC_INTERNAL_MALLOC_IGNORE_OFF_PAGE as we don't need the rest of the GC messing around with the toggleref array.
Diffstat (limited to 'libgc')
-rw-r--r--libgc/finalize.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/libgc/finalize.c b/libgc/finalize.c
index fd133ae4b11..91f6970180c 100644
--- a/libgc/finalize.c
+++ b/libgc/finalize.c
@@ -386,7 +386,7 @@ static void GC_mark_togglerefs ()
if (!GC_toggleref_array)
return;
- GC_set_mark_bit (GC_toggleref_array);
+ GC_set_mark_bit ((GC_PTR)GC_toggleref_array);
for (i = 0; i < GC_toggleref_array_size; ++i) {
if (GC_toggleref_array [i].strong_ref) {
GC_PTR object = GC_toggleref_array [i].strong_ref;
@@ -424,7 +424,7 @@ ensure_toggleref_capacity (int capacity)
{
if (!GC_toggleref_array) {
GC_toggleref_array_capacity = 32;
- GC_toggleref_array = (GCToggleRef *) GC_INTERNAL_MALLOC (GC_toggleref_array_capacity * sizeof (GCToggleRef), NORMAL);
+ GC_toggleref_array = (GCToggleRef *) GC_INTERNAL_MALLOC_IGNORE_OFF_PAGE (GC_toggleref_array_capacity * sizeof (GCToggleRef), NORMAL);
}
if (GC_toggleref_array_size + capacity >= GC_toggleref_array_capacity) {
GCToggleRef *tmp;
@@ -432,10 +432,9 @@ ensure_toggleref_capacity (int capacity)
while (GC_toggleref_array_capacity < GC_toggleref_array_size + capacity)
GC_toggleref_array_capacity *= 2;
- tmp = (GCToggleRef *) GC_INTERNAL_MALLOC (GC_toggleref_array_capacity * sizeof (GCToggleRef), NORMAL);
+ tmp = (GCToggleRef *) GC_INTERNAL_MALLOC_IGNORE_OFF_PAGE (GC_toggleref_array_capacity * sizeof (GCToggleRef), NORMAL);
memcpy (tmp, GC_toggleref_array, GC_toggleref_array_size * sizeof (GCToggleRef));
-
- GC_free((GC_PTR)GC_toggleref_array);
+ GC_INTERNAL_FREE (GC_toggleref_array);
GC_toggleref_array = tmp;
}
}