diff options
author | 2018-12-20 16:23:33 -0800 | |
---|---|---|
committer | 2019-01-07 13:35:19 -0800 | |
commit | f2c793939c42ff233ced4095cf85bb93ec74523f (patch) | |
tree | aacfff50dddb82b315b449189e0de89861261836 | |
parent | 2098e207ff2c9fb1e54a236b649401e6436502f1 (diff) |
SF: Latching buffers requires holding mStateLock
Bug: 119481871
Test: SurfaceFlinger unit tests
Test: go/wm-smoke
Change-Id: I036b2cd1ae096a62542088b19608e43cbcceb120
-rw-r--r-- | services/surfaceflinger/SurfaceFlinger.cpp | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/services/surfaceflinger/SurfaceFlinger.cpp b/services/surfaceflinger/SurfaceFlinger.cpp index 13997bea21..1b31674d03 100644 --- a/services/surfaceflinger/SurfaceFlinger.cpp +++ b/services/surfaceflinger/SurfaceFlinger.cpp @@ -3002,12 +3002,18 @@ bool SurfaceFlinger::handlePageFlip() } }); - for (auto& layer : mLayersWithQueuedFrames) { - const Region dirty(layer->latchBuffer(visibleRegions, latchTime, getBE().flushFence)); - layer->useSurfaceDamage(); - invalidateLayerStack(layer, dirty); - if (layer->isBufferLatched()) { - newDataLatched = true; + if (!mLayersWithQueuedFrames.empty()) { + // mStateLock is needed for latchBuffer as LayerRejecter::reject() + // writes to Layer current state. See also b/119481871 + Mutex::Autolock lock(mStateLock); + + for (auto& layer : mLayersWithQueuedFrames) { + const Region dirty(layer->latchBuffer(visibleRegions, latchTime, getBE().flushFence)); + layer->useSurfaceDamage(); + invalidateLayerStack(layer, dirty); + if (layer->isBufferLatched()) { + newDataLatched = true; + } } } |