aboutsummaryrefslogtreecommitdiffstats
path: root/vm_insnhelper.c
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-10-29 22:43:45 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-10-29 22:43:45 +0000
commit86b4e3bb817c4f2992a60eba88b2543d80123804 (patch)
tree0de55747f141abd966094612066382ed73e78302 /vm_insnhelper.c
parent1d122a7c73ba8ec2af0f9ec1a7662b9d90bb5efe (diff)
downloadruby-86b4e3bb817c4f2992a60eba88b2543d80123804.tar.gz
* insns.def (getinlinecache/setinlinecache): compare ic->ic_cref and
current cref only when cached CREF list includes singleton class. Singleton classes have own namespaces, so that we need to check cref as a key (#10943). However, if current CREF list does not include singleton class, no need to check CREF beacuse it should be same name space. * vm_insnhelper.c (vm_get_const_key_cref): add a function returns CREF only when it includes singleton class. * vm_core.h: constify iseq_inline_cache_entry::ic_cref. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52371 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'vm_insnhelper.c')
-rw-r--r--vm_insnhelper.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/vm_insnhelper.c b/vm_insnhelper.c
index 6a7bba92d4..ae6195ef4c 100644
--- a/vm_insnhelper.c
+++ b/vm_insnhelper.c
@@ -500,6 +500,23 @@ rb_vm_get_cref(const VALUE *ep)
}
}
+static const rb_cref_t *
+vm_get_const_key_cref(const VALUE *ep)
+{
+ const rb_cref_t *cref = rb_vm_get_cref(ep);
+ const rb_cref_t *key_cref = cref;
+
+ while (cref) {
+ if (FL_TEST(CREF_CLASS(cref), FL_SINGLETON)) {
+ return key_cref;
+ }
+ cref = CREF_NEXT(cref);
+ }
+
+ /* does not incldue singleton class */
+ return NULL;
+}
+
void
rb_vm_rewrite_cref(rb_cref_t *cref, VALUE old_klass, VALUE new_klass, rb_cref_t **new_cref_ptr)
{