1 #include "Thread_Task.h"
3 #include "ace/High_Res_Timer.h"
4 #include "ace/OS_NS_unistd.h"
6 #include "tao/ORB_Core.h"
9 #include "Task_Stats.h"
10 #include "ace/Barrier.h"
12 Thread_Task::Thread_Task (void)
17 Thread_Task::activate_task (ACE_Barrier
* barrier
, RTCORBA::PriorityMapping
*priority_mapping
)
21 // Convert the priority specified to this class to its native number.
22 RTCORBA::NativePriority native_priority
;
24 if (priority_mapping
->to_native (this->task_priority_
, native_priority
) == 0)
25 ACE_ERROR_RETURN ((LM_ERROR
,
26 "Cannot convert CORBA priority %d to native priority\n",
27 this->task_priority_
),
33 ACTIVITY::instance()->orb ()->orb_core ()->orb_params ()->thread_creation_flags ();
35 // Become an active object.
36 if (this->activate (flags
,
39 native_priority
) == -1)
41 if (ACE_OS::last_error () == EPERM
)
42 ACE_ERROR_RETURN ((LM_ERROR
,
43 ACE_TEXT ("Insufficient privilege to run this test.\n")),
47 ACE_TEXT ("(%t) task activation at priority %d failed, ")
48 ACE_TEXT ("exiting!\n%a"),
56 Thread_Task::svc (void)
58 // if debugging, dump the priority that we're actually at.
59 if (TAO_debug_level
> 0)
62 // Get the priority of the current thread.
63 RTCORBA::Priority prio
=
64 ACTIVITY::instance()->current ()->the_priority ();
66 if (prio
== this->task_priority_
)
68 ACE_TEXT ("(%t) actual prio of %d equals desired priority\n"),
73 ACE_TEXT ("(%t) actual prio = %d, desired priority_ = %d!\n"),
75 this->task_priority_
));
79 if (TAO_debug_level
> 0)
80 ACE_DEBUG ((LM_DEBUG
, "Thread_Task (%t) - wait\n"));
82 // First, wait for other threads.
83 this->barrier_
->wait ();
85 // first thread here inits the Base_Time.
86 task_stats_
->base_time (BASE_TIME::instance ()->base_time_
);
88 // now wait till the phase_ period expires.
89 ACE_OS::sleep (ACE_Time_Value (0, phase_
));
91 ACE_High_Res_Timer::global_scale_factor_type gsf
=
92 ACE_High_Res_Timer::global_scale_factor ();
94 ACE_hrtime_t before
, after
;
96 for (int i
= 0; i
< iter_
; ++i
)
98 before
= ACE_OS::gethrtime ();
102 after
= ACE_OS::gethrtime ();
104 task_stats_
->sample (before
, after
);
106 if (period_
!= 0) // blast mode, no sleep.
108 // convert to microseconds
109 ACE_UINT32 elapsed_microseconds
= ACE_UINT32((after
- before
) / gsf
);
111 #if defined (ACE_WIN32)
112 elapsed_microseconds
*=1000; // convert to uSec on Win32
113 #endif /* ACE_WIN32 */
115 // did we miss any deadlines?
118 elapsed_microseconds
> period_
? elapsed_microseconds
/period_
: 0;
120 long sleep_time
= (missed
+ 1)*period_
;
121 sleep_time
-= elapsed_microseconds
;
123 if (TAO_debug_level
> 0)
124 ACE_DEBUG ((LM_DEBUG
, "(%t) sleep time = %d\n", sleep_time
));
126 ACE_Time_Value
t_sleep (0, sleep_time
);
127 ACE_OS::sleep (t_sleep
);
131 task_stats_
->end_time (ACE_OS::gethrtime ());
133 job_
->shutdown (); // tell the job that we're done.
135 ACTIVITY::instance ()->task_ended (this);