david/ipxe
david
/
ipxe
Archived
1
0
Fork 0

[process] Make it safe to call process_add() multiple times

This commit is contained in:
Michael Brown 2009-08-10 01:09:41 +01:00
parent 46073f1239
commit 04878ef745
5 changed files with 14 additions and 3 deletions

View File

@ -37,11 +37,18 @@ static LIST_HEAD ( run_queue );
* Add process to process list
*
* @v process Process
*
* It is safe to call process_add() multiple times; further calls will
* have no effect.
*/
void process_add ( struct process *process ) {
DBGC ( process, "PROCESS %p starting\n", process );
ref_get ( process->refcnt );
list_add_tail ( &process->list, &run_queue );
if ( list_empty ( &process->list ) ) {
DBGC ( process, "PROCESS %p starting\n", process );
ref_get ( process->refcnt );
list_add_tail ( &process->list, &run_queue );
} else {
DBGC ( process, "PROCESS %p already started\n", process );
}
}
/**

View File

@ -47,6 +47,7 @@ static inline __attribute__ (( always_inline )) void
process_init_stopped ( struct process *process,
void ( * step ) ( struct process *process ),
struct refcnt *refcnt ) {
INIT_LIST_HEAD ( &process->list );
process->step = step;
process->refcnt = refcnt;
}

View File

@ -802,6 +802,7 @@ static void ib_step ( struct process *process __unused ) {
/** Infiniband event queue process */
struct process ib_process __permanent_process = {
.list = LIST_HEAD_INIT ( ib_process.list ),
.step = ib_step,
};

View File

@ -625,5 +625,6 @@ static void net_step ( struct process *process __unused ) {
/** Networking stack process */
struct process net_process __permanent_process = {
.list = LIST_HEAD_INIT ( net_process.list ),
.step = net_step,
};

View File

@ -187,5 +187,6 @@ static void retry_step ( struct process *process __unused ) {
/** Retry timer process */
struct process retry_process __permanent_process = {
.list = LIST_HEAD_INIT ( retry_process.list ),
.step = retry_step,
};