summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2019-08-27 03:08:53 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2019-08-27 03:08:53 +0000
commit00a7d49b422b5cca81120e370c97c4ce0d864fe8 (patch)
tree33b4cd561b7e0d079d23f8b1bdb02077b0f00d8b
parent4d9c58752a1d83be10811d4929c809a60eefeff8 (diff)
merge revision(s) f1a52d96a59c63d46cb23af60cdcaf38e30e0512 [Backport #15784]
Defer setting gc_stress until inits done [Bug #15784] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_5@67775 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--gc.c12
-rw-r--r--inits.c1
-rw-r--r--version.h2
3 files changed, 14 insertions, 1 deletions
diff --git a/gc.c b/gc.c
index 21554eeabf..7c972f5b50 100644
--- a/gc.c
+++ b/gc.c
@@ -2388,6 +2388,10 @@ Init_heap(void)
gc_stress_set(objspace, ruby_initial_gc_stress);
+ dont_gc = 1;
+
+ gc_stress_set(objspace, ruby_initial_gc_stress);
+
#if RGENGC_ESTIMATE_OLDMALLOC
objspace->rgengc.oldmalloc_increase_limit = gc_params.oldmalloc_limit_min;
#endif
@@ -2409,6 +2413,14 @@ Init_heap(void)
finalizer_table = st_init_numtable();
}
+void
+Init_gc_stress(void)
+{
+ rb_objspace_t *objspace = &rb_objspace;
+
+ dont_gc = 0;
+}
+
typedef int each_obj_callback(void *, void *, size_t, void *);
struct each_obj_args {
diff --git a/inits.c b/inits.c
index 5822f04cab..d6cc0cbc78 100644
--- a/inits.c
+++ b/inits.c
@@ -61,5 +61,6 @@ rb_call_inits(void)
CALL(Complex);
CALL(version);
CALL(vm_trace);
+ CALL(gc_stress);
}
#undef CALL
diff --git a/version.h b/version.h
index 1cb2cd846a..0abdcb48a6 100644
--- a/version.h
+++ b/version.h
@@ -1,6 +1,6 @@
#define RUBY_VERSION "2.5.6"
#define RUBY_RELEASE_DATE "2019-08-27"
-#define RUBY_PATCHLEVEL 193
+#define RUBY_PATCHLEVEL 194
#define RUBY_RELEASE_YEAR 2019
#define RUBY_RELEASE_MONTH 8