Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(533)

Side by Side Diff: base/watchdog.h

Issue 6079009: Move some misc thread-related stuff from base to base/thread and into the bas... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « base/threading/worker_pool_win.cc ('k') | base/watchdog.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // The Watchdog class creates a second thread that can Alarm if a specific
6 // duration of time passes without proper attention. The duration of time is
7 // specified at construction time. The Watchdog may be used many times by
8 // simply calling Arm() (to start timing) and Disarm() (to reset the timer).
9 // The Watchdog is typically used under a debugger, where the stack traces on
10 // other threads can be examined if/when the Watchdog alarms.
11
12 // Some watchdogs will be enabled or disabled via command line switches. To
13 // facilitate such code, an "enabled" argument for the constuctor can be used
14 // to permanently disable the watchdog. Disabled watchdogs don't even spawn
15 // a second thread, and their methods call (Arm() and Disarm()) return very
16 // quickly.
17
18 #ifndef BASE_WATCHDOG_H__
19 #define BASE_WATCHDOG_H__
20 #pragma once
21
22 #include <string>
23
24 #include "base/condition_variable.h"
25 #include "base/lock.h"
26 #include "base/platform_thread.h"
27 #include "base/time.h"
28
29 class Watchdog {
30 public:
31 // Constructor specifies how long the Watchdog will wait before alarming.
32 Watchdog(const base::TimeDelta& duration,
33 const std::string& thread_watched_name,
34 bool enabled);
35 virtual ~Watchdog();
36
37 // Start timing, and alarm when time expires (unless we're disarm()ed.)
38 void Arm(); // Arm starting now.
39 void ArmSomeTimeDeltaAgo(const base::TimeDelta& time_delta);
40 void ArmAtStartTime(const base::TimeTicks start_time);
41
42 // Reset time, and do not set off the alarm.
43 void Disarm();
44
45 // Alarm is called if the time expires after an Arm() without someone calling
46 // Disarm(). This method can be overridden to create testable classes.
47 virtual void Alarm();
48
49 // Reset static data to initial state. Useful for tests, to ensure
50 // they are independent.
51 static void ResetStaticData();
52
53 private:
54 class ThreadDelegate : public PlatformThread::Delegate {
55 public:
56 explicit ThreadDelegate(Watchdog* watchdog) : watchdog_(watchdog) {
57 }
58 virtual void ThreadMain();
59 private:
60 Watchdog* watchdog_;
61
62 void SetThreadName() const;
63 };
64
65 enum State {ARMED, DISARMED, SHUTDOWN };
66
67 bool init_successful_;
68
69 Lock lock_; // Mutex for state_.
70 ConditionVariable condition_variable_;
71 State state_;
72 const base::TimeDelta duration_; // How long after start_time_ do we alarm?
73 const std::string thread_watched_name_;
74 PlatformThreadHandle handle_;
75 ThreadDelegate delegate_; // Store it, because it must outlive the thread.
76
77 base::TimeTicks start_time_; // Start of epoch, and alarm after duration_.
78
79 // When the debugger breaks (when we alarm), all the other alarms that are
80 // armed will expire (also alarm). To diminish this effect, we track any
81 // delay due to debugger breaks, and we *try* to adjust the effective start
82 // time of other alarms to step past the debugging break.
83 // Without this safety net, any alarm will typically trigger a host of follow
84 // on alarms from callers that specify old times.
85 static Lock static_lock_; // Lock for access of static data...
86 // When did we last alarm and get stuck (for a while) in a debugger?
87 static base::TimeTicks last_debugged_alarm_time_;
88 // How long did we sit on a break in the debugger?
89 static base::TimeDelta last_debugged_alarm_delay_;
90
91 DISALLOW_COPY_AND_ASSIGN(Watchdog);
92 };
93
94 #endif // BASE_WATCHDOG_H__
OLDNEW
« no previous file with comments | « base/threading/worker_pool_win.cc ('k') | base/watchdog.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698