mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Remove unused class serial
Before object shapes, we were using class serial to invalidate inline caches. Now that we use shape_id for inline cache keys, the class serial is unnecessary. Co-Authored-By: Aaron Patterson <tenderlove@ruby-lang.org>
This commit is contained in:
parent
87bb0bee6b
commit
13bd617ea6
Notes:
git
2022-10-21 21:57:08 +00:00
7 changed files with 3 additions and 57 deletions
6
class.c
6
class.c
|
@ -208,9 +208,6 @@ class_alloc(VALUE flags, VALUE klass)
|
||||||
|
|
||||||
#if USE_RVARGC
|
#if USE_RVARGC
|
||||||
memset(RCLASS_EXT(obj), 0, sizeof(rb_classext_t));
|
memset(RCLASS_EXT(obj), 0, sizeof(rb_classext_t));
|
||||||
# if SIZEOF_SERIAL_T != SIZEOF_VALUE
|
|
||||||
RCLASS(obj)->class_serial_ptr = ZALLOC(rb_serial_t);
|
|
||||||
# endif
|
|
||||||
#else
|
#else
|
||||||
obj->ptr = ZALLOC(rb_classext_t);
|
obj->ptr = ZALLOC(rb_classext_t);
|
||||||
#endif
|
#endif
|
||||||
|
@ -226,7 +223,6 @@ class_alloc(VALUE flags, VALUE klass)
|
||||||
RCLASS_MODULE_SUBCLASSES(obj) = NULL;
|
RCLASS_MODULE_SUBCLASSES(obj) = NULL;
|
||||||
*/
|
*/
|
||||||
RCLASS_SET_ORIGIN((VALUE)obj, (VALUE)obj);
|
RCLASS_SET_ORIGIN((VALUE)obj, (VALUE)obj);
|
||||||
RCLASS_SERIAL(obj) = rb_next_class_serial();
|
|
||||||
RB_OBJ_WRITE(obj, &RCLASS_REFINED_CLASS(obj), Qnil);
|
RB_OBJ_WRITE(obj, &RCLASS_REFINED_CLASS(obj), Qnil);
|
||||||
RCLASS_ALLOCATOR(obj) = 0;
|
RCLASS_ALLOCATOR(obj) = 0;
|
||||||
|
|
||||||
|
@ -2143,9 +2139,7 @@ singleton_class_of(VALUE obj)
|
||||||
klass = METACLASS_OF(obj);
|
klass = METACLASS_OF(obj);
|
||||||
if (!(FL_TEST(klass, FL_SINGLETON) &&
|
if (!(FL_TEST(klass, FL_SINGLETON) &&
|
||||||
rb_attr_get(klass, id_attached) == obj)) {
|
rb_attr_get(klass, id_attached) == obj)) {
|
||||||
rb_serial_t serial = RCLASS_SERIAL(klass);
|
|
||||||
klass = rb_make_metaclass(obj, klass);
|
klass = rb_make_metaclass(obj, klass);
|
||||||
RCLASS_SERIAL(klass) = serial;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RB_FL_SET_RAW(klass, RB_OBJ_FROZEN_RAW(obj));
|
RB_FL_SET_RAW(klass, RB_OBJ_FROZEN_RAW(obj));
|
||||||
|
|
3
gc.c
3
gc.c
|
@ -3463,9 +3463,6 @@ obj_free(rb_objspace_t *objspace, VALUE obj)
|
||||||
if (FL_TEST_RAW(obj, RCLASS_SUPERCLASSES_INCLUDE_SELF)) {
|
if (FL_TEST_RAW(obj, RCLASS_SUPERCLASSES_INCLUDE_SELF)) {
|
||||||
xfree(RCLASS_SUPERCLASSES(obj));
|
xfree(RCLASS_SUPERCLASSES(obj));
|
||||||
}
|
}
|
||||||
#if SIZEOF_SERIAL_T != SIZEOF_VALUE && USE_RVARGC
|
|
||||||
xfree(RCLASS(obj)->class_serial_ptr);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !USE_RVARGC
|
#if !USE_RVARGC
|
||||||
if (RCLASS_EXT(obj))
|
if (RCLASS_EXT(obj))
|
||||||
|
|
|
@ -40,9 +40,6 @@ struct rb_cvar_class_tbl_entry {
|
||||||
|
|
||||||
struct rb_classext_struct {
|
struct rb_classext_struct {
|
||||||
struct st_table *iv_tbl;
|
struct st_table *iv_tbl;
|
||||||
#if SIZEOF_SERIAL_T == SIZEOF_VALUE /* otherwise m_tbl is in struct RClass */
|
|
||||||
struct rb_id_table *m_tbl;
|
|
||||||
#endif
|
|
||||||
struct rb_id_table *const_tbl;
|
struct rb_id_table *const_tbl;
|
||||||
struct rb_id_table *callable_m_tbl;
|
struct rb_id_table *callable_m_tbl;
|
||||||
struct rb_id_table *cc_tbl; /* ID -> [[ci, cc1], cc2, ...] */
|
struct rb_id_table *cc_tbl; /* ID -> [[ci, cc1], cc2, ...] */
|
||||||
|
@ -57,9 +54,6 @@ struct rb_classext_struct {
|
||||||
* included. Hopefully that makes sense.
|
* included. Hopefully that makes sense.
|
||||||
*/
|
*/
|
||||||
struct rb_subclass_entry *module_subclass_entry;
|
struct rb_subclass_entry *module_subclass_entry;
|
||||||
#if SIZEOF_SERIAL_T != SIZEOF_VALUE && !USE_RVARGC /* otherwise class_serial is in struct RClass */
|
|
||||||
rb_serial_t class_serial;
|
|
||||||
#endif
|
|
||||||
const VALUE origin_;
|
const VALUE origin_;
|
||||||
const VALUE refined_class;
|
const VALUE refined_class;
|
||||||
rb_alloc_func_t allocator;
|
rb_alloc_func_t allocator;
|
||||||
|
@ -73,19 +67,10 @@ struct rb_classext_struct {
|
||||||
struct RClass {
|
struct RClass {
|
||||||
struct RBasic basic;
|
struct RBasic basic;
|
||||||
VALUE super;
|
VALUE super;
|
||||||
|
struct rb_id_table *m_tbl;
|
||||||
#if !USE_RVARGC
|
#if !USE_RVARGC
|
||||||
struct rb_classext_struct *ptr;
|
struct rb_classext_struct *ptr;
|
||||||
#endif
|
#endif
|
||||||
#if SIZEOF_SERIAL_T == SIZEOF_VALUE
|
|
||||||
/* Class serial is as wide as VALUE. Place it here. */
|
|
||||||
rb_serial_t class_serial;
|
|
||||||
#else
|
|
||||||
/* Class serial does not fit into struct RClass. Place m_tbl instead. */
|
|
||||||
struct rb_id_table *m_tbl;
|
|
||||||
# if USE_RVARGC
|
|
||||||
rb_serial_t *class_serial_ptr;
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct rb_subclass_entry rb_subclass_entry_t;
|
typedef struct rb_subclass_entry rb_subclass_entry_t;
|
||||||
|
@ -98,25 +83,12 @@ typedef struct rb_classext_struct rb_classext_t;
|
||||||
#endif
|
#endif
|
||||||
#define RCLASS_IV_TBL(c) (RCLASS_EXT(c)->iv_tbl)
|
#define RCLASS_IV_TBL(c) (RCLASS_EXT(c)->iv_tbl)
|
||||||
#define RCLASS_CONST_TBL(c) (RCLASS_EXT(c)->const_tbl)
|
#define RCLASS_CONST_TBL(c) (RCLASS_EXT(c)->const_tbl)
|
||||||
#if SIZEOF_SERIAL_T == SIZEOF_VALUE
|
|
||||||
# define RCLASS_M_TBL(c) (RCLASS_EXT(c)->m_tbl)
|
|
||||||
#else
|
|
||||||
#define RCLASS_M_TBL(c) (RCLASS(c)->m_tbl)
|
#define RCLASS_M_TBL(c) (RCLASS(c)->m_tbl)
|
||||||
#endif
|
|
||||||
#define RCLASS_CALLABLE_M_TBL(c) (RCLASS_EXT(c)->callable_m_tbl)
|
#define RCLASS_CALLABLE_M_TBL(c) (RCLASS_EXT(c)->callable_m_tbl)
|
||||||
#define RCLASS_CC_TBL(c) (RCLASS_EXT(c)->cc_tbl)
|
#define RCLASS_CC_TBL(c) (RCLASS_EXT(c)->cc_tbl)
|
||||||
#define RCLASS_CVC_TBL(c) (RCLASS_EXT(c)->cvc_tbl)
|
#define RCLASS_CVC_TBL(c) (RCLASS_EXT(c)->cvc_tbl)
|
||||||
#define RCLASS_ORIGIN(c) (RCLASS_EXT(c)->origin_)
|
#define RCLASS_ORIGIN(c) (RCLASS_EXT(c)->origin_)
|
||||||
#define RCLASS_REFINED_CLASS(c) (RCLASS_EXT(c)->refined_class)
|
#define RCLASS_REFINED_CLASS(c) (RCLASS_EXT(c)->refined_class)
|
||||||
#if SIZEOF_SERIAL_T == SIZEOF_VALUE
|
|
||||||
# define RCLASS_SERIAL(c) (RCLASS(c)->class_serial)
|
|
||||||
#else
|
|
||||||
# if USE_RVARGC
|
|
||||||
# define RCLASS_SERIAL(c) (*RCLASS(c)->class_serial_ptr)
|
|
||||||
# else
|
|
||||||
# define RCLASS_SERIAL(c) (RCLASS_EXT(c)->class_serial)
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
#define RCLASS_INCLUDER(c) (RCLASS_EXT(c)->includer)
|
#define RCLASS_INCLUDER(c) (RCLASS_EXT(c)->includer)
|
||||||
#define RCLASS_SUBCLASS_ENTRY(c) (RCLASS_EXT(c)->subclass_entry)
|
#define RCLASS_SUBCLASS_ENTRY(c) (RCLASS_EXT(c)->subclass_entry)
|
||||||
#define RCLASS_MODULE_SUBCLASS_ENTRY(c) (RCLASS_EXT(c)->module_subclass_entry)
|
#define RCLASS_MODULE_SUBCLASS_ENTRY(c) (RCLASS_EXT(c)->module_subclass_entry)
|
||||||
|
|
|
@ -40,7 +40,6 @@ enum method_missing_reason {
|
||||||
};
|
};
|
||||||
|
|
||||||
/* vm_insnhelper.h */
|
/* vm_insnhelper.h */
|
||||||
rb_serial_t rb_next_class_serial(void);
|
|
||||||
VALUE rb_vm_push_frame_fname(struct rb_execution_context_struct *ec, VALUE fname);
|
VALUE rb_vm_push_frame_fname(struct rb_execution_context_struct *ec, VALUE fname);
|
||||||
|
|
||||||
/* vm.c */
|
/* vm.c */
|
||||||
|
|
|
@ -4,11 +4,9 @@ require 'test/unit'
|
||||||
class TestRubyVM < Test::Unit::TestCase
|
class TestRubyVM < Test::Unit::TestCase
|
||||||
def test_stat
|
def test_stat
|
||||||
assert_kind_of Hash, RubyVM.stat
|
assert_kind_of Hash, RubyVM.stat
|
||||||
assert_kind_of Integer, RubyVM.stat[:class_serial]
|
|
||||||
|
|
||||||
RubyVM.stat(stat = {})
|
RubyVM.stat(stat = {})
|
||||||
assert_not_empty stat
|
assert_not_empty stat
|
||||||
assert_equal stat[:class_serial], RubyVM.stat(:class_serial)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_stat_unknown
|
def test_stat_unknown
|
||||||
|
|
13
vm.c
13
vm.c
|
@ -488,13 +488,6 @@ jit_exec(rb_execution_context_t *ec)
|
||||||
|
|
||||||
#define PROCDEBUG 0
|
#define PROCDEBUG 0
|
||||||
|
|
||||||
rb_serial_t
|
|
||||||
rb_next_class_serial(void)
|
|
||||||
{
|
|
||||||
rb_serial_t class_serial = NEXT_CLASS_SERIAL();
|
|
||||||
return class_serial;
|
|
||||||
}
|
|
||||||
|
|
||||||
VALUE rb_cRubyVM;
|
VALUE rb_cRubyVM;
|
||||||
VALUE rb_cThread;
|
VALUE rb_cThread;
|
||||||
VALUE rb_mRubyVMFrozenCore;
|
VALUE rb_mRubyVMFrozenCore;
|
||||||
|
@ -532,7 +525,6 @@ unsigned int ruby_vm_event_local_num;
|
||||||
|
|
||||||
rb_serial_t ruby_vm_constant_cache_invalidations = 0;
|
rb_serial_t ruby_vm_constant_cache_invalidations = 0;
|
||||||
rb_serial_t ruby_vm_constant_cache_misses = 0;
|
rb_serial_t ruby_vm_constant_cache_misses = 0;
|
||||||
rb_serial_t ruby_vm_class_serial = 1;
|
|
||||||
rb_serial_t ruby_vm_global_cvar_state = 1;
|
rb_serial_t ruby_vm_global_cvar_state = 1;
|
||||||
|
|
||||||
static const struct rb_callcache vm_empty_cc = {
|
static const struct rb_callcache vm_empty_cc = {
|
||||||
|
@ -612,7 +604,6 @@ rb_dtrace_setup(rb_execution_context_t *ec, VALUE klass, ID id,
|
||||||
* {
|
* {
|
||||||
* :constant_cache_invalidations=>2,
|
* :constant_cache_invalidations=>2,
|
||||||
* :constant_cache_misses=>14,
|
* :constant_cache_misses=>14,
|
||||||
* :class_serial=>546,
|
|
||||||
* :global_cvar_state=>27
|
* :global_cvar_state=>27
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
|
@ -624,7 +615,7 @@ rb_dtrace_setup(rb_execution_context_t *ec, VALUE klass, ID id,
|
||||||
static VALUE
|
static VALUE
|
||||||
vm_stat(int argc, VALUE *argv, VALUE self)
|
vm_stat(int argc, VALUE *argv, VALUE self)
|
||||||
{
|
{
|
||||||
static VALUE sym_constant_cache_invalidations, sym_constant_cache_misses, sym_class_serial, sym_global_cvar_state;
|
static VALUE sym_constant_cache_invalidations, sym_constant_cache_misses, sym_global_cvar_state;
|
||||||
VALUE arg = Qnil;
|
VALUE arg = Qnil;
|
||||||
VALUE hash = Qnil, key = Qnil;
|
VALUE hash = Qnil, key = Qnil;
|
||||||
|
|
||||||
|
@ -644,7 +635,6 @@ vm_stat(int argc, VALUE *argv, VALUE self)
|
||||||
#define S(s) sym_##s = ID2SYM(rb_intern_const(#s))
|
#define S(s) sym_##s = ID2SYM(rb_intern_const(#s))
|
||||||
S(constant_cache_invalidations);
|
S(constant_cache_invalidations);
|
||||||
S(constant_cache_misses);
|
S(constant_cache_misses);
|
||||||
S(class_serial);
|
|
||||||
S(global_cvar_state);
|
S(global_cvar_state);
|
||||||
#undef S
|
#undef S
|
||||||
|
|
||||||
|
@ -656,7 +646,6 @@ vm_stat(int argc, VALUE *argv, VALUE self)
|
||||||
|
|
||||||
SET(constant_cache_invalidations, ruby_vm_constant_cache_invalidations);
|
SET(constant_cache_invalidations, ruby_vm_constant_cache_invalidations);
|
||||||
SET(constant_cache_misses, ruby_vm_constant_cache_misses);
|
SET(constant_cache_misses, ruby_vm_constant_cache_misses);
|
||||||
SET(class_serial, ruby_vm_class_serial);
|
|
||||||
SET(global_cvar_state, ruby_vm_global_cvar_state);
|
SET(global_cvar_state, ruby_vm_global_cvar_state);
|
||||||
#undef SET
|
#undef SET
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,6 @@ MJIT_SYMBOL_EXPORT_BEGIN
|
||||||
RUBY_EXTERN VALUE ruby_vm_const_missing_count;
|
RUBY_EXTERN VALUE ruby_vm_const_missing_count;
|
||||||
RUBY_EXTERN rb_serial_t ruby_vm_constant_cache_invalidations;
|
RUBY_EXTERN rb_serial_t ruby_vm_constant_cache_invalidations;
|
||||||
RUBY_EXTERN rb_serial_t ruby_vm_constant_cache_misses;
|
RUBY_EXTERN rb_serial_t ruby_vm_constant_cache_misses;
|
||||||
RUBY_EXTERN rb_serial_t ruby_vm_class_serial;
|
|
||||||
RUBY_EXTERN rb_serial_t ruby_vm_global_cvar_state;
|
RUBY_EXTERN rb_serial_t ruby_vm_global_cvar_state;
|
||||||
|
|
||||||
MJIT_SYMBOL_EXPORT_END
|
MJIT_SYMBOL_EXPORT_END
|
||||||
|
@ -182,8 +181,6 @@ CC_SET_FASTPATH(const struct rb_callcache *cc, vm_call_handler func, bool enable
|
||||||
} while (0)
|
} while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define PREV_CLASS_SERIAL() (ruby_vm_class_serial)
|
|
||||||
#define NEXT_CLASS_SERIAL() (++ruby_vm_class_serial)
|
|
||||||
#define GET_GLOBAL_CVAR_STATE() (ruby_vm_global_cvar_state)
|
#define GET_GLOBAL_CVAR_STATE() (ruby_vm_global_cvar_state)
|
||||||
#define INC_GLOBAL_CVAR_STATE() (++ruby_vm_global_cvar_state)
|
#define INC_GLOBAL_CVAR_STATE() (++ruby_vm_global_cvar_state)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue