diff options
author | Jeff Brown <jeffbrown@google.com> | 2012-01-13 15:18:18 -0800 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2012-01-13 15:18:18 -0800 |
commit | 15d0bc4756c3b8012cb958ff96a35759504a8f98 (patch) | |
tree | b4b0fb42b6165357a25f21d89c41541b692d4054 | |
parent | effbc523df5171bd3f44533ea34dd24592857e65 (diff) | |
parent | dfef19940f2af5c043e0c6fb49909f093b8ff96b (diff) | |
download | frameworks_base-15d0bc4756c3b8012cb958ff96a35759504a8f98.zip frameworks_base-15d0bc4756c3b8012cb958ff96a35759504a8f98.tar.gz frameworks_base-15d0bc4756c3b8012cb958ff96a35759504a8f98.tar.bz2 |
am dfef1994: Merge "Fix a few memory leaks in the input dispatcher."
* commit 'dfef19940f2af5c043e0c6fb49909f093b8ff96b':
Fix a few memory leaks in the input dispatcher.
-rw-r--r-- | services/input/InputDispatcher.cpp | 30 | ||||
-rw-r--r-- | services/input/InputDispatcher.h | 3 |
2 files changed, 27 insertions, 6 deletions
diff --git a/services/input/InputDispatcher.cpp b/services/input/InputDispatcher.cpp index a0f372a..9f09062 100644 --- a/services/input/InputDispatcher.cpp +++ b/services/input/InputDispatcher.cpp @@ -1906,10 +1906,21 @@ void InputDispatcher::prepareDispatchCycleLocked(nsecs_t currentTime, connection->getInputChannelName()); logOutboundMotionDetailsLocked(" ", splitMotionEntry); #endif - eventEntry = splitMotionEntry; + enqueueDispatchEntriesLocked(currentTime, connection, + splitMotionEntry, inputTarget, resumeWithAppendedMotionSample); + splitMotionEntry->release(); + return; } } + // Not splitting. Enqueue dispatch entries for the event as is. + enqueueDispatchEntriesLocked(currentTime, connection, eventEntry, inputTarget, + resumeWithAppendedMotionSample); +} + +void InputDispatcher::enqueueDispatchEntriesLocked(nsecs_t currentTime, + const sp<Connection>& connection, EventEntry* eventEntry, const InputTarget* inputTarget, + bool resumeWithAppendedMotionSample) { // Resume the dispatch cycle with a freshly appended motion sample. // First we check that the last dispatch entry in the outbound queue is for the same // motion event to which we appended the motion sample. If we find such a dispatch @@ -2046,9 +2057,6 @@ void InputDispatcher::enqueueDispatchEntryLocked( DispatchEntry* dispatchEntry = new DispatchEntry(eventEntry, // increments ref inputTargetFlags, inputTarget->xOffset, inputTarget->yOffset, inputTarget->scaleFactor); - if (dispatchEntry->hasForegroundTarget()) { - incrementPendingForegroundDispatchesLocked(eventEntry); - } // Handle the case where we could not stream a new motion sample because the consumer has // already consumed the motion event (otherwise the corresponding dispatch entry would @@ -2077,6 +2085,7 @@ void InputDispatcher::enqueueDispatchEntryLocked( ALOGD("channel '%s' ~ enqueueDispatchEntryLocked: skipping inconsistent key event", connection->getInputChannelName()); #endif + delete dispatchEntry; return; // skip the inconsistent event } break; @@ -2118,12 +2127,18 @@ void InputDispatcher::enqueueDispatchEntryLocked( ALOGD("channel '%s' ~ enqueueDispatchEntryLocked: skipping inconsistent motion event", connection->getInputChannelName()); #endif + delete dispatchEntry; return; // skip the inconsistent event } break; } } + // Remember that we are waiting for this dispatch to complete. + if (dispatchEntry->hasForegroundTarget()) { + incrementPendingForegroundDispatchesLocked(eventEntry); + } + // Enqueue the dispatch entry. connection->outboundQueue.enqueueAtTail(dispatchEntry); } @@ -2462,14 +2477,17 @@ void InputDispatcher::synthesizeCancelationEventsForInputChannelLocked( void InputDispatcher::synthesizeCancelationEventsForConnectionLocked( const sp<Connection>& connection, const CancelationOptions& options) { + if (connection->status == Connection::STATUS_BROKEN) { + return; + } + nsecs_t currentTime = now(); mTempCancelationEvents.clear(); connection->inputState.synthesizeCancelationEvents(currentTime, mTempCancelationEvents, options); - if (! mTempCancelationEvents.isEmpty() - && connection->status != Connection::STATUS_BROKEN) { + if (!mTempCancelationEvents.isEmpty()) { #if DEBUG_OUTBOUND_EVENT_DETAILS ALOGD("channel '%s' ~ Synthesized %d cancelation events to bring channel back in sync " "with reality: %s, mode=%d.", diff --git a/services/input/InputDispatcher.h b/services/input/InputDispatcher.h index 8ae5a56..1478d67 100644 --- a/services/input/InputDispatcher.h +++ b/services/input/InputDispatcher.h @@ -1070,6 +1070,9 @@ private: void prepareDispatchCycleLocked(nsecs_t currentTime, const sp<Connection>& connection, EventEntry* eventEntry, const InputTarget* inputTarget, bool resumeWithAppendedMotionSample); + void enqueueDispatchEntriesLocked(nsecs_t currentTime, const sp<Connection>& connection, + EventEntry* eventEntry, const InputTarget* inputTarget, + bool resumeWithAppendedMotionSample); void enqueueDispatchEntryLocked(const sp<Connection>& connection, EventEntry* eventEntry, const InputTarget* inputTarget, bool resumeWithAppendedMotionSample, int32_t dispatchMode); |