parrotcode: Thread handling stuff | |
Contents | C |
src/thread.c - Thread handling stuff
Threads are created by creating new ParrotInterpreter
objects.
PARROT_CAN_RETURN_NULL static PMC *make_local_copy(PARROT_INTERP, NOTNULL(Parrot_Interp from), NULLOK(PMC *arg))
static Shared_gc_info *get_pool(PARROT_INTERP)
PARROT_CAN_RETURN_NULL static PMC *make_local_args_copy(PARROT_INTERP, Parrot_Interp old_interp, PMC *args)
PMC *pt_shared_fixup(PARROT_INTERP, PMC *pmc)
static void pt_thread_signal(NOTNULL(Parrot_Interp self), PARROT_INTERP)
interp
which should have called pt_thread_wait().void pt_thread_wait_with(PARROT_INTERP, Parrot_mutex *mutex)
*mutex
is assumed locked on entry and will be locked on exit from this function.
If a GC run occurs in the middle of this function,
then a spurious wakeup may occur.static void pt_thread_wait(PARROT_INTERP)
interpreter_array_mutex
is assumed held.
Spurious wakeups may occur.PARROT_CAN_RETURN_NULL static void *thread_func(void *arg)
void pt_clone_code(Parrot_Interp d, Parrot_Interp s)
s
to d
.
All resources are created in d
.static void pt_ns_clone(Parrot_Interp d, PMC *dest_ns, Parrot_Interp s, PMC *source_ns)
s
to d
.void pt_clone_globals(Parrot_Interp d, Parrot_Interp s)
void pt_thread_prepare_for_run(Parrot_Interp d, Parrot_Interp s)
PMC *pt_transfer_sub(Parrot_Interp d, Parrot_Interp s, NULLOK(PMC *sub))
int pt_thread_run(PARROT_INTERP, PMC *dest_interp, PMC *sub, PMC *arg)
*sub
PMC in a separate thread using interpreter in *dest_interp
.arg
should be an array of arguments for the subroutine.
intint pt_thread_run_1(PARROT_INTERP, PMC *dest_interp, PMC *sub, PMC *arg)
int pt_thread_run_2(PARROT_INTERP, PMC *dest_interp, PMC *sub, PMC *arg)
int pt_thread_run_3(PARROT_INTERP, PMC *dest_interp, PMC *sub, PMC *arg)
void pt_thread_yield(void)
static Parrot_Interp pt_check_tid(UINTVAL tid, NOTNULL(const char *from))
tid
is valid.
The caller holds the mutex.
Returns the interpreter for tid
.static void mutex_unlock(void *arg)
*arg
.static int is_suspended_for_gc(PARROT_INTERP)
interp
is suspended so a global GC can be performed.
interpreter_array_mutex must be held.static QUEUE_ENTRY *remove_queued_suspend_gc(PARROT_INTERP)
static int pt_gc_count_threads(PARROT_INTERP)
static void pt_gc_wait_for_stage(PARROT_INTERP, thread_gc_stage_enum from_stage, thread_gc_stage_enum to_stage)
static void pt_gc_wakeup_check(PARROT_INTERP)
static void pt_suspend_one_for_gc(PARROT_INTERP)
interpreter_array_mutex
assumed held.static void pt_suspend_all_for_gc(PARROT_INTERP)
void pt_suspend_self_for_gc(PARROT_INTERP)
PMC *pt_thread_join(NOTNULL(Parrot_Interp parent), UINTVAL tid)
void pt_join_threads(PARROT_INTERP)
interp
.static Parrot_Interp detach(UINTVAL tid)
void pt_thread_detach(UINTVAL tid)
void pt_thread_kill(UINTVAL tid)
void pt_add_to_interpreters(PARROT_INTERP, Parrot_Interp new_interp)
void pt_DOD_start_mark(PARROT_INTERP)
PMC->next_for_GC
may be changed.flags
are the DOD flags.
We check if we need to collect shared objects or not.dod_mark_ptr
is updated.void pt_DOD_mark_root_finished(PARROT_INTERP)
void pt_DOD_stop_mark(PARROT_INTERP)
PARROT_API void Parrot_shared_DOD_block(PARROT_INTERP)
PARROT_API void Parrot_shared_DOD_unblock(PARROT_INTERP)
|