aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Framework/Monitoring/Watchdog.cs48
1 files changed, 22 insertions, 26 deletions
diff --git a/OpenSim/Framework/Monitoring/Watchdog.cs b/OpenSim/Framework/Monitoring/Watchdog.cs
index 83f8e01..b2c1fb1 100644
--- a/OpenSim/Framework/Monitoring/Watchdog.cs
+++ b/OpenSim/Framework/Monitoring/Watchdog.cs
@@ -332,41 +332,37 @@ namespace OpenSim.Framework.Monitoring
332 if (callback != null) 332 if (callback != null)
333 { 333 {
334 List<ThreadWatchdogInfo> callbackInfos = null; 334 List<ThreadWatchdogInfo> callbackInfos = null;
335
336 // get a copy since we may change m_threads
337 List<ThreadWatchdogInfo> threadsInfo; 335 List<ThreadWatchdogInfo> threadsInfo;
336
338 lock (m_threads) 337 lock (m_threads)
339 threadsInfo = m_threads.Values.ToList();
340
341 foreach (ThreadWatchdogInfo threadInfo in threadsInfo)
342 { 338 {
343 lock (m_threads) 339 // get a copy since we may change m_threads
344 { 340 threadsInfo = m_threads.Values.ToList();
345 if(!m_threads.ContainsValue(threadInfo))
346 continue;
347 }
348
349 if(threadInfo.Thread.ThreadState == ThreadState.Stopped)
350 {
351 RemoveThread(threadInfo.Thread.ManagedThreadId);
352
353 if(callbackInfos == null)
354 callbackInfos = new List<ThreadWatchdogInfo>();
355 341
356 callbackInfos.Add(threadInfo); 342 foreach(ThreadWatchdogInfo threadInfo in threadsInfo)
357 }
358 else if(!threadInfo.IsTimedOut && now - threadInfo.LastTick >= threadInfo.Timeout)
359 { 343 {
360 threadInfo.IsTimedOut = true; 344 if(threadInfo.Thread.ThreadState == ThreadState.Stopped)
361
362 if(threadInfo.AlarmIfTimeout)
363 { 345 {
346 RemoveThread(threadInfo.Thread.ManagedThreadId);
347
364 if(callbackInfos == null) 348 if(callbackInfos == null)
365 callbackInfos = new List<ThreadWatchdogInfo>(); 349 callbackInfos = new List<ThreadWatchdogInfo>();
366 350
367 // Send a copy of the watchdog info to prevent race conditions where the watchdog 351 callbackInfos.Add(threadInfo);
368 // thread updates the monitoring info after an alarm has been sent out. 352 }
369 callbackInfos.Add(new ThreadWatchdogInfo(threadInfo)); 353 else if(!threadInfo.IsTimedOut && now - threadInfo.LastTick >= threadInfo.Timeout)
354 {
355 threadInfo.IsTimedOut = true;
356
357 if(threadInfo.AlarmIfTimeout)
358 {
359 if(callbackInfos == null)
360 callbackInfos = new List<ThreadWatchdogInfo>();
361
362 // Send a copy of the watchdog info to prevent race conditions where the watchdog
363 // thread updates the monitoring info after an alarm has been sent out.
364 callbackInfos.Add(new ThreadWatchdogInfo(threadInfo));
365 }
370 } 366 }
371 } 367 }
372 } 368 }