summaryrefslogtreecommitdiff
path: root/services/surfaceflinger/MessageQueue.cpp
diff options
context:
space:
mode:
author Chia-I Wu <olv@google.com> 2017-10-31 18:46:54 +0000
committer android-build-merger <android-build-merger@google.com> 2017-10-31 18:46:54 +0000
commit3c192d059e2c1e5fc47812091dcf276f25f24f2c (patch)
treefb5418f4470abed437b67a63b41221d1353dc330 /services/surfaceflinger/MessageQueue.cpp
parentcf47b0b6d01c0891043244c9aa9a60e2dbcf5d38 (diff)
parentffbf2d94a1838126f05fcebb6a90a7d6cdf9601f (diff)
surfaceflinger: make vsync injection more robust am: 6200eacdc9
am: ffbf2d94a1 Change-Id: I2f007234616adaff87866089bec9be000412e7cb
Diffstat (limited to 'services/surfaceflinger/MessageQueue.cpp')
-rw-r--r--services/surfaceflinger/MessageQueue.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/services/surfaceflinger/MessageQueue.cpp b/services/surfaceflinger/MessageQueue.cpp
index bca3430794..0b1199c2d0 100644
--- a/services/surfaceflinger/MessageQueue.cpp
+++ b/services/surfaceflinger/MessageQueue.cpp
@@ -91,6 +91,14 @@ void MessageQueue::init(const sp<SurfaceFlinger>& flinger)
void MessageQueue::setEventThread(const sp<EventThread>& eventThread)
{
+ if (mEventThread == eventThread) {
+ return;
+ }
+
+ if (mEventTube.getFd() >= 0) {
+ mLooper->removeFd(mEventTube.getFd());
+ }
+
mEventThread = eventThread;
mEvents = eventThread->createEventConnection();
mEvents->stealReceiveChannel(&mEventTube);