summaryrefslogtreecommitdiffstats
path: root/services/input/InputReader.cpp
diff options
context:
space:
mode:
authorJeff Brown <jeffbrown@google.com>2012-01-27 17:37:31 -0800
committerAndroid (Google) Code Review <android-gerrit@google.com>2012-01-27 17:37:31 -0800
commitcb0af4f1b0709b236a030f41c75edd97cf0bf1fd (patch)
tree772ae4db2d2ccfe56cb6e6ef2532a565b2ea6670 /services/input/InputReader.cpp
parent2d2d7d6f42fe22ecc2b1dc8bb96a19e503a61a20 (diff)
parent112b5f52c5a4b6743eeb7b26a8896c7636c74455 (diff)
downloadframeworks_base-cb0af4f1b0709b236a030f41c75edd97cf0bf1fd.zip
frameworks_base-cb0af4f1b0709b236a030f41c75edd97cf0bf1fd.tar.gz
frameworks_base-cb0af4f1b0709b236a030f41c75edd97cf0bf1fd.tar.bz2
Merge "Improve watchdog monitor for InputReader and InputDispatcher."
Diffstat (limited to 'services/input/InputReader.cpp')
-rw-r--r--services/input/InputReader.cpp11
1 files changed, 8 insertions, 3 deletions
diff --git a/services/input/InputReader.cpp b/services/input/InputReader.cpp
index fa0b3d8..4be06e4 100644
--- a/services/input/InputReader.cpp
+++ b/services/input/InputReader.cpp
@@ -278,17 +278,20 @@ void InputReader::loopOnce() {
{ // acquire lock
AutoMutex _l(mLock);
+ mReaderIsAliveCondition.broadcast();
if (count) {
processEventsLocked(mEventBuffer, count);
}
if (!count || timeoutMillis == 0) {
nsecs_t now = systemTime(SYSTEM_TIME_MONOTONIC);
+ if (now >= mNextTimeout) {
#if DEBUG_RAW_EVENTS
- ALOGD("Timeout expired, latency=%0.3fms", (now - mNextTimeout) * 0.000001f);
+ ALOGD("Timeout expired, latency=%0.3fms", (now - mNextTimeout) * 0.000001f);
#endif
- mNextTimeout = LLONG_MAX;
- timeoutExpiredLocked(now);
+ mNextTimeout = LLONG_MAX;
+ timeoutExpiredLocked(now);
+ }
}
} // release lock
@@ -772,6 +775,8 @@ void InputReader::dump(String8& dump) {
void InputReader::monitor() {
// Acquire and release the lock to ensure that the reader has not deadlocked.
mLock.lock();
+ mEventHub->wake();
+ mReaderIsAliveCondition.wait(mLock);
mLock.unlock();
// Check the EventHub