summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Lloyd Pique <lpique@google.com> 2018-12-20 16:23:33 -0800
committer Lloyd Pique <lpique@google.com> 2019-01-07 13:35:19 -0800
commitf2c793939c42ff233ced4095cf85bb93ec74523f (patch)
treeaacfff50dddb82b315b449189e0de89861261836
parent2098e207ff2c9fb1e54a236b649401e6436502f1 (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.cpp18
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;
+ }
}
}