started adding code for mark-sweep gc
This commit is contained in:
parent
7eb10b162a
commit
c29b256fec
@ -1629,7 +1629,7 @@ static moo_oop_process_t start_initial_process (moo_t* moo, moo_oop_context_t c)
|
||||
MOO_ASSERT (moo, moo->processor->active == moo->nil_process);
|
||||
|
||||
proc = make_process(moo, c, MOO_OBJ_FLAGS_PROC_INNATE);
|
||||
if (!proc) return MOO_NULL;
|
||||
if (MOO_UNLIKELY(!proc)) return MOO_NULL;
|
||||
|
||||
chain_into_processor (moo, proc, PROC_STATE_RUNNING);
|
||||
moo->processor->active = proc;
|
||||
@ -1666,7 +1666,7 @@ static MOO_INLINE int activate_new_method (moo_t* moo, moo_oop_method_t mth, moo
|
||||
moo_pushvolat (moo, (moo_oop_t*)&mth);
|
||||
ctx = (moo_oop_context_t)moo_instantiate(moo, moo->_method_context, MOO_NULL, actual_ntmprs);
|
||||
moo_popvolat (moo);
|
||||
if (!ctx) return -1;
|
||||
if (MOO_UNLIKELY(!ctx)) return -1;
|
||||
|
||||
MOO_STORE_OOP (moo, (moo_oop_t*)&ctx->sender, (moo_oop_t)moo->active_context);
|
||||
ctx->ip = MOO_SMOOI_TO_OOP(0);
|
||||
@ -1968,7 +1968,7 @@ static int start_initial_process_and_context (moo_t* moo, const moo_oocs_t* objn
|
||||
moo_oop_process_t proc;
|
||||
moo_oow_t tmp_count = 0;
|
||||
moo_oop_t sym_startup;
|
||||
|
||||
|
||||
#if defined(INVOKE_DIRECTLY)
|
||||
moo_oop_association_t ass;
|
||||
#else
|
||||
@ -1984,7 +1984,7 @@ static int start_initial_process_and_context (moo_t* moo, const moo_oocs_t* objn
|
||||
MOO_LOG2 (moo, MOO_LOG_DEBUG, "Cannot find a class '%.*js'", objname->len, objname->ptr);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
sym_statup = moo_findsymbol(moo, mthname->ptr, mthname->len;
|
||||
if (!sym_startup)
|
||||
{
|
||||
@ -2476,7 +2476,7 @@ static moo_pfrc_t pf_method_get_ip_source_line (moo_t* moo, moo_mod_t* mod, moo_
|
||||
if (ipv < di->code_loc_len && code_loc_ptr[ipv] <= MOO_SMOOI_MAX)
|
||||
{
|
||||
retv = moo_oowtoint(moo, code_loc_ptr[ipv]);
|
||||
if (!retv) return MOO_PF_FAILURE;
|
||||
if (MOO_UNLIKELY(!retv)) return MOO_PF_FAILURE;
|
||||
}
|
||||
}
|
||||
|
||||
@ -5258,16 +5258,17 @@ static MOO_INLINE int do_return (moo_t* moo, moo_oob_t bcode, moo_oop_t return_v
|
||||
{
|
||||
unwind_protect = 0;
|
||||
|
||||
/* set the instruction pointer to an invalid value.
|
||||
* this is stored into the current method context
|
||||
* before context switching and marks a dead context */
|
||||
|
||||
if (moo->active_context->origin == moo->active_context)
|
||||
{
|
||||
/* returning from a method */
|
||||
MOO_ASSERT (moo, MOO_CLASSOF(moo, moo->active_context) == moo->_method_context);
|
||||
|
||||
/* mark that the context is dead. it will be
|
||||
* save to the context object by SWITCH_ACTIVE_CONTEXT() */
|
||||
|
||||
/* set the instruction pointer to an invalid value.
|
||||
* this is stored into the current method context
|
||||
* before context switching by SWITCH_ACTIVE_CONTEXT()
|
||||
* and marks the context dead */
|
||||
moo->ip = -1;
|
||||
}
|
||||
else
|
||||
|
10
moo/lib/gc.c
10
moo/lib/gc.c
@ -514,7 +514,7 @@ static int ignite_2 (moo_t* moo)
|
||||
/* Create 'true' and 'false objects */
|
||||
moo->_true = moo_instantiate(moo, moo->_true_class, MOO_NULL, 0);
|
||||
moo->_false = moo_instantiate(moo, moo->_false_class, MOO_NULL, 0);
|
||||
if (!moo->_true || !moo->_false) return -1;
|
||||
if (MOO_UNLIKELY(!moo->_true) || MOO_UNLIKELY(!moo->_false)) return -1;
|
||||
|
||||
/* Prevent the object instations in the permspace.
|
||||
*
|
||||
@ -537,7 +537,7 @@ static int ignite_2 (moo_t* moo)
|
||||
|
||||
/* Create the symbol table */
|
||||
tmp = moo_instantiate(moo, moo->_symbol_table, MOO_NULL, 0);
|
||||
if (!tmp) return -1;
|
||||
if (MOO_UNLIKELY(!tmp)) return -1;
|
||||
moo->symtab = (moo_oop_dic_t)tmp;
|
||||
|
||||
moo->symtab->tally = MOO_SMOOI_TO_OOP(0);
|
||||
@ -937,6 +937,11 @@ static moo_rbt_walk_t call_module_gc (moo_rbt_t* rbt, moo_rbt_pair_t* pair, void
|
||||
|
||||
void moo_gc (moo_t* moo)
|
||||
{
|
||||
#if defined(MOO_ENABLE_GC_MARK_SWEEP)
|
||||
/* TODO: */
|
||||
|
||||
|
||||
#else
|
||||
/*
|
||||
* move a referenced object to the new heap.
|
||||
* inspect the fields of the moved object in the new heap.
|
||||
@ -1103,6 +1108,7 @@ void moo_gc (moo_t* moo)
|
||||
MOO_LOG4 (moo, MOO_LOG_GC | MOO_LOG_INFO,
|
||||
"Finished GC curheap base %p ptr %p newheap base %p ptr %p\n",
|
||||
moo->heap->curspace.base, moo->heap->curspace.ptr, moo->heap->newspace.base, moo->heap->newspace.ptr);
|
||||
#endif
|
||||
}
|
||||
|
||||
void moo_pushvolat (moo_t* moo, moo_oop_t* oop_ptr)
|
||||
|
@ -720,7 +720,6 @@ struct moo_compiler_t
|
||||
# error Unsupported MOO_BCODE_LONG_PARAM_SIZE
|
||||
#endif
|
||||
|
||||
|
||||
/*
|
||||
----------------------------------------------------------------------------------------------------------------
|
||||
SHORT INSTRUCTION CODE LONG INSTRUCTION CODE
|
||||
|
@ -34,6 +34,9 @@
|
||||
/* TODO: move this macro out to the build files.... */
|
||||
#define MOO_INCLUDE_COMPILER
|
||||
|
||||
/*#define MOO_ENABLE_GC_MARK_SWEEP*/
|
||||
|
||||
|
||||
typedef struct moo_mod_t moo_mod_t;
|
||||
|
||||
/* ========================================================================== */
|
||||
@ -198,6 +201,19 @@ enum moo_method_type_t
|
||||
};
|
||||
typedef enum moo_method_type_t moo_method_type_t;
|
||||
|
||||
|
||||
/* =========================================================================
|
||||
* HEADER FOR SOME GC IMPLEMENTATIONS
|
||||
* ========================================================================= */
|
||||
#if defined(MOO_ENABLE_GC_MARK_SWEEP)
|
||||
typedef struct moo_gchdr_t moo_gchdr_t;
|
||||
struct moo_gchdr_t
|
||||
{
|
||||
moo_gchdr_t* next;
|
||||
};
|
||||
/* The size of moo_gchdr_t must be aligned to MOO_SIZEOF_OOP_T */
|
||||
#endif
|
||||
|
||||
/* =========================================================================
|
||||
* OBJECT STRUCTURE
|
||||
* ========================================================================= */
|
||||
@ -1780,6 +1796,10 @@ struct moo_t
|
||||
moo_uintmax_t inst_counter;
|
||||
} stat;
|
||||
|
||||
#if defined(MOO_ENABLE_GC_MARK_SWEEP)
|
||||
moo_gchdr_t* gch;
|
||||
#endif
|
||||
|
||||
#if defined(MOO_INCLUDE_COMPILER)
|
||||
moo_compiler_t* c;
|
||||
#endif
|
||||
|
@ -29,11 +29,38 @@
|
||||
void* moo_allocbytes (moo_t* moo, moo_oow_t size)
|
||||
{
|
||||
moo_uint8_t* ptr;
|
||||
#if defined(MOO_ENABLE_GC_MARK_SWEEP)
|
||||
moo_gchdr_t* gch;
|
||||
#endif
|
||||
|
||||
#if defined(MOO_BUILD_DEBUG)
|
||||
if ((moo->option.trait & MOO_TRAIT_DEBUG_GC) && !(moo->option.trait & MOO_TRAIT_NOGC)) moo_gc (moo);
|
||||
#endif
|
||||
|
||||
#if defined(MOO_ENABLE_GC_MARK_SWEEP)
|
||||
if (MOO_UNLIKELY(moo->igniting))
|
||||
{
|
||||
gch = (moo_gchdr_t*)moo_allocmem(moo, MOO_SIZEOF(*gch) + size);
|
||||
if (MOO_UNLIKELY(!gch)) return MOO_NULL;
|
||||
}
|
||||
else
|
||||
{
|
||||
// TODO: perform GC if allocation got above threshold...
|
||||
gch = (moo_gchdr_t*)moo_allocmem(moo, MOO_SIZEOF(*gch) + size);
|
||||
if (!gch && moo->errnum == MOO_EOOMEM && !(moo->option.trait & MOO_TRAIT_NOGC))
|
||||
{
|
||||
moo_gc (moo);
|
||||
MOO_LOG0 (moo, MOO_LOG_GC | MOO_LOG_INFO, "GC completed\n"); /* TODO: add more inforamtion */
|
||||
gch = (moo_gchdr_t*)moo_allocmem(moo, MOO_SIZEOF(*gch) + size);
|
||||
if (MOO_UNLIKELY(!gch)) return MOO_NULL;
|
||||
}
|
||||
}
|
||||
|
||||
gch->next = moo->gch;
|
||||
moo->gch = gch;
|
||||
|
||||
ptr = (moo_uint8_t*)(gch + 1);
|
||||
#else
|
||||
if (MOO_UNLIKELY(moo->igniting))
|
||||
{
|
||||
/* you must increase the size of the permspace if this allocation fails */
|
||||
@ -55,6 +82,8 @@ void* moo_allocbytes (moo_t* moo, moo_oow_t size)
|
||||
/* TODO: grow heap if ptr is still null. */
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
return ptr;
|
||||
}
|
||||
|
||||
@ -74,7 +103,7 @@ moo_oop_t moo_allocoopobj (moo_t* moo, moo_oow_t size)
|
||||
* of the allocated space to be an even number.
|
||||
* see MOO_OOP_IS_NUMERIC() and MOO_OOP_IS_POINTER() */
|
||||
hdr = (moo_oop_oop_t)moo_allocbytes(moo, MOO_SIZEOF(moo_obj_t) + nbytes_aligned);
|
||||
if (!hdr) return MOO_NULL;
|
||||
if (MOO_UNLIKELY(!hdr)) return MOO_NULL;
|
||||
|
||||
hdr->_flags = MOO_OBJ_MAKE_FLAGS(MOO_OBJ_TYPE_OOP, MOO_SIZEOF(moo_oop_t), 0, 0, moo->igniting, 0, 0, 0, 0, 0);
|
||||
MOO_OBJ_SET_SIZE (hdr, size);
|
||||
|
Loading…
x
Reference in New Issue
Block a user