diff options
author | Jacek Antonelli | 2008-08-15 23:45:54 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:45:54 -0500 |
commit | d0b03a62fd799317d5da0bd56615739ce3b5b052 (patch) | |
tree | 8bc79bbbb52e18294f62810d9fa66ce136f90e2d /linden/indra/newview/llwatchdog.cpp | |
parent | Second Life viewer sources 1.20.8 (diff) | |
download | meta-impy-d0b03a62fd799317d5da0bd56615739ce3b5b052.zip meta-impy-d0b03a62fd799317d5da0bd56615739ce3b5b052.tar.gz meta-impy-d0b03a62fd799317d5da0bd56615739ce3b5b052.tar.bz2 meta-impy-d0b03a62fd799317d5da0bd56615739ce3b5b052.tar.xz |
Second Life viewer sources 1.20.9
Diffstat (limited to 'linden/indra/newview/llwatchdog.cpp')
-rw-r--r-- | linden/indra/newview/llwatchdog.cpp | 68 |
1 files changed, 52 insertions, 16 deletions
diff --git a/linden/indra/newview/llwatchdog.cpp b/linden/indra/newview/llwatchdog.cpp index d92d381..55975ee 100644 --- a/linden/indra/newview/llwatchdog.cpp +++ b/linden/indra/newview/llwatchdog.cpp | |||
@@ -33,6 +33,8 @@ | |||
33 | #include "llviewerprecompiledheaders.h" | 33 | #include "llviewerprecompiledheaders.h" |
34 | #include "llwatchdog.h" | 34 | #include "llwatchdog.h" |
35 | 35 | ||
36 | const U32 WATCHDOG_SLEEP_TIME_USEC = 1000000; | ||
37 | |||
36 | // This class runs the watchdog timing thread. | 38 | // This class runs the watchdog timing thread. |
37 | class LLWatchdogTimerThread : public LLThread | 39 | class LLWatchdogTimerThread : public LLThread |
38 | { | 40 | { |
@@ -105,6 +107,11 @@ bool LLWatchdogTimeout::isAlive() const | |||
105 | return (mTimer.getStarted() && !mTimer.hasExpired()); | 107 | return (mTimer.getStarted() && !mTimer.hasExpired()); |
106 | } | 108 | } |
107 | 109 | ||
110 | void LLWatchdogTimeout::reset() | ||
111 | { | ||
112 | mTimer.setTimerExpirySec(mTimeout); | ||
113 | } | ||
114 | |||
108 | void LLWatchdogTimeout::setTimeout(F32 d) | 115 | void LLWatchdogTimeout::setTimeout(F32 d) |
109 | { | 116 | { |
110 | mTimeout = d; | 117 | mTimeout = d; |
@@ -132,13 +139,14 @@ void LLWatchdogTimeout::ping(const std::string& state) | |||
132 | { | 139 | { |
133 | mPingState = state; | 140 | mPingState = state; |
134 | } | 141 | } |
135 | mTimer.setTimerExpirySec(mTimeout); | 142 | reset(); |
136 | } | 143 | } |
137 | 144 | ||
138 | // LlWatchdog | 145 | // LLWatchdog |
139 | LLWatchdog::LLWatchdog() : | 146 | LLWatchdog::LLWatchdog() : |
140 | mSuspectsAccessMutex(NULL), | 147 | mSuspectsAccessMutex(NULL), |
141 | mTimer(NULL) | 148 | mTimer(NULL), |
149 | mLastClockCount(0) | ||
142 | { | 150 | { |
143 | } | 151 | } |
144 | 152 | ||
@@ -166,7 +174,11 @@ void LLWatchdog::init() | |||
166 | { | 174 | { |
167 | mSuspectsAccessMutex = new LLMutex(NULL); | 175 | mSuspectsAccessMutex = new LLMutex(NULL); |
168 | mTimer = new LLWatchdogTimerThread(); | 176 | mTimer = new LLWatchdogTimerThread(); |
169 | mTimer->setSleepTime(1000); | 177 | mTimer->setSleepTime(WATCHDOG_SLEEP_TIME_USEC / 1000); |
178 | mLastClockCount = LLTimer::getTotalTime(); | ||
179 | |||
180 | // mTimer->start() kicks off the thread, any code after | ||
181 | // start needs to use the mSuspectsAccessMutex | ||
170 | mTimer->start(); | 182 | mTimer->start(); |
171 | } | 183 | } |
172 | } | 184 | } |
@@ -177,40 +189,64 @@ void LLWatchdog::cleanup() | |||
177 | { | 189 | { |
178 | mTimer->stop(); | 190 | mTimer->stop(); |
179 | delete mTimer; | 191 | delete mTimer; |
192 | mTimer = NULL; | ||
180 | } | 193 | } |
181 | 194 | ||
182 | if(mSuspectsAccessMutex) | 195 | if(mSuspectsAccessMutex) |
183 | { | 196 | { |
184 | delete mSuspectsAccessMutex; | 197 | delete mSuspectsAccessMutex; |
198 | mSuspectsAccessMutex = NULL; | ||
185 | } | 199 | } |
200 | |||
201 | mLastClockCount = 0; | ||
186 | } | 202 | } |
187 | 203 | ||
188 | void LLWatchdog::run() | 204 | void LLWatchdog::run() |
189 | { | 205 | { |
190 | lockThread(); | 206 | lockThread(); |
207 | |||
208 | // Check the time since the last call to run... | ||
209 | // If the time elapsed is two times greater than the regualr sleep time | ||
210 | // reset the active timeouts. | ||
211 | const U32 TIME_ELAPSED_MULTIPLIER = 2; | ||
212 | U64 current_time = LLTimer::getTotalTime(); | ||
213 | U64 current_run_delta = current_time - mLastClockCount; | ||
214 | mLastClockCount = current_time; | ||
191 | 215 | ||
192 | SuspectsRegistry::iterator result = | 216 | if(current_run_delta > (WATCHDOG_SLEEP_TIME_USEC * TIME_ELAPSED_MULTIPLIER)) |
193 | std::find_if(mSuspects.begin(), | 217 | { |
218 | llinfos << "Watchdog thread delayed: resetting entries." << llendl; | ||
219 | std::for_each(mSuspects.begin(), | ||
194 | mSuspects.end(), | 220 | mSuspects.end(), |
195 | std::not1(std::mem_fun(&LLWatchdogEntry::isAlive)) | 221 | std::mem_fun(&LLWatchdogEntry::reset) |
196 | ); | 222 | ); |
197 | 223 | } | |
198 | if(result != mSuspects.end()) | 224 | else |
199 | { | 225 | { |
200 | // error!!! | 226 | SuspectsRegistry::iterator result = |
201 | if(mTimer) | 227 | std::find_if(mSuspects.begin(), |
228 | mSuspects.end(), | ||
229 | std::not1(std::mem_fun(&LLWatchdogEntry::isAlive)) | ||
230 | ); | ||
231 | |||
232 | if(result != mSuspects.end()) | ||
202 | { | 233 | { |
203 | mTimer->stop(); | 234 | // error!!! |
204 | } | 235 | if(mTimer) |
236 | { | ||
237 | mTimer->stop(); | ||
238 | } | ||
205 | 239 | ||
206 | llinfos << "Watchdog detected error:" << llendl; | 240 | llinfos << "Watchdog detected error:" << llendl; |
207 | #ifdef LL_WINDOWS | 241 | #ifdef LL_WINDOWS |
208 | RaiseException(0,0,0,0); | 242 | RaiseException(0,0,0,0); |
209 | #else | 243 | #else |
210 | raise(SIGQUIT); | 244 | raise(SIGQUIT); |
211 | #endif | 245 | #endif |
246 | } | ||
212 | } | 247 | } |
213 | 248 | ||
249 | |||
214 | unlockThread(); | 250 | unlockThread(); |
215 | } | 251 | } |
216 | 252 | ||