diff options
| author | 2018-11-02 18:34:07 -0700 | |
|---|---|---|
| committer | 2018-11-02 18:43:01 -0700 | |
| commit | 8e8fe529a69761aad6a84fb8025cebd3673d77db (patch) | |
| tree | 13b8f06e4a81d4318abc98cfea8b90bc968400d0 /services/surfaceflinger/BufferStateLayer.cpp | |
| parent | c39309375b269bce3a68dadd0bc1d5bc29bc57c0 (diff) | |
SF TimeStats: fix a hazard issue
The setAcquireFence and setDesiredTime could happen in between the
splited setLayerName and setPostTime, where setLayerName inserts an
entry but setPostTime actually initializes the structure and waitData
position. This change combine setLayerName and setPostTime again to
eliminate the hazard.
Test: build
Bug: b/118770127
Change-Id: Ia1961cb688bbabf23d88305750e69c9fa41da8dd
Diffstat (limited to 'services/surfaceflinger/BufferStateLayer.cpp')
| -rw-r--r-- | services/surfaceflinger/BufferStateLayer.cpp | 3 | 
1 files changed, 1 insertions, 2 deletions
| diff --git a/services/surfaceflinger/BufferStateLayer.cpp b/services/surfaceflinger/BufferStateLayer.cpp index 5df8ade34e..73098bf2aa 100644 --- a/services/surfaceflinger/BufferStateLayer.cpp +++ b/services/surfaceflinger/BufferStateLayer.cpp @@ -470,8 +470,7 @@ status_t BufferStateLayer::updateTexImage(bool& /*recomputeVisibleRegions*/, nse      }      // TODO(marissaw): properly support mTimeStats -    mTimeStats.setLayerName(layerID, getName().c_str()); -    mTimeStats.setPostTime(layerID, getFrameNumber(), latchTime); +    mTimeStats.setPostTime(layerID, getFrameNumber(), getName().c_str(), latchTime);      mTimeStats.setAcquireFence(layerID, getFrameNumber(), getCurrentFenceTime());      mTimeStats.setLatchTime(layerID, getFrameNumber(), latchTime); |