summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-03-19 13:13:46 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-03-19 13:13:46 +0000
commit8ed4c1a42042e66ecbafd65ed5602154c39b4e65 (patch)
treec0f15ff80477fc85630ba52eacfbd12f35e6c8e7
parent531f775fd4ed171a1f297e1aa00940ce9f2a457b (diff)
* gc.c (rb_copy_wb_protected_attribute): `dest' can be WB unprotected.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@50028 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--gc.c7
2 files changed, 5 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 01f9280364..2938126075 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Thu Mar 19 22:12:46 2015 Koichi Sasada <ko1@atdot.net>
+
+ * gc.c (rb_copy_wb_protected_attribute): `dest' can be WB unprotected.
+
Thu Mar 19 21:25:25 2015 Koichi Sasada <ko1@atdot.net>
* gc.c (rb_copy_wb_protected_attribute): demote `dest' object.
diff --git a/gc.c b/gc.c
index 2a191ae90e..a0158d24db 100644
--- a/gc.c
+++ b/gc.c
@@ -5734,12 +5734,7 @@ rb_copy_wb_protected_attribute(VALUE dest, VALUE obj)
#if USE_RGENGC
rb_objspace_t *objspace = &rb_objspace;
- if (RGENGC_CHECK_MODE > 0 && RVALUE_WB_UNPROTECTED(dest)) {
- rb_bug("rb_copy_wb_protected_attribute: dest should not be WB unprotected - %s",
- obj_info(dest));
- }
-
- if (RVALUE_WB_UNPROTECTED(obj)) {
+ if (RVALUE_WB_UNPROTECTED(obj) && !RVALUE_WB_UNPROTECTED(dest)) {
if (!RVALUE_OLD_P(dest)) {
MARK_IN_BITMAP(GET_HEAP_WB_UNPROTECTED_BITS(dest), dest);
RVALUE_AGE_RESET_RAW(dest);