aboutsummaryrefslogtreecommitdiffstats
path: root/gc.c
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-04-21 23:37:18 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-04-21 23:37:18 +0000
commitd32ad2efcaf6cf9babc6272482582dddda241a8f (patch)
treefaea1abe62d57cceee19b0af844e47038ace9d89 /gc.c
parent5890cb9d2d9ccd704b07764beba879bb9b97c2c9 (diff)
downloadruby-d32ad2efcaf6cf9babc6272482582dddda241a8f.tar.gz
* gc.c (objspace_malloc_increase): don't cause GC by malloc_increase
when memop type is MEMOP_TYPE_REALLOC. GC at realloc is not well maintained. We need a time to make it safe. [ruby-dev:48117] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@45656 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r--gc.c26
1 files changed, 13 insertions, 13 deletions
diff --git a/gc.c b/gc.c
index 2a2be3b06a..29e75a8e51 100644
--- a/gc.c
+++ b/gc.c
@@ -6097,20 +6097,20 @@ objspace_malloc_increase(rb_objspace_t *objspace, void *mem, size_t new_size, si
#endif
}
- if (type == MEMOP_TYPE_MALLOC || type == MEMOP_TYPE_REALLOC) {
- int full_mark = gc_stress_full_mark_after_malloc_p();
- if (ruby_gc_stress && !ruby_disable_gc_stress && ruby_native_thread_p()) {
- garbage_collect_with_gvl(objspace, full_mark, TRUE, GPR_FLAG_MALLOC);
- }
- else {
- retry:
- if (malloc_increase > malloc_limit && ruby_native_thread_p()) {
- if (ruby_thread_has_gvl_p() && is_lazy_sweeping(heap_eden)) {
- gc_rest_sweep(objspace); /* rest_sweep can reduce malloc_increase */
- goto retry;
- }
- garbage_collect_with_gvl(objspace, full_mark, TRUE, GPR_FLAG_MALLOC);
+ if (type != MEMOP_TYPE_FREE &&
+ ruby_gc_stress && !ruby_disable_gc_stress &&
+ ruby_native_thread_p()) {
+ garbage_collect_with_gvl(objspace, gc_stress_full_mark_after_malloc_p(), TRUE, GPR_FLAG_MALLOC);
+ }
+
+ if (type == MEMOP_TYPE_MALLOC) {
+ retry:
+ if (malloc_increase > malloc_limit && ruby_native_thread_p()) {
+ if (ruby_thread_has_gvl_p() && is_lazy_sweeping(heap_eden)) {
+ gc_rest_sweep(objspace); /* rest_sweep can reduce malloc_increase */
+ goto retry;
}
+ garbage_collect_with_gvl(objspace, FALSE, TRUE, GPR_FLAG_MALLOC);
}
}