summaryrefslogtreecommitdiff
path: root/tests/test.c
diff options
context:
space:
mode:
authorIvan Maidanski <ivmai@mail.ru>2018-05-08 22:21:59 +0300
committerIvan Maidanski <ivmai@mail.ru>2018-05-08 22:21:59 +0300
commitb52c140d37cb212f93c6247a7a06e523ce420279 (patch)
tree23449d29a0f8544b08a2f23bd09927e0570897de /tests/test.c
parent510fb9f634b3374da6de7f6849e0a4f44f945723 (diff)
downloadbdwgc-b52c140d37cb212f93c6247a7a06e523ce420279.tar.gz
Fix tests for GC compiled with MANUAL_VDB
* tests/disclaim_test.c (pair_dct, pair_new): Call GC_end_stubborn_change(p) after writing the last pointer field of p. * tests/test.c [!DBG_HDRS_ALL] (run_one_test): Likewise. * tests/test.c (small_cons, small_cons_uncollectable, mktree, typed_test): Call GC_END_STUBBORN_CHANGE(r) after writing the last pointer field of r. * tests/test.c [GC_GCJ_SUPPORT] (gcj_cons): Likewise. * tests/test.c [!SMALL_CONFIG && !GC_DEBUG] (alloc8bytes): Likewise.
Diffstat (limited to 'tests/test.c')
-rw-r--r--tests/test.c27
1 files changed, 20 insertions, 7 deletions
diff --git a/tests/test.c b/tests/test.c
index c389b397..2506321d 100644
--- a/tests/test.c
+++ b/tests/test.c
@@ -369,6 +369,7 @@ sexpr small_cons (sexpr x, sexpr y)
AO_fetch_and_add1(&collectable_count);
r -> sexpr_car = x;
r -> sexpr_cdr = y;
+ GC_END_STUBBORN_CHANGE(r);
return(r);
}
@@ -380,6 +381,7 @@ sexpr small_cons_uncollectable (sexpr x, sexpr y)
AO_fetch_and_add1(&uncollectable_count);
r -> sexpr_car = x;
r -> sexpr_cdr = (sexpr)(~(GC_word)y);
+ GC_END_STUBBORN_CHANGE(r);
return(r);
}
@@ -397,6 +399,7 @@ sexpr small_cons_uncollectable (sexpr x, sexpr y)
result = (sexpr)(r + 1);
result -> sexpr_car = x;
result -> sexpr_cdr = y;
+ GC_END_STUBBORN_CHANGE(r);
return(result);
}
#endif /* GC_GCJ_SUPPORT */
@@ -865,12 +868,16 @@ tn * mktree(int n)
result -> rchild = mktree(n-1);
if (AO_fetch_and_add1(&extra_count) % 17 == 0 && n >= 2) {
tn * tmp;
-
- CHECK_OUT_OF_MEMORY(result->lchild);
- tmp = result -> lchild -> rchild;
- CHECK_OUT_OF_MEMORY(result->rchild);
- result -> lchild -> rchild = result -> rchild -> lchild;
- result -> rchild -> lchild = tmp;
+ tn * left = result -> lchild;
+ tn * right = result -> rchild;
+
+ CHECK_OUT_OF_MEMORY(left);
+ tmp = left -> rchild;
+ CHECK_OUT_OF_MEMORY(right);
+ left -> rchild = right -> lchild;
+ right -> lchild = tmp;
+ GC_END_STUBBORN_CHANGE(left);
+ GC_END_STUBBORN_CHANGE(right);
}
if (AO_fetch_and_add1(&extra_count) % 119 == 0) {
# ifndef GC_NO_FINALIZATION
@@ -959,6 +966,7 @@ tn * mktree(int n)
# endif
GC_reachable_here(result);
}
+ GC_END_STUBBORN_CHANGE(result);
return(result);
}
@@ -1016,6 +1024,7 @@ void * alloc8bytes(void)
}
*my_free_list_ptr = GC_NEXT(my_free_list);
GC_NEXT(my_free_list) = 0;
+ GC_END_STUBBORN_CHANGE(my_free_list_ptr);
AO_fetch_and_add1(&collectable_count);
return(my_free_list);
# endif
@@ -1159,12 +1168,14 @@ void typed_test(void)
CHECK_OUT_OF_MEMORY(newP);
newP[0] = 17;
newP[1] = (GC_word)old;
+ GC_END_STUBBORN_CHANGE(newP);
old = newP;
AO_fetch_and_add1(&collectable_count);
newP = (GC_word*)GC_malloc_explicitly_typed(33 * sizeof(GC_word), d3);
CHECK_OUT_OF_MEMORY(newP);
newP[0] = 17;
newP[1] = (GC_word)old;
+ GC_END_STUBBORN_CHANGE(newP);
old = newP;
AO_fetch_and_add1(&collectable_count);
newP = (GC_word *)GC_calloc_explicitly_typed(4, 2 * sizeof(GC_word),
@@ -1172,6 +1183,7 @@ void typed_test(void)
CHECK_OUT_OF_MEMORY(newP);
newP[0] = 17;
newP[1] = (GC_word)old;
+ GC_END_STUBBORN_CHANGE(newP);
old = newP;
AO_fetch_and_add1(&collectable_count);
if (i & 0xff) {
@@ -1189,6 +1201,7 @@ void typed_test(void)
CHECK_OUT_OF_MEMORY(newP);
newP[0] = 17;
newP[1] = (GC_word)old;
+ GC_END_STUBBORN_CHANGE(newP);
old = newP;
}
for (i = 0; i < 20000; i++) {
@@ -1348,6 +1361,7 @@ void run_one_test(void)
CHECK_OUT_OF_MEMORY(z);
AO_fetch_and_add1(&collectable_count);
GC_PTR_STORE(z, x);
+ GC_end_stubborn_change(z);
if (*z != x) {
GC_printf("GC_PTR_STORE failed: %p != %p\n", (void *)(*z), (void *)x);
FAIL;
@@ -1846,7 +1860,6 @@ void GC_CALLBACK warn_proc(char *msg, GC_word p)
# if defined(CPPCHECK)
/* Entry points we should be testing, but aren't. */
# ifndef GC_DEBUG
- UNTESTED(GC_debug_end_stubborn_change);
UNTESTED(GC_debug_generic_or_special_malloc);
UNTESTED(GC_debug_register_displacement);
UNTESTED(GC_post_incr);