Merge pull request #2220 from DOCGroup/revert-2217-jwi-inetwraning
[ACE_TAO.git] / ACE / ace / Metrics_Cache_T.inl
blobe4900cb88b8657b49fa61b4691048a56a5f2ab0b
1 // -*- C++ -*-
2 #ifndef ACE_METRICS_CACHE_T_INL
3 #define ACE_METRICS_CACHE_T_INL
5 #if defined (ACE_COMPILE_TIMEPROBES)
7 ACE_BEGIN_VERSIONED_NAMESPACE_DECL
9 /////////////////////////////
10 // Class ACE_Metrics_Cache //
11 /////////////////////////////
14 template <class ACE_LOCK, class ALLOCATOR>
15 ACE_INLINE void
16 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_enqueue_start (u_long i)
18   if (i < this->probe_set_size_)
19     {
20       u_long & count =
21         this->enqueue_count_ [this->supplier_index_] [i];
22       ++count;
24       if (! this->interval_initialized_)
25         {
26           this->interval_initialized_ = 1;
27           ACE_hrtime_t hrtime_now = ACE_OS::gethrtime ();
28           ACE_High_Res_Timer::hrtime_to_tv (this->interval_start_,
29                                             hrtime_now);
30           this->interval_end_.set (this->interval_start_.sec(),
31                                    this->interval_start_.usec());
32         }
34       // Take the metrics timeprobe last, to avoid measuring the above
35       // metrics processing.
36       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
37         this->enqueue_probes_ [this->supplier_index_][i];
38       probe->
39         timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_START);
40     }
44 template <class ACE_LOCK, class ALLOCATOR>
45 ACE_INLINE void
46 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_enqueue_stop (u_long i)
48   if (i < this->probe_set_size_)
49     {
50       // Take the metrics timeprobe first, to avoid measuring the below
51       // metrics processing.
52       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
53         this->enqueue_probes_ [this->supplier_index_][i];
54       probe->
55         timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_STOP);
57       ACE_hrtime_t hrtime_now = ACE_OS::gethrtime ();
58       ACE_High_Res_Timer::hrtime_to_tv (this->interval_end_,
59                                             hrtime_now);
61       u_long & count = enqueue_count_ [this->supplier_index_][i];
62       ++count;
63     }
68 template <class ACE_LOCK, class ALLOCATOR>
69 ACE_INLINE void
70 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_enqueue_suspend (u_long i)
72   if (i < this->probe_set_size_)
73     {
74       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
75         this->enqueue_probes_ [this->supplier_index_][i];
76       probe->
77         timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_SUSPEND);
78       u_long & count =
79         this->enqueue_count_ [this->supplier_index_] [i];
80       ++count;
81     }
85 template <class ACE_LOCK, class ALLOCATOR>
86 ACE_INLINE void
87 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_enqueue_resume (u_long i)
89   if (i < this->probe_set_size_)
90     {
91       u_long & count =
92         this->enqueue_count_ [this->supplier_index_] [i];
93       ++count;
94       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
95         this->enqueue_probes_ [this->supplier_index_][i];
96       probe->
97         timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_RESUME);
98     }
102 template <class ACE_LOCK, class ALLOCATOR>
103 ACE_INLINE void
104 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_dequeue_start (u_long i)
106   if (i < this->probe_set_size_)
107     {
108       u_long & count =
109         this->dequeue_count_ [this->supplier_index_] [i];
110       ++count;
112       if (! this->interval_initialized_)
113         {
114           this->interval_initialized_ = 1;
115           ACE_hrtime_t hrtime_now = ACE_OS::gethrtime ();
116           ACE_High_Res_Timer::hrtime_to_tv (this->interval_start_,
117                                                     hrtime_now);
118           this->interval_end_.set (this->interval_start_.sec(),
119                                    this->interval_start_.usec());
120         }
122       // Take the metrics timeprobe last, to avoid measuring the above
123       // metrics processing.
124       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
125         this->dequeue_probes_ [this->supplier_index_][i];
126       probe->
127         timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_START);
128     }
132 template <class ACE_LOCK, class ALLOCATOR>
133 ACE_INLINE void
134 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_dequeue_stop (u_long i)
136   if (i < this->probe_set_size_)
137     {
138       // Take the metrics timeprobe first, to avoid measuring the
139       // metrics processing below.
140       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
141         this->dequeue_probes_ [this->supplier_index_][i];
143       probe->timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_STOP);
145       ACE_hrtime_t hrtime_now = ACE_OS::gethrtime ();
146       ACE_High_Res_Timer::hrtime_to_tv (this->interval_end_,
147                                                     hrtime_now);
149       u_long & count = dequeue_count_ [this->supplier_index_] [i];
150       ++count;
151     }
155 template <class ACE_LOCK, class ALLOCATOR>
156 ACE_INLINE void
157 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_dequeue_suspend (u_long i)
159   if (i < this->probe_set_size_)
160     {
161       u_long & count =
162         this->dequeue_count_ [this->supplier_index_] [i];
163       ++count;
164       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
165         this->dequeue_probes_ [this->supplier_index_][i];
166       probe->
167         timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_SUSPEND);
168     }
172 template <class ACE_LOCK, class ALLOCATOR>
173 ACE_INLINE void
174 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::report_dequeue_resume (u_long i)
176   if (i < this->probe_set_size_)
177     {
178       u_long & count =
179         this->dequeue_count_ [this->supplier_index_] [i];
180       ++count;
181       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
182         this->dequeue_probes_ [this->supplier_index_][i];
183       probe->
184         timeprobe (ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR>::WORK_RESUME);
185     }
189 template <class ACE_LOCK, class ALLOCATOR>
190 ACE_INLINE void
191 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::reset_base_statistics ()
193   this->interval_initialized_ = 0;
194   this->interval_start_.set (0, 0);
195   this->interval_end_.set (0, 0);
197   for (u_int i = 0; i < this->probe_set_size_; ++i)
198     {
199       this->enqueue_count_ [this->consumer_index_] [i] = 0;
200       this->dequeue_count_ [this->consumer_index_] [i] = 0;
202       ACE_Metrics_Timeprobe<ACE_LOCK, ALLOCATOR> * probe =
203         this->enqueue_probes_ [this->consumer_index_][i];
204       probe->reset ();
205       probe =
206         this->dequeue_probes_ [this->consumer_index_][i];
207       probe->reset ();
208     }
212 // Flips the supplier and consumer positions.
214 template <class ACE_LOCK, class ALLOCATOR>
215 ACE_INLINE void
216 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::flip_supplier_and_consumer ()
218   int temp = consumer_index_;
219   consumer_index_ = supplier_index_;
220   supplier_index_ = temp;
223 template <class ACE_LOCK, class ALLOCATOR>
224 ACE_INLINE void
225 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::metrics_enabled(int enabled)
227    metrics_enabled_ = enabled;
230 template <class ACE_LOCK, class ALLOCATOR>
231 ACE_INLINE int
232 ACE_Metrics_Cache<ACE_LOCK, ALLOCATOR>::metrics_enabled() const
234    return metrics_enabled_;
237 ACE_END_VERSIONED_NAMESPACE_DECL
239 #endif
241 #endif /* ACE_METRICS_CACHE_T_INL */