Skip to content

Commit d0501c6

Browse files
committed
Fix MRB_TT_CPTR object with MRB_NAN_BOXING
Previously, if `MRB_NAN_BOXING` is defined, for example, `mrb_cptr_value()` could not keep an odd address. If it is `MRB_32BIT`, it can be embedded in `NaN` as it is. If it is `MRB_64BIT`, some operations are shared with `MRB_WORD_BOXING`. In this case, the MRB_API function `mrb_nan_boxing_cptr_value()` is defined.
1 parent 63c7ff3 commit d0501c6

4 files changed

Lines changed: 31 additions & 11 deletions

File tree

include/mruby/boxing_nan.h

Lines changed: 11 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -44,6 +44,9 @@ typedef struct mrb_value {
4444
};
4545
)
4646
};
47+
#ifdef MRB_64BIT
48+
struct RCptr *vp;
49+
#endif
4750
} value;
4851
};
4952
} mrb_value;
@@ -54,13 +57,15 @@ typedef struct mrb_value {
5457
#define mrb_type(o) (enum mrb_vtype)((uint32_t)0xfff00000 < (o).value.ttt ? mrb_tt(o) : MRB_TT_FLOAT)
5558
#define mrb_ptr(o) ((void*)((((uintptr_t)0x3fffffffffff)&((uintptr_t)((o).value.p)))<<2))
5659
#define mrb_float(o) (o).f
57-
#define mrb_cptr(o) mrb_ptr(o)
5860
#define mrb_fixnum(o) (o).value.i
5961
#define mrb_symbol(o) (o).value.sym
6062

6163
#ifdef MRB_64BIT
64+
MRB_API mrb_value mrb_nan_boxing_cptr_value(struct mrb_state*, void*);
65+
#define mrb_cptr(o) (((struct RCptr*)mrb_ptr(o))->p)
6266
#define BOXNAN_SHIFT_LONG_POINTER(v) (((uintptr_t)(v)>>34)&0x3fff)
6367
#else
68+
#define mrb_cptr(o) ((o).value.p)
6469
#define BOXNAN_SHIFT_LONG_POINTER(v) 0
6570
#endif
6671

@@ -90,7 +95,11 @@ typedef struct mrb_value {
9095
#define SET_INT_VALUE(r,n) BOXNAN_SET_VALUE(r, MRB_TT_FIXNUM, value.i, (n))
9196
#define SET_SYM_VALUE(r,v) BOXNAN_SET_VALUE(r, MRB_TT_SYMBOL, value.sym, (v))
9297
#define SET_OBJ_VALUE(r,v) BOXNAN_SET_OBJ_VALUE(r, (((struct RObject*)(v))->tt), (v))
93-
#define SET_CPTR_VALUE(mrb,r,v) BOXNAN_SET_OBJ_VALUE(r, MRB_TT_CPTR, v)
98+
#ifdef MRB_64BIT
99+
#define SET_CPTR_VALUE(mrb,r,v) ((r) = mrb_nan_boxing_cptr_value(mrb, v))
100+
#else
101+
#define SET_CPTR_VALUE(mrb,r,v) BOXNAN_SET_VALUE(r, MRB_TT_CPTR, value.p, v)
102+
#endif
94103
#define SET_UNDEF_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_UNDEF, value.i, 0)
95104

96105
#endif /* MRUBY_BOXING_NAN_H */

include/mruby/boxing_word.h

Lines changed: 0 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -18,11 +18,6 @@ struct RFloat {
1818
};
1919
#endif
2020

21-
struct RCptr {
22-
MRB_OBJECT_HEADER;
23-
void *p;
24-
};
25-
2621
enum mrb_special_consts {
2722
MRB_Qnil = 0,
2823
MRB_Qfalse = 4,

include/mruby/value.h

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -149,6 +149,13 @@ typedef void mrb_value;
149149

150150
#endif
151151

152+
#if defined(MRB_WORD_BOXING) || (defined(MRB_NAN_BOXING) && defined(MRB_64BIT))
153+
struct RCptr {
154+
MRB_OBJECT_HEADER;
155+
void *p;
156+
};
157+
#endif
158+
152159
#if defined(MRB_NAN_BOXING)
153160
#include "boxing_nan.h"
154161
#elif defined(MRB_WORD_BOXING)

src/etc.c

Lines changed: 13 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -140,7 +140,13 @@ mrb_obj_id(mrb_value obj)
140140
}
141141
}
142142

143+
#if defined(MRB_NAN_BOXING) && defined(MRB_64BIT)
144+
#define mrb_xxx_boxing_cptr_value mrb_nan_boxing_cptr_value
145+
#endif
146+
143147
#ifdef MRB_WORD_BOXING
148+
#define mrb_xxx_boxing_cptr_value mrb_word_boxing_cptr_value
149+
144150
#ifndef MRB_WITHOUT_FLOAT
145151
MRB_API mrb_value
146152
mrb_word_boxing_float_value(mrb_state *mrb, mrb_float f)
@@ -164,17 +170,20 @@ mrb_word_boxing_float_pool(mrb_state *mrb, mrb_float f)
164170
return mrb_obj_value(nf);
165171
}
166172
#endif /* MRB_WITHOUT_FLOAT */
173+
#endif /* MRB_WORD_BOXING */
167174

175+
#if defined(MRB_WORD_BOXING) || (defined(MRB_NAN_BOXING) && defined(MRB_64BIT))
168176
MRB_API mrb_value
169-
mrb_word_boxing_cptr_value(mrb_state *mrb, void *p)
177+
mrb_xxx_boxing_cptr_value(mrb_state *mrb, void *p)
170178
{
171179
mrb_value v;
180+
struct RCptr *cptr = (struct RCptr*)mrb_obj_alloc(mrb, MRB_TT_CPTR, mrb->object_class);
172181

173-
v.value.p = mrb_obj_alloc(mrb, MRB_TT_CPTR, mrb->object_class);
174-
v.value.vp->p = p;
182+
SET_OBJ_VALUE(v, cptr);
183+
cptr->p = p;
175184
return v;
176185
}
177-
#endif /* MRB_WORD_BOXING */
186+
#endif
178187

179188
#if defined _MSC_VER && _MSC_VER < 1900
180189

0 commit comments

Comments
 (0)