summaryrefslogtreecommitdiffhomepage
path: root/include
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2020-11-10 11:50:59 +0900
committerGitHub <[email protected]>2020-11-10 11:50:59 +0900
commit352c4755b204d1b4b17d5c668fb11edb7d9a6b15 (patch)
tree4a74dcbafa15a9a244f10058f2fb97fbe01beb4c /include
parent0df460892cc3035782226768e41299156ec9a37d (diff)
parent926ec1dc7e6e887e96d4be56eccc55b487a2ec9b (diff)
downloadmruby-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.h15
-rw-r--r--include/mruby/boxing_word.h40
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)