diff options
author | Jesse Hall <jessehall@google.com> | 2013-10-14 12:56:09 -0700 |
---|---|---|
committer | Jesse Hall <jessehall@google.com> | 2013-10-14 16:25:01 -0700 |
commit | 948fe0ce74c13e1bbff233883c158519fa8fb293 (patch) | |
tree | 3e4b8fbb223a63b22eb4c361c4b9f5548c4473d8 /services/surfaceflinger | |
parent | 8e26b28be62e7c0e093900540db5e5cdcf52a0ff (diff) | |
download | frameworks_native-948fe0ce74c13e1bbff233883c158519fa8fb293.zip frameworks_native-948fe0ce74c13e1bbff233883c158519fa8fb293.tar.gz frameworks_native-948fe0ce74c13e1bbff233883c158519fa8fb293.tar.bz2 |
Disable hardware vsync when blanking the screen
Bug: 11220224
Change-Id: I99d0a42e1a6bb0aaf89706f6d100e9ef2a5deaa4
Diffstat (limited to 'services/surfaceflinger')
-rw-r--r-- | services/surfaceflinger/SurfaceFlinger.cpp | 25 | ||||
-rw-r--r-- | services/surfaceflinger/SurfaceFlinger.h | 5 |
2 files changed, 22 insertions, 8 deletions
diff --git a/services/surfaceflinger/SurfaceFlinger.cpp b/services/surfaceflinger/SurfaceFlinger.cpp index 4a1373e..bc8cfb8 100644 --- a/services/surfaceflinger/SurfaceFlinger.cpp +++ b/services/surfaceflinger/SurfaceFlinger.cpp @@ -147,6 +147,7 @@ SurfaceFlinger::SurfaceFlinger() mLastTransactionTime(0), mBootFinished(false), mPrimaryHWVsyncEnabled(false), + mHWVsyncAvailable(false), mDaltonize(false) { ALOGI("SurfaceFlinger is starting"); @@ -752,16 +753,23 @@ void SurfaceFlinger::run() { void SurfaceFlinger::enableHardwareVsync() { Mutex::Autolock _l(mHWVsyncLock); - if (!mPrimaryHWVsyncEnabled) { + if (!mPrimaryHWVsyncEnabled && mHWVsyncAvailable) { mPrimaryDispSync.beginResync(); eventControl(HWC_DISPLAY_PRIMARY, SurfaceFlinger::EVENT_VSYNC, true); mPrimaryHWVsyncEnabled = true; } } -void SurfaceFlinger::resyncToHardwareVsync() { +void SurfaceFlinger::resyncToHardwareVsync(bool makeAvailable) { Mutex::Autolock _l(mHWVsyncLock); + if (makeAvailable) { + mHWVsyncAvailable = true; + } else if (!mHWVsyncAvailable) { + ALOGE("resyncToHardwareVsync called when HW vsync unavailable"); + return; + } + const nsecs_t period = getHwComposer().getRefreshPeriod(HWC_DISPLAY_PRIMARY); @@ -775,13 +783,16 @@ void SurfaceFlinger::resyncToHardwareVsync() { } } -void SurfaceFlinger::disableHardwareVsync() { +void SurfaceFlinger::disableHardwareVsync(bool makeUnavailable) { Mutex::Autolock _l(mHWVsyncLock); if (mPrimaryHWVsyncEnabled) { eventControl(HWC_DISPLAY_PRIMARY, SurfaceFlinger::EVENT_VSYNC, false); mPrimaryDispSync.endResync(); mPrimaryHWVsyncEnabled = false; } + if (makeUnavailable) { + mHWVsyncAvailable = false; + } } void SurfaceFlinger::onVSyncReceived(int type, nsecs_t timestamp) { @@ -791,7 +802,7 @@ void SurfaceFlinger::onVSyncReceived(int type, nsecs_t timestamp) { if (needsHwVsync) { enableHardwareVsync(); } else { - disableHardwareVsync(); + disableHardwareVsync(false); } } } @@ -933,7 +944,7 @@ void SurfaceFlinger::postComposition() if (mPrimaryDispSync.addPresentFence(presentFence)) { enableHardwareVsync(); } else { - disableHardwareVsync(); + disableHardwareVsync(false); } } @@ -2178,7 +2189,7 @@ void SurfaceFlinger::onScreenAcquired(const sp<const DisplayDevice>& hw) { // FIXME: eventthread only knows about the main display right now mEventThread->onScreenAcquired(); - resyncToHardwareVsync(); + resyncToHardwareVsync(true); } } mVisibleRegionsDirty = true; @@ -2196,6 +2207,8 @@ void SurfaceFlinger::onScreenReleased(const sp<const DisplayDevice>& hw) { int32_t type = hw->getDisplayType(); if (type < DisplayDevice::NUM_BUILTIN_DISPLAY_TYPES) { if (type == DisplayDevice::DISPLAY_PRIMARY) { + disableHardwareVsync(true); // also cancels any in-progress resync + // FIXME: eventthread only knows about the main display right now mEventThread->onScreenReleased(); } diff --git a/services/surfaceflinger/SurfaceFlinger.h b/services/surfaceflinger/SurfaceFlinger.h index f1c19c2..353e7ba 100644 --- a/services/surfaceflinger/SurfaceFlinger.h +++ b/services/surfaceflinger/SurfaceFlinger.h @@ -383,8 +383,8 @@ private: * VSync */ void enableHardwareVsync(); - void disableHardwareVsync(); - void resyncToHardwareVsync(); + void disableHardwareVsync(bool makeUnavailable); + void resyncToHardwareVsync(bool makeAvailable); /* ------------------------------------------------------------------------ * Debugging & dumpsys @@ -467,6 +467,7 @@ private: // protected by mHWVsyncLock Mutex mHWVsyncLock; bool mPrimaryHWVsyncEnabled; + bool mHWVsyncAvailable; /* ------------------------------------------------------------------------ * Feature prototyping |