|
TAO_RTEvent
2.2.0
|
Dispatching strategy that minimizes mt inversion. More...
#include <EC_MT_Dispatching.h>


Public Member Functions | |
| TAO_EC_MT_Dispatching (int nthreads, int thread_creation_flags, int thread_priority, int force_activate, TAO_EC_Queue_Full_Service_Object *queue_full_service_object_name) | |
| virtual void | activate (void) |
| virtual void | shutdown (void) |
| virtual void | push (TAO_EC_ProxyPushSupplier *proxy, RtecEventComm::PushConsumer_ptr consumer, const RtecEventComm::EventSet &event, TAO_EC_QOS_Info &qos_info) |
| virtual void | push_nocopy (TAO_EC_ProxyPushSupplier *proxy, RtecEventComm::PushConsumer_ptr consumer, RtecEventComm::EventSet &event, TAO_EC_QOS_Info &qos_info) |
Public Member Functions inherited from TAO_EC_Dispatching | |
| virtual | ~TAO_EC_Dispatching (void) |
| Destructor... More... | |
Private Attributes | |
| ACE_Thread_Manager | thread_manager_ |
| Use our own thread manager. More... | |
| int | nthreads_ |
| The number of active tasks. More... | |
| int | thread_creation_flags_ |
| int | thread_priority_ |
| The priority of the dispatching threads. More... | |
| int | force_activate_ |
| TAO_EC_Dispatching_Task | task_ |
| The dispatching task. More... | |
| TAO_SYNCH_MUTEX | lock_ |
| Synchronize access to internal data. More... | |
| int | active_ |
| Are the threads running? More... | |
| TAO_EC_Queue_Full_Service_Object * | queue_full_service_object_ |
| Service Object information. More... | |
Dispatching strategy that minimizes mt inversion.
This strategy uses a single queue, serviced by one or more threads. It's main purpose is to decouple the suppliers from the client execution time, specially in the collocated case.
| TAO_EC_MT_Dispatching::TAO_EC_MT_Dispatching | ( | int | nthreads, |
| int | thread_creation_flags, | ||
| int | thread_priority, | ||
| int | force_activate, | ||
| TAO_EC_Queue_Full_Service_Object * | queue_full_service_object_name | ||
| ) |
Constructor It will create nthreads servicing threads...
|
virtual |
Initialize all the data structures, activate any internal threads, etc.
Implements TAO_EC_Dispatching.
|
virtual |
The consumer represented by proxy should receive event. It can use the information in qos_info to determine the event priority (among other things).
Implements TAO_EC_Dispatching.
|
virtual |
Implements TAO_EC_Dispatching.
|
virtual |
Deactivate any internal threads and cleanup internal data structures, it should only return once the threads have finished their jobs.
Implements TAO_EC_Dispatching.
|
private |
Are the threads running?
|
private |
If activation at the requested priority fails then we fallback on the defaults for thread activation.
|
private |
Synchronize access to internal data.
|
private |
The number of active tasks.
|
private |
Service Object information.
|
private |
The dispatching task.
|
private |
The flags (THR_BOUND, THR_NEW_LWP, etc.) used to create the dispatching threads.
|
private |
Use our own thread manager.
|
private |
The priority of the dispatching threads.
1.8.3.1