Merge pull request #1551 from DOCGroup/plm_jira_333
[ACE_TAO.git] / TAO / examples / RTCORBA / Activity / Thread_Task.cpp
blob10003b602608df95156020045f2383bf7fa0cb19
1 #include "Thread_Task.h"
3 #include "ace/High_Res_Timer.h"
4 #include "ace/OS_NS_unistd.h"
5 #include "tao/debug.h"
6 #include "tao/ORB_Core.h"
8 #include "Activity.h"
9 #include "Task_Stats.h"
10 #include "ace/Barrier.h"
12 Thread_Task::Thread_Task (void)
16 int
17 Thread_Task::activate_task (ACE_Barrier* barrier, RTCORBA::PriorityMapping *priority_mapping)
19 barrier_ = barrier;
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_),
28 -1);
30 long flags =
31 THR_NEW_LWP |
32 THR_JOINABLE |
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")),
44 -1);
45 else
46 ACE_DEBUG ((LM_ERROR,
47 ACE_TEXT ("(%t) task activation at priority %d failed, ")
48 ACE_TEXT ("exiting!\n%a"),
49 native_priority,
50 -1));
52 return 0;
55 int
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_)
67 ACE_DEBUG ((LM_DEBUG,
68 ACE_TEXT ("(%t) actual prio of %d equals desired priority\n"),
69 prio));
70 else
72 ACE_DEBUG ((LM_ERROR,
73 ACE_TEXT ("(%t) actual prio = %d, desired priority_ = %d!\n"),
74 prio,
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 ();
100 job_->work (load_);
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?
117 int const missed =
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);
128 } /* period != 0 */
129 } /* for */
131 task_stats_->end_time (ACE_OS::gethrtime ());
133 job_->shutdown (); // tell the job that we're done.
135 ACTIVITY::instance ()->task_ended (this);
137 return 0;