2015-02-26 09:02:31 -06:00
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2015-06-01 10:28:29 -05:00
|
|
|
#include "trick/Threads.hh"
|
2015-02-26 09:02:31 -06:00
|
|
|
|
|
|
|
Trick::Threads::Threads(int in_id , bool in_rt_nap) :
|
|
|
|
enabled(true) ,
|
|
|
|
thread_id(in_id) ,
|
|
|
|
curr_time_tics(0) ,
|
|
|
|
amf_cycle(0.0) ,
|
|
|
|
amf_cycle_tics(0) ,
|
|
|
|
amf_next_tics(0) ,
|
|
|
|
curr_job(NULL) ,
|
|
|
|
rt_nap(in_rt_nap) ,
|
|
|
|
process_type(PROCESS_TYPE_SCHEDULED) ,
|
|
|
|
child_complete(false) ,
|
|
|
|
running(false) ,
|
|
|
|
shutdown_wait_async(false) {
|
|
|
|
std::stringstream oss ;
|
|
|
|
oss << "Child_" << in_id ;
|
|
|
|
name = oss.str() ;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Trick::Threads::set_pthread_id(pthread_t in_pthread_id) {
|
|
|
|
pthread_id = in_pthread_id ;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Trick::Threads::set_enabled( bool in_enabled ) {
|
|
|
|
enabled = in_enabled ;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Trick::Threads::clear_scheduled_queues() {
|
|
|
|
job_queue.clear() ;
|
|
|
|
top_of_frame_queue.clear() ;
|
|
|
|
end_of_frame_queue.clear() ;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Trick::Threads::dump( std::ostream & oss ) {
|
|
|
|
oss << "Trick::Threads (" << name << ")" << std::endl ;
|
|
|
|
oss << " process_type = " ;
|
2024-01-18 10:40:19 -06:00
|
|
|
// Regardless of type, amf_cycle is used to store the cycle time set.
|
|
|
|
// If thread_id is 0 which means main thread, amf_cycle can't be set so the init value 0 will be dumped.
|
2015-02-26 09:02:31 -06:00
|
|
|
switch ( process_type ) {
|
2024-01-18 10:40:19 -06:00
|
|
|
case PROCESS_TYPE_SCHEDULED: oss << "scheduled = " << amf_cycle << std::endl ; break ;
|
|
|
|
case PROCESS_TYPE_ASYNC_CHILD: oss << "asynchronous = " << amf_cycle << std::endl ; break ;
|
2015-02-26 09:02:31 -06:00
|
|
|
case PROCESS_TYPE_AMF_CHILD: oss << "asynchronous must finish with amf_cycle = " << amf_cycle << std::endl ; break ;
|
|
|
|
}
|
2015-12-02 10:35:25 -06:00
|
|
|
trigger_container.getThreadTrigger()->dump(oss) ;
|
2015-02-26 09:02:31 -06:00
|
|
|
oss << " number of scheduled jobs = " << job_queue.size() << std::endl ;
|
|
|
|
Trick::ThreadBase::dump(oss) ;
|
|
|
|
}
|