Commit 926ec1dc authored by dearblue's avatar dearblue

Define `mrb_value` in struct for Word/NaN boxing

This is to make it possible to distinguish between `mrb_value` and `mrb_sym` in C++ "Function overloading" and C11 "Generic selection".
parent e2829bef
...@@ -30,7 +30,9 @@ ...@@ -30,7 +30,9 @@
* In order to get enough bit size to save TT, all pointers are shifted 2 bits * 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; * 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_ { union mrb_value_ {
mrb_float f; mrb_float f;
...@@ -44,13 +46,16 @@ union mrb_value_ { ...@@ -44,13 +46,16 @@ union mrb_value_ {
,uint32_t i; ,uint32_t i;
) )
}; };
mrb_value value;
}; };
mrb_static_assert1(sizeof(mrb_value) == sizeof(union mrb_value_));
static inline union mrb_value_ static inline union mrb_value_
mrb_val_union(mrb_value v) mrb_val_union(mrb_value v)
{ {
union mrb_value_ x; union mrb_value_ x;
x.u = v; x.value = v;
return x; return x;
} }
...@@ -75,7 +80,7 @@ mrb_val_union(mrb_value v) ...@@ -75,7 +80,7 @@ mrb_val_union(mrb_value v)
union mrb_value_ mrb_value_union_variable; \ union mrb_value_ mrb_value_union_variable; \
mrb_value_union_variable.attr = (v);\ mrb_value_union_variable.attr = (v);\
mrb_value_union_variable.ttt = 0xfff00000 | (((tt)+1)<<14);\ mrb_value_union_variable.ttt = 0xfff00000 | (((tt)+1)<<14);\
o = mrb_value_union_variable.u;\ o = mrb_value_union_variable.value;\
} while (0) } while (0)
#ifdef MRB_64BIT #ifdef MRB_64BIT
...@@ -83,7 +88,7 @@ mrb_val_union(mrb_value v) ...@@ -83,7 +88,7 @@ mrb_val_union(mrb_value v)
union mrb_value_ mrb_value_union_variable;\ union mrb_value_ mrb_value_union_variable;\
mrb_value_union_variable.p = (void*)((uintptr_t)(v)>>2);\ mrb_value_union_variable.p = (void*)((uintptr_t)(v)>>2);\
mrb_value_union_variable.ttt = (0xfff00000|(((tt)+1)<<14)|BOXNAN_SHIFT_LONG_POINTER(v));\ 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) } while (0)
#else #else
#define BOXNAN_SET_OBJ_VALUE(o, tt, v) BOXNAN_SET_VALUE(o, tt, i, (uint32_t)v) #define BOXNAN_SET_OBJ_VALUE(o, tt, v) BOXNAN_SET_VALUE(o, tt, i, (uint32_t)v)
...@@ -98,7 +103,7 @@ mrb_val_union(mrb_value v) ...@@ -98,7 +103,7 @@ mrb_val_union(mrb_value v)
else { \ else { \
mrb_value_union_variable.f = (v); \ mrb_value_union_variable.f = (v); \
} \ } \
r = mrb_value_union_variable.u; \ r = mrb_value_union_variable.value; \
} while(0) } while(0)
#define SET_NIL_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, i, 0) #define SET_NIL_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, i, 0)
......
...@@ -52,11 +52,11 @@ enum mrb_special_consts { ...@@ -52,11 +52,11 @@ enum mrb_special_consts {
#define BOXWORD_IMMEDIATE_MASK 0x07 #define BOXWORD_IMMEDIATE_MASK 0x07
#define BOXWORD_SHIFT_VALUE(o,n,t) \ #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) \ #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) \ #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) \ #define BOXWORD_OBJ_TYPE_P(o,n) \
(!mrb_immediate_p(o) && mrb_val_union(o).bp->tt == MRB_TT_##n) (!mrb_immediate_p(o) && mrb_val_union(o).bp->tt == MRB_TT_##n)
...@@ -71,7 +71,10 @@ enum mrb_special_consts { ...@@ -71,7 +71,10 @@ enum mrb_special_consts {
* symbol: ...SSSS SS10 (use only upper 32-bit as symbol value on 64-bit CPU) * symbol: ...SSSS SS10 (use only upper 32-bit as symbol value on 64-bit CPU)
* object: ...PPPP P000 (any bits are 1) * object: ...PPPP P000 (any bits are 1)
*/ */
typedef uintptr_t mrb_value; typedef struct mrb_value {
uintptr_t w;
} mrb_value;
union mrb_value_ { union mrb_value_ {
void *p; void *p;
#ifdef MRB_64BIT #ifdef MRB_64BIT
...@@ -90,13 +93,16 @@ union mrb_value_ { ...@@ -90,13 +93,16 @@ union mrb_value_ {
struct RInteger *ip; struct RInteger *ip;
struct RCptr *vp; struct RCptr *vp;
uintptr_t w; uintptr_t w;
mrb_value value;
}; };
mrb_static_assert1(sizeof(mrb_value) == sizeof(union mrb_value_));
static inline union mrb_value_ static inline union mrb_value_
mrb_val_union(mrb_value v) mrb_val_union(mrb_value v)
{ {
union mrb_value_ x; union mrb_value_ x;
x.w = v; x.value = v;
return x; return x;
} }
...@@ -106,7 +112,7 @@ MRB_API mrb_value mrb_word_boxing_float_value(struct mrb_state*, mrb_float); ...@@ -106,7 +112,7 @@ MRB_API mrb_value mrb_word_boxing_float_value(struct mrb_state*, mrb_float);
#endif #endif
MRB_API mrb_value mrb_word_boxing_int_value(struct mrb_state*, mrb_int); 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_ptr(o) mrb_val_union(o).p
#define mrb_cptr(o) mrb_val_union(o).vp->p #define mrb_cptr(o) mrb_val_union(o).vp->p
...@@ -125,7 +131,7 @@ mrb_integer_func(mrb_value o) { ...@@ -125,7 +131,7 @@ mrb_integer_func(mrb_value o) {
#else #else
#define mrb_symbol(o) BOXWORD_SHIFT_VALUE(o, SYMBOL, mrb_sym) #define mrb_symbol(o) BOXWORD_SHIFT_VALUE(o, SYMBOL, mrb_sym)
#endif #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_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)) #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) { ...@@ -134,10 +140,10 @@ mrb_integer_func(mrb_value o) {
#else #else
#define mrb_symbol_p(o) BOXWORD_SHIFT_VALUE_P(o, SYMBOL) #define mrb_symbol_p(o) BOXWORD_SHIFT_VALUE_P(o, SYMBOL)
#endif #endif
#define mrb_undef_p(o) ((o) == MRB_Qundef) #define mrb_undef_p(o) ((o).w == MRB_Qundef)
#define mrb_nil_p(o) ((o) == MRB_Qnil) #define mrb_nil_p(o) ((o).w == MRB_Qnil)
#define mrb_false_p(o) ((o) == MRB_Qfalse) #define mrb_false_p(o) ((o).w == MRB_Qfalse)
#define mrb_true_p(o) ((o) == MRB_Qtrue) #define mrb_true_p(o) ((o).w == MRB_Qtrue)
#ifndef MRB_NO_FLOAT #ifndef MRB_NO_FLOAT
#define mrb_float_p(o) BOXWORD_OBJ_TYPE_P(o, FLOAT) #define mrb_float_p(o) BOXWORD_OBJ_TYPE_P(o, FLOAT)
#endif #endif
...@@ -164,10 +170,10 @@ mrb_integer_func(mrb_value o) { ...@@ -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)) #define SET_FLOAT_VALUE(mrb,r,v) ((r) = mrb_word_boxing_float_value(mrb, v))
#endif #endif
#define SET_CPTR_VALUE(mrb,r,v) ((r) = mrb_word_boxing_cptr_value(mrb, v)) #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_UNDEF_VALUE(r) ((r).w = MRB_Qundef)
#define SET_NIL_VALUE(r) ((r) = MRB_Qnil) #define SET_NIL_VALUE(r) ((r).w = MRB_Qnil)
#define SET_FALSE_VALUE(r) ((r) = MRB_Qfalse) #define SET_FALSE_VALUE(r) ((r).w = MRB_Qfalse)
#define SET_TRUE_VALUE(r) ((r) = MRB_Qtrue) #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_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_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) #define SET_FIXNUM_VALUE(r,n) BOXWORD_SET_SHIFT_VALUE(r, FIXNUM, n)
...@@ -176,12 +182,12 @@ mrb_integer_func(mrb_value o) { ...@@ -176,12 +182,12 @@ mrb_integer_func(mrb_value o) {
union mrb_value_ mrb_value_union_variable;\ union mrb_value_ mrb_value_union_variable;\
mrb_value_union_variable.sym = v;\ mrb_value_union_variable.sym = v;\
mrb_value_union_variable.sym_flag = BOXWORD_SYMBOL_FLAG;\ mrb_value_union_variable.sym_flag = BOXWORD_SYMBOL_FLAG;\
(r) = mrb_value_union_variable.w;\ (r) = mrb_value_union_variable.value;\
} while (0) } while (0)
#else #else
#define SET_SYM_VALUE(r,n) BOXWORD_SET_SHIFT_VALUE(r, SYMBOL, n) #define SET_SYM_VALUE(r,n) BOXWORD_SET_SHIFT_VALUE(r, SYMBOL, n)
#endif #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_INLINE enum mrb_vtype
mrb_type(mrb_value o) mrb_type(mrb_value o)
......
...@@ -161,7 +161,7 @@ mrb_word_boxing_float_value(mrb_state *mrb, mrb_float f) ...@@ -161,7 +161,7 @@ mrb_word_boxing_float_value(mrb_state *mrb, mrb_float f)
v.p = mrb_obj_alloc(mrb, MRB_TT_FLOAT, mrb->float_class); v.p = mrb_obj_alloc(mrb, MRB_TT_FLOAT, mrb->float_class);
v.fp->f = f; v.fp->f = f;
MRB_SET_FROZEN_FLAG(v.bp); MRB_SET_FROZEN_FLAG(v.bp);
return v.w; return v.value;
} }
#endif /* MRB_NO_FLOAT */ #endif /* MRB_NO_FLOAT */
...@@ -175,7 +175,7 @@ mrb_word_boxing_int_value(mrb_state *mrb, mrb_int n) ...@@ -175,7 +175,7 @@ mrb_word_boxing_int_value(mrb_state *mrb, mrb_int n)
v.p = mrb_obj_alloc(mrb, MRB_TT_INTEGER, mrb->integer_class); v.p = mrb_obj_alloc(mrb, MRB_TT_INTEGER, mrb->integer_class);
v.ip->i = n; v.ip->i = n;
MRB_SET_FROZEN_FLAG(v.ip); MRB_SET_FROZEN_FLAG(v.ip);
return v.w; return v.value;
} }
} }
#endif /* MRB_WORD_BOXING */ #endif /* MRB_WORD_BOXING */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment