forked from Imagelibrary/rtems
* rtems/include/rtems/rtems/event.h, rtems/inline/rtems/rtems/eventset.inl, rtems/src/event.c, rtems/src/eventseize.c, rtems/src/eventsurrender.c, rtems/src/eventtimeout.c, score/Makefile.am, score/preinstall.am, score/include/rtems/score/interr.h, score/include/rtems/score/thread.h, score/include/rtems/score/threadq.h, score/include/rtems/score/tqdata.h, score/inline/rtems/score/threadq.inl, score/inline/rtems/score/tqdata.inl, score/src/threadq.c, score/src/threadqdequeue.c, score/src/threadqdequeuefifo.c, score/src/threadqdequeuepriority.c, score/src/threadqenqueue.c, score/src/threadqenqueuefifo.c, score/src/threadqenqueuepriority.c, score/src/threadqextract.c, score/src/threadqextractfifo.c, score/src/threadqextractpriority.c, score/src/threadqextractwithproxy.c, score/src/threadqfirst.c, score/src/threadqfirstfifo.c, score/src/threadqfirstpriority.c, score/src/threadqflush.c, score/src/threadqrequeue.c, score/src/threadqtimeout.c: Refactor thread queue enqueue and event blocking synchronization critical sections. This resulted in three copies of essentially the same hard to test critical section code becoming the one shared routine _Thread_blocking_operation_Cancel. In addition, the thread queue and event code now share a common synchronization enumerated type. Along the way, switches were reworked to eliminate dead code generated by gcc and comments and copyrights were updated. * score/include/rtems/score/threadsync.h, score/src/threadblockingoperationcancel.c: New files.
67 lines
1.7 KiB
C
67 lines
1.7 KiB
C
/*
|
|
* Thread Queue Handler
|
|
*
|
|
*
|
|
* COPYRIGHT (c) 1989-2008.
|
|
* On-Line Applications Research Corporation (OAR).
|
|
*
|
|
* The license and distribution terms for this file may be
|
|
* found in the file LICENSE in this distribution or at
|
|
* http://www.rtems.com/license/LICENSE.
|
|
*
|
|
* $Id$
|
|
*/
|
|
|
|
#if HAVE_CONFIG_H
|
|
#include "config.h"
|
|
#endif
|
|
|
|
#include <rtems/system.h>
|
|
#include <rtems/score/chain.h>
|
|
#include <rtems/score/isr.h>
|
|
#include <rtems/score/object.h>
|
|
#include <rtems/score/states.h>
|
|
#include <rtems/score/thread.h>
|
|
#include <rtems/score/threadq.h>
|
|
#include <rtems/score/tqdata.h>
|
|
|
|
/*PAGE
|
|
*
|
|
* _Thread_queue_Initialize
|
|
*
|
|
* This routine initializes the specified threadq.
|
|
*
|
|
* Input parameters:
|
|
* the_thread_queue - pointer to a threadq header
|
|
* discipline - queueing discipline
|
|
* state - state of waiting threads
|
|
* timeout_status - return on a timeout
|
|
*
|
|
* Output parameters: NONE
|
|
*/
|
|
|
|
void _Thread_queue_Initialize(
|
|
Thread_queue_Control *the_thread_queue,
|
|
Thread_queue_Disciplines the_discipline,
|
|
States_Control state,
|
|
uint32_t timeout_status
|
|
)
|
|
{
|
|
the_thread_queue->state = state;
|
|
the_thread_queue->discipline = the_discipline;
|
|
the_thread_queue->timeout_status = timeout_status;
|
|
the_thread_queue->sync_state = THREAD_BLOCKING_OPERATION_SYNCHRONIZED;
|
|
|
|
if ( the_discipline == THREAD_QUEUE_DISCIPLINE_PRIORITY ) {
|
|
uint32_t index;
|
|
|
|
for( index=0 ;
|
|
index < TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS ;
|
|
index++)
|
|
_Chain_Initialize_empty( &the_thread_queue->Queues.Priority[index] );
|
|
} else { /* must be THREAD_QUEUE_DISCIPLINE_FIFO */
|
|
_Chain_Initialize_empty( &the_thread_queue->Queues.Fifo );
|
|
}
|
|
|
|
}
|