summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-06-24 18:38:36 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-06-24 18:38:36 +0000
commit9a2638717c929a29247507a030f33777b7d11e98 (patch)
tree0a8c5853bbfe16ddfad05f197d6f87aa63ab264f
parent8b192636730a58eb51f218aaa1d861da1758fd7e (diff)
* gc.c (RGENGC_OBJ_INFO, obj_info): add a macro to enable/disable
rich obj_info() output. At the default, the value of RGENGC_OBJ_INFO is (RGENGC_DEBUG | RGENGC_CHECK_MODE). * gc.c (RGENGC_OBJ_INFO): force enable it to debug #11244. * gc.c (gc_mark_ptr): print more details with obj_info(). * gc.c (gc_mark_children): remove useless debug prints. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@51018 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog14
-rw-r--r--gc.c25
2 files changed, 31 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog
index 2a924b4ce2..757f9f9c9d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,17 @@
+Thu Jun 25 03:33:21 2015 Koichi Sasada <ko1@atdot.net>
+
+ * gc.c (RGENGC_OBJ_INFO, obj_info): add a macro to enable/disable
+ rich obj_info() output.
+
+ At the default, the value of RGENGC_OBJ_INFO is
+ (RGENGC_DEBUG | RGENGC_CHECK_MODE).
+
+ * gc.c (RGENGC_OBJ_INFO): force enable it to debug #11244.
+
+ * gc.c (gc_mark_ptr): print more details with obj_info().
+
+ * gc.c (gc_mark_children): remove useless debug prints.
+
Thu Jun 25 02:40:33 2015 Eric Wong <e@80x24.org>
* ext/openssl/ossl_ssl.c (ossl_ssl_read_internal):
diff --git a/gc.c b/gc.c
index d5719fe7b1..d0def041c5 100644
--- a/gc.c
+++ b/gc.c
@@ -305,6 +305,12 @@ static ruby_gc_params_t gc_params = {
#define GC_DEBUG_STRESS_TO_CLASS 0
#endif
+#define RGENGC_OBJ_INFO 1
+
+#ifndef RGENGC_OBJ_INFO
+#define RGENGC_OBJ_INFO (RGENGC_DEBUG | RGENGC_CHECK_MODE)
+#endif
+
typedef enum {
GPR_FLAG_NONE = 0x000,
/* major reason */
@@ -4192,11 +4198,18 @@ static void
gc_mark_ptr(rb_objspace_t *objspace, VALUE obj)
{
if (LIKELY(objspace->mark_func_data == NULL)) {
- rgengc_check_relation(objspace, obj);
-
/* check code for Bug #11244 */
- if (BUILTIN_TYPE(obj) == T_NONE) rb_bug("gc_mark_ptr: obj is T_NONE");
+ if (BUILTIN_TYPE(obj) == T_NONE) {
+ if (objspace->rgengc.parent_object) {
+ rb_bug("gc_mark_ptr: obj is %s (parent: %s)", obj_info(obj),
+ obj_info(objspace->rgengc.parent_object));
+ }
+ else {
+ rb_bug("gc_mark_ptr: obj is %s (parent is not old)", obj_info(obj));
+ }
+ }
+ rgengc_check_relation(objspace, obj);
if (!gc_mark_set(objspace, obj)) return; /* already marked */
gc_aging(objspace, obj);
gc_grey(objspace, obj);
@@ -4304,10 +4317,6 @@ gc_mark_children(rb_objspace_t *objspace, VALUE obj)
if (!RCLASS_EXT(obj)) break;
mark_tbl(objspace, RCLASS_IV_TBL(obj));
mark_const_tbl(objspace, RCLASS_CONST_TBL(obj));
-
- /* TODO: remove it. check code for Bug #11244 */
- if (RB_TYPE_P(RCLASS_SUPER(obj), T_NONE)) rb_bug("gc_mark_children: super is T_NONE (%s)", obj_info(obj));
-
gc_mark(objspace, RCLASS_SUPER((VALUE)obj));
break;
@@ -8828,7 +8837,7 @@ obj_type_name(VALUE obj)
return type_name(TYPE(obj), obj);
}
-#if RGENGC_DEBUG || RGENGC_CHECK_MODE
+#if RGENGC_OBJ_INFO
#define OBJ_INFO_BUFFERS_NUM 10
#define OBJ_INFO_BUFFERS_SIZE 0x100
static int obj_info_buffers_index = 0;