diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2020-11-10 11:50:59 +0900 |
|---|---|---|
| committer | GitHub <[email protected]> | 2020-11-10 11:50:59 +0900 |
| commit | 352c4755b204d1b4b17d5c668fb11edb7d9a6b15 (patch) | |
| tree | 4a74dcbafa15a9a244f10058f2fb97fbe01beb4c /include | |
| parent | 0df460892cc3035782226768e41299156ec9a37d (diff) | |
| parent | 926ec1dc7e6e887e96d4be56eccc55b487a2ec9b (diff) | |
| download | mruby-352c4755b204d1b4b17d5c668fb11edb7d9a6b15.tar.gz mruby-352c4755b204d1b4b17d5c668fb11edb7d9a6b15.zip | |
Merge pull request #5118 from dearblue/mrb_value
Define `mrb_value` in struct for Word/NaN boxing
Diffstat (limited to 'include')
| -rw-r--r-- | include/mruby/boxing_nan.h | 15 | ||||
| -rw-r--r-- | include/mruby/boxing_word.h | 40 |
2 files changed, 33 insertions, 22 deletions
diff --git a/include/mruby/boxing_nan.h b/include/mruby/boxing_nan.h index e68982977..96ca46ef3 100644 --- a/include/mruby/boxing_nan.h +++ b/include/mruby/boxing_nan.h @@ -30,7 +30,9 @@ * In order to get enough bit size to save TT, all pointers are shifted 2 bits * in the right direction. Also, TTTTTT is the mrb_vtype + 1; */ -typedef uint64_t mrb_value; +typedef struct mrb_value { + uint64_t u; +} mrb_value; union mrb_value_ { mrb_float f; @@ -48,13 +50,16 @@ union mrb_value_ { #endif ) }; + mrb_value value; }; +mrb_static_assert1(sizeof(mrb_value) == sizeof(union mrb_value_)); + static inline union mrb_value_ mrb_val_union(mrb_value v) { union mrb_value_ x; - x.u = v; + x.value = v; return x; } @@ -79,7 +84,7 @@ mrb_val_union(mrb_value v) union mrb_value_ mrb_value_union_variable; \ mrb_value_union_variable.attr = (v);\ mrb_value_union_variable.ttt = 0xfff00000 | (((tt)+1)<<14);\ - o = mrb_value_union_variable.u;\ + o = mrb_value_union_variable.value;\ } while (0) #ifdef MRB_64BIT @@ -87,7 +92,7 @@ mrb_val_union(mrb_value v) union mrb_value_ mrb_value_union_variable;\ mrb_value_union_variable.p = (void*)((uintptr_t)(v)>>2);\ mrb_value_union_variable.ttt = (0xfff00000|(((tt)+1)<<14)|BOXNAN_SHIFT_LONG_POINTER(v));\ - o = mrb_value_union_variable.u;\ + o = mrb_value_union_variable.value;\ } while (0) #else #define BOXNAN_SET_OBJ_VALUE(o, tt, v) BOXNAN_SET_VALUE(o, tt, i, (uint32_t)v) @@ -102,7 +107,7 @@ mrb_val_union(mrb_value v) else { \ mrb_value_union_variable.f = (v); \ } \ - r = mrb_value_union_variable.u; \ + r = mrb_value_union_variable.value; \ } while(0) #define SET_NIL_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, i, 0) diff --git a/include/mruby/boxing_word.h b/include/mruby/boxing_word.h index d7b5ff990..120c4f476 100644 --- a/include/mruby/boxing_word.h +++ b/include/mruby/boxing_word.h @@ -52,11 +52,11 @@ enum mrb_special_consts { #define BOXWORD_IMMEDIATE_MASK 0x07 #define BOXWORD_SHIFT_VALUE(o,n,t) \ - (t)(((intptr_t)(o)) >> BOXWORD_##n##_SHIFT) + (t)(((intptr_t)(o).w) >> BOXWORD_##n##_SHIFT) #define BOXWORD_SET_SHIFT_VALUE(o,n,v) \ - ((o) = (((uintptr_t)(v)) << BOXWORD_##n##_SHIFT) | BOXWORD_##n##_FLAG) + ((o).w = (((uintptr_t)(v)) << BOXWORD_##n##_SHIFT) | BOXWORD_##n##_FLAG) #define BOXWORD_SHIFT_VALUE_P(o,n) \ - (((o) & BOXWORD_##n##_MASK) == BOXWORD_##n##_FLAG) + (((o).w & BOXWORD_##n##_MASK) == BOXWORD_##n##_FLAG) #define BOXWORD_OBJ_TYPE_P(o,n) \ (!mrb_immediate_p(o) && mrb_val_union(o).bp->tt == MRB_TT_##n) @@ -71,7 +71,10 @@ enum mrb_special_consts { * symbol: ...SSSS SS10 (use only upper 32-bit as symbol value on 64-bit CPU) * object: ...PPPP P000 (any bits are 1) */ -typedef uintptr_t mrb_value; +typedef struct mrb_value { + uintptr_t w; +} mrb_value; + union mrb_value_ { void *p; #ifdef MRB_64BIT @@ -90,13 +93,16 @@ union mrb_value_ { struct RInteger *ip; struct RCptr *vp; uintptr_t w; + mrb_value value; }; +mrb_static_assert1(sizeof(mrb_value) == sizeof(union mrb_value_)); + static inline union mrb_value_ mrb_val_union(mrb_value v) { union mrb_value_ x; - x.w = v; + x.value = v; return x; } @@ -106,7 +112,7 @@ MRB_API mrb_value mrb_word_boxing_float_value(struct mrb_state*, mrb_float); #endif MRB_API mrb_value mrb_word_boxing_int_value(struct mrb_state*, mrb_int); -#define mrb_immediate_p(o) ((o) & BOXWORD_IMMEDIATE_MASK || (o) == MRB_Qnil) +#define mrb_immediate_p(o) ((o).w & BOXWORD_IMMEDIATE_MASK || (o).w == MRB_Qnil) #define mrb_ptr(o) mrb_val_union(o).p #define mrb_cptr(o) mrb_val_union(o).vp->p @@ -125,7 +131,7 @@ mrb_integer_func(mrb_value o) { #else #define mrb_symbol(o) BOXWORD_SHIFT_VALUE(o, SYMBOL, mrb_sym) #endif -#define mrb_bool(o) (((o) & ~(unsigned long)MRB_Qfalse) != 0) +#define mrb_bool(o) (((o).w & ~(unsigned long)MRB_Qfalse) != 0) #define mrb_fixnum_p(o) BOXWORD_SHIFT_VALUE_P(o, FIXNUM) #define mrb_integer_p(o) (BOXWORD_SHIFT_VALUE_P(o, FIXNUM)||BOXWORD_OBJ_TYPE_P(o, INTEGER)) @@ -134,10 +140,10 @@ mrb_integer_func(mrb_value o) { #else #define mrb_symbol_p(o) BOXWORD_SHIFT_VALUE_P(o, SYMBOL) #endif -#define mrb_undef_p(o) ((o) == MRB_Qundef) -#define mrb_nil_p(o) ((o) == MRB_Qnil) -#define mrb_false_p(o) ((o) == MRB_Qfalse) -#define mrb_true_p(o) ((o) == MRB_Qtrue) +#define mrb_undef_p(o) ((o).w == MRB_Qundef) +#define mrb_nil_p(o) ((o).w == MRB_Qnil) +#define mrb_false_p(o) ((o).w == MRB_Qfalse) +#define mrb_true_p(o) ((o).w == MRB_Qtrue) #ifndef MRB_NO_FLOAT #define mrb_float_p(o) BOXWORD_OBJ_TYPE_P(o, FLOAT) #endif @@ -164,10 +170,10 @@ mrb_integer_func(mrb_value o) { #define SET_FLOAT_VALUE(mrb,r,v) ((r) = mrb_word_boxing_float_value(mrb, v)) #endif #define SET_CPTR_VALUE(mrb,r,v) ((r) = mrb_word_boxing_cptr_value(mrb, v)) -#define SET_UNDEF_VALUE(r) ((r) = MRB_Qundef) -#define SET_NIL_VALUE(r) ((r) = MRB_Qnil) -#define SET_FALSE_VALUE(r) ((r) = MRB_Qfalse) -#define SET_TRUE_VALUE(r) ((r) = MRB_Qtrue) +#define SET_UNDEF_VALUE(r) ((r).w = MRB_Qundef) +#define SET_NIL_VALUE(r) ((r).w = MRB_Qnil) +#define SET_FALSE_VALUE(r) ((r).w = MRB_Qfalse) +#define SET_TRUE_VALUE(r) ((r).w = MRB_Qtrue) #define SET_BOOL_VALUE(r,b) ((b) ? SET_TRUE_VALUE(r) : SET_FALSE_VALUE(r)) #define SET_INT_VALUE(mrb,r,n) ((r) = mrb_word_boxing_int_value(mrb, n)) #define SET_FIXNUM_VALUE(r,n) BOXWORD_SET_SHIFT_VALUE(r, FIXNUM, n) @@ -176,12 +182,12 @@ mrb_integer_func(mrb_value o) { union mrb_value_ mrb_value_union_variable;\ mrb_value_union_variable.sym = v;\ mrb_value_union_variable.sym_flag = BOXWORD_SYMBOL_FLAG;\ - (r) = mrb_value_union_variable.w;\ + (r) = mrb_value_union_variable.value;\ } while (0) #else #define SET_SYM_VALUE(r,n) BOXWORD_SET_SHIFT_VALUE(r, SYMBOL, n) #endif -#define SET_OBJ_VALUE(r,v) ((r) = (uintptr_t)v) +#define SET_OBJ_VALUE(r,v) ((r).w = (uintptr_t)(v)) MRB_INLINE enum mrb_vtype mrb_type(mrb_value o) |
