diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2020-08-03 16:47:07 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2020-10-12 16:21:25 +0900 |
| commit | 5e9dc72bc5a5f65e2bd4fde4b7e040be58962b4b (patch) | |
| tree | 74ca9f4bccfbd831c879d4170fd81863839ba6ef /include | |
| parent | 1eacdae319244ac33dfb86e006ccbd68d8f81767 (diff) | |
| download | mruby-5e9dc72bc5a5f65e2bd4fde4b7e040be58962b4b.tar.gz mruby-5e9dc72bc5a5f65e2bd4fde4b7e040be58962b4b.zip | |
Pack `mrb_value` into `uint64_t` when `MRB_NAN_BOXING`.
Diffstat (limited to 'include')
| -rw-r--r-- | include/mruby/boxing_nan.h | 58 |
1 files changed, 36 insertions, 22 deletions
diff --git a/include/mruby/boxing_nan.h b/include/mruby/boxing_nan.h index 4b44bba8a..85cba4554 100644 --- a/include/mruby/boxing_nan.h +++ b/include/mruby/boxing_nan.h @@ -30,9 +30,12 @@ * 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 struct mrb_value { +typedef uint64_t mrb_value; + +struct mrb_value { union { mrb_float f; + uint64_t u; union { void *p; struct { @@ -44,47 +47,58 @@ typedef struct mrb_value { }; ) }; -#ifdef MRB_64BIT - struct RCptr *vp; -#endif } value; }; -} mrb_value; +}; -#define mrb_tt(o) ((enum mrb_vtype)(((o).value.ttt & 0xfc000)>>14)-1) -#define mrb_type(o) (enum mrb_vtype)((uint32_t)0xfff00000 < (o).value.ttt ? mrb_tt(o) : MRB_TT_FLOAT) -#define mrb_ptr(o) ((void*)((((uintptr_t)0x3fffffffffff)&((uintptr_t)((o).value.p)))<<2)) -#define mrb_float(o) (o).f -#define mrb_fixnum(o) (o).value.i -#define mrb_symbol(o) (o).value.sym +static inline struct mrb_value +mrb_val_stru(mrb_value v) +{ + struct mrb_value mrb_value_struct_variable = {.u = v}; + return mrb_value_struct_variable; +} + +#define mrb_tt(o) ((enum mrb_vtype)((mrb_val_stru(o).value.ttt & 0xfc000)>>14)-1) +#define mrb_type(o) (enum mrb_vtype)((uint32_t)0xfff00000 < mrb_val_stru(o).value.ttt ? mrb_tt(o) : MRB_TT_FLOAT) +#define mrb_ptr(o) ((void*)((((uintptr_t)0x3fffffffffff)&((uintptr_t)(mrb_val_stru(o).value.p)))<<2)) +#define mrb_float(o) mrb_val_stru(o).f +#define mrb_fixnum(o) mrb_val_stru(o).value.i +#define mrb_symbol(o) mrb_val_stru(o).value.sym #ifdef MRB_64BIT MRB_API mrb_value mrb_nan_boxing_cptr_value(struct mrb_state*, void*); #define mrb_cptr(o) (((struct RCptr*)mrb_ptr(o))->p) #define BOXNAN_SHIFT_LONG_POINTER(v) (((uintptr_t)(v)>>34)&0x3fff) #else -#define mrb_cptr(o) ((o).value.p) +#define mrb_cptr(o) (mrb_val_stru(o).value.p) #define BOXNAN_SHIFT_LONG_POINTER(v) 0 #endif -#define BOXNAN_SET_VALUE(o, tt, attr, v) do {\ - (o).attr = (v);\ - (o).value.ttt = 0xfff00000 | (((tt)+1)<<14);\ +#define BOXNAN_SET_VALUE(o, tt, attr, v) do { \ + struct mrb_value mrb_value_struct_variable; \ + mrb_value_struct_variable.attr = (v);\ + mrb_value_struct_variable.value.ttt = 0xfff00000 | (((tt)+1)<<14);\ + o = mrb_value_struct_variable.u;\ } while (0) #define BOXNAN_SET_OBJ_VALUE(o, tt, v) do {\ - (o).value.p = (void*)((uintptr_t)(v)>>2);\ - (o).value.ttt = (0xfff00000|(((tt)+1)<<14)|BOXNAN_SHIFT_LONG_POINTER(v));\ + struct mrb_value mrb_value_struct_variable;\ + mrb_value_struct_variable.value.p = (void*)((uintptr_t)(v)>>2);\ + mrb_value_struct_variable.value.ttt = (0xfff00000|(((tt)+1)<<14)|BOXNAN_SHIFT_LONG_POINTER(v));\ + o = mrb_value_struct_variable.u;\ } while (0) #define SET_FLOAT_VALUE(mrb,r,v) do { \ - if ((v) != (v)) { \ - (r).value.ttt = 0x7ff80000; \ - (r).value.i = 0; \ + struct mrb_value mrb_value_struct_variable; \ + if ((v) != (v)) { /* NaN */ \ + mrb_value_struct_variable.value.ttt = 0x7ff80000; \ + mrb_value_struct_variable.value.i = 0; \ } \ else { \ - (r).f = v; \ - }} while(0) + mrb_value_struct_variable.f = (v); \ + } \ + r = mrb_value_struct_variable.u; \ +} while(0) #define SET_NIL_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, value.i, 0) #define SET_FALSE_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, value.i, 1) |
