]> granicus.if.org Git - gc/commitdiff
Fix infinite mark_some calls after memory mapping disappeared (Glibc)
authorIvan Maidanski <ivmai@mail.ru>
Tue, 19 Sep 2017 07:51:24 +0000 (10:51 +0300)
committerIvan Maidanski <ivmai@mail.ru>
Thu, 28 Sep 2017 21:35:57 +0000 (00:35 +0300)
Issue #179 (bdwgc).

* mark.c [WRAP_MARK_SOME && REGISTER_LIBRARIES_EARLY] (GC_mark_some):
Call GC_cond_register_dynamic_libraries (with the world running)
before GC_invalidate_mark_state().

mark.c

diff --git a/mark.c b/mark.c
index 9cb6f2e4a81a24ae78c4e0ec01b88262bb37e4bd..a77f9662a9433177f43651e5bc2e6bece98a6f63 100644 (file)
--- a/mark.c
+++ b/mark.c
@@ -580,6 +580,11 @@ handle_ex:
       }
       /* We have bad roots on the stack.  Discard mark stack.   */
       /* Rescan from marked objects.  Redetermine roots.        */
+#     ifdef REGISTER_LIBRARIES_EARLY
+        START_WORLD();
+        GC_cond_register_dynamic_libraries();
+        STOP_WORLD();
+#     endif
       GC_invalidate_mark_state();
       scan_ptr = 0;