diff options
Diffstat (limited to 'services')
| -rw-r--r-- | services/surfaceflinger/SurfaceFlinger.cpp | 6 | ||||
| -rw-r--r-- | services/surfaceflinger/SurfaceFlinger_hwc1.cpp | 6 | 
2 files changed, 8 insertions, 4 deletions
| diff --git a/services/surfaceflinger/SurfaceFlinger.cpp b/services/surfaceflinger/SurfaceFlinger.cpp index 7392006c6f..ee63ebcb9c 100644 --- a/services/surfaceflinger/SurfaceFlinger.cpp +++ b/services/surfaceflinger/SurfaceFlinger.cpp @@ -3210,7 +3210,8 @@ void SurfaceFlinger::setPowerModeInternal(const sp<DisplayDevice>& hw,              ALOGW("Couldn't set SCHED_OTHER on display off");          } -        if (type == DisplayDevice::DISPLAY_PRIMARY) { +        if (type == DisplayDevice::DISPLAY_PRIMARY && +            currentMode != HWC_POWER_MODE_DOZE_SUSPEND) {              disableHardwareVsync(true); // also cancels any in-progress resync              // FIXME: eventthread only knows about the main display right now @@ -3224,7 +3225,8 @@ void SurfaceFlinger::setPowerModeInternal(const sp<DisplayDevice>& hw,                 mode == HWC_POWER_MODE_NORMAL) {          // Update display while dozing          getHwComposer().setPowerMode(type, mode); -        if (type == DisplayDevice::DISPLAY_PRIMARY) { +        if (type == DisplayDevice::DISPLAY_PRIMARY && +            currentMode == HWC_POWER_MODE_DOZE_SUSPEND) {              // FIXME: eventthread only knows about the main display right now              mEventThread->onScreenAcquired();              resyncToHardwareVsync(true); diff --git a/services/surfaceflinger/SurfaceFlinger_hwc1.cpp b/services/surfaceflinger/SurfaceFlinger_hwc1.cpp index 0b3a0d0d38..43cf99898a 100644 --- a/services/surfaceflinger/SurfaceFlinger_hwc1.cpp +++ b/services/surfaceflinger/SurfaceFlinger_hwc1.cpp @@ -2869,7 +2869,8 @@ void SurfaceFlinger::setPowerModeInternal(const sp<DisplayDevice>& hw,              ALOGW("Couldn't set SCHED_OTHER on display off");          } -        if (type == DisplayDevice::DISPLAY_PRIMARY) { +        if (type == DisplayDevice::DISPLAY_PRIMARY && +            currentMode != HWC_POWER_MODE_DOZE_SUSPEND) {              disableHardwareVsync(true); // also cancels any in-progress resync              // FIXME: eventthread only knows about the main display right now @@ -2883,7 +2884,8 @@ void SurfaceFlinger::setPowerModeInternal(const sp<DisplayDevice>& hw,                 mode == HWC_POWER_MODE_NORMAL) {          // Update display while dozing          getHwComposer().setPowerMode(type, mode); -        if (type == DisplayDevice::DISPLAY_PRIMARY) { +        if (type == DisplayDevice::DISPLAY_PRIMARY && +            currentMode == HWC_POWER_MODE_DOZE_SUSPEND) {              // FIXME: eventthread only knows about the main display right now              mEventThread->onScreenAcquired();              resyncToHardwareVsync(true); |