Commit 41e32205 authored by Rory OConnell's avatar Rory OConnell

All values use page slot size in calculation

parent 37d66286
...@@ -21,6 +21,7 @@ struct mrb_state; ...@@ -21,6 +21,7 @@ struct mrb_state;
#define MRB_EACH_OBJ_BREAK 1 #define MRB_EACH_OBJ_BREAK 1
typedef int (mrb_each_object_callback)(struct mrb_state *mrb, struct RBasic *obj, void *data); typedef int (mrb_each_object_callback)(struct mrb_state *mrb, struct RBasic *obj, void *data);
void mrb_objspace_each_objects(struct mrb_state *mrb, mrb_each_object_callback *callback, void *data); void mrb_objspace_each_objects(struct mrb_state *mrb, mrb_each_object_callback *callback, void *data);
const mrb_int mrb_objspace_page_slot_size();
MRB_API void mrb_free_context(struct mrb_state *mrb, struct mrb_context *c); MRB_API void mrb_free_context(struct mrb_state *mrb, struct mrb_context *c);
#ifndef MRB_GC_ARENA_SIZE #ifndef MRB_GC_ARENA_SIZE
......
...@@ -251,6 +251,7 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t ...@@ -251,6 +251,7 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t
case MRB_TT_SCLASS: case MRB_TT_SCLASS:
case MRB_TT_ICLASS: case MRB_TT_ICLASS:
case MRB_TT_OBJECT: { case MRB_TT_OBJECT: {
(*t) += mrb_objspace_page_slot_size();
os_memsize_of_ivars(mrb, obj, recurse, t); os_memsize_of_ivars(mrb, obj, recurse, t);
if(mrb_obj_is_kind_of(mrb, obj, mrb_class_get(mrb, "UnboundMethod"))) { if(mrb_obj_is_kind_of(mrb, obj, mrb_class_get(mrb, "UnboundMethod"))) {
os_memsize_of_method(mrb, obj, t); os_memsize_of_method(mrb, obj, t);
...@@ -270,6 +271,7 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t ...@@ -270,6 +271,7 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t
len = RARRAY_LEN(obj); len = RARRAY_LEN(obj);
/* Arrays that do not fit within an RArray perform a heap allocation /* Arrays that do not fit within an RArray perform a heap allocation
* storing an array of pointers to the original objects*/ * storing an array of pointers to the original objects*/
(*t) += mrb_objspace_page_slot_size();
if(len > MRB_ARY_EMBED_LEN_MAX) (*t) += sizeof(mrb_value *) * len; if(len > MRB_ARY_EMBED_LEN_MAX) (*t) += sizeof(mrb_value *) * len;
if(recurse) { if(recurse) {
...@@ -280,12 +282,14 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t ...@@ -280,12 +282,14 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t
break; break;
} }
case MRB_TT_PROC: { case MRB_TT_PROC: {
(*t) += mrb_objspace_page_slot_size();
struct RProc* proc = mrb_proc_ptr(obj); struct RProc* proc = mrb_proc_ptr(obj);
(*t) += MRB_ENV_LEN(proc->e.env) * sizeof(mrb_value); (*t) += MRB_ENV_LEN(proc->e.env) * sizeof(mrb_value);
if(!MRB_PROC_CFUNC_P(proc)) os_memsize_of_irep(mrb, proc->body.irep, t); if(!MRB_PROC_CFUNC_P(proc)) os_memsize_of_irep(mrb, proc->body.irep, t);
break; break;
} }
case MRB_TT_DATA: case MRB_TT_DATA:
(*t) += mrb_objspace_page_slot_size();
if(mrb_respond_to(mrb, obj, mrb_intern_lit(mrb, "memsize"))) { if(mrb_respond_to(mrb, obj, mrb_intern_lit(mrb, "memsize"))) {
(*t) += mrb_fixnum(mrb_funcall(mrb, obj, "memsize", 0)); (*t) += mrb_fixnum(mrb_funcall(mrb, obj, "memsize", 0));
} }
...@@ -293,23 +297,25 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t ...@@ -293,23 +297,25 @@ os_memsize_of_object(mrb_state* mrb, mrb_value obj, mrb_bool recurse, mrb_int* t
#ifndef MRB_WITHOUT_FLOAT #ifndef MRB_WITHOUT_FLOAT
case MRB_TT_FLOAT: case MRB_TT_FLOAT:
#ifdef MRB_WORD_BOXING #ifdef MRB_WORD_BOXING
(*t) += sizeof(struct RFloat); (*t) += mrb_objspace_page_slot_size() +
sizeof(struct RFloat);
#endif #endif
break; break;
#endif #endif
case MRB_TT_RANGE: case MRB_TT_RANGE:
#ifndef MRB_RANGE_EMBED #ifndef MRB_RANGE_EMBED
(*t) += sizeof(struct mrb_range_edges); (*t) += mrb_objspace_page_slot_size() +
sizeof(struct mrb_range_edges);
#endif #endif
break; break;
case MRB_TT_FIBER: { case MRB_TT_FIBER: {
/* struct RFiber* fiber = (struct RFiber*)mrb_ptr(obj); */ /* struct RFiber* fiber = (struct RFiber*)mrb_ptr(obj); */
(*t) += sizeof(struct mrb_context); (*t) += sizeof(struct mrb_context);
case MRB_TT_ISTRUCT:
(*t) += mrb_objspace_page_slot_size();
break; break;
}
/* zero heap size types. /* zero heap size types.
* immediate VM stack values, contained within mrb_state, mrb_heap_page, * immediate VM stack values, contained within mrb_state, or on C stack */
* or on C stack */
case MRB_TT_TRUE: case MRB_TT_TRUE:
case MRB_TT_FALSE: case MRB_TT_FALSE:
case MRB_TT_FIXNUM: case MRB_TT_FIXNUM:
......
...@@ -1599,6 +1599,13 @@ mrb_objspace_each_objects(mrb_state *mrb, mrb_each_object_callback *callback, vo ...@@ -1599,6 +1599,13 @@ mrb_objspace_each_objects(mrb_state *mrb, mrb_each_object_callback *callback, vo
} }
} }
const mrb_int
mrb_objspace_page_slot_size()
{
const mrb_int i = sizeof(RVALUE);
return i;
}
#ifdef GC_TEST #ifdef GC_TEST
#ifdef GC_DEBUG #ifdef GC_DEBUG
static mrb_value gc_test(mrb_state *, mrb_value); static mrb_value gc_test(mrb_state *, mrb_value);
......
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