diff options
| author | 2023-01-21 16:58:22 -0500 | |
|---|---|---|
| committer | 2023-01-30 13:44:19 -0500 | |
| commit | 63f127947bcb0275d2c75fdb25fe7ba8f30fecbc (patch) | |
| tree | 8389c657da64608fe012c518d7c96a962467f70f /services/surfaceflinger/SurfaceFlinger.cpp | |
| parent | dff1554cc8c39f4a64e74a50c0371bd0b794239f (diff) | |
SF: Bundle ftl::Flags for CompositionCoverage
...as they will later be passed to Scheduler via ICompositor. For now,
extract ICompositor to its own header, alongside CompositionCoverage.
Bug: 241285475
Bug: 241285191
Test: Frame misses are still traced.
Change-Id: I1562893c9357a02aa42516e775700065b9b17e4b
Diffstat (limited to 'services/surfaceflinger/SurfaceFlinger.cpp')
| -rw-r--r-- | services/surfaceflinger/SurfaceFlinger.cpp | 64 | 
1 files changed, 38 insertions, 26 deletions
| diff --git a/services/surfaceflinger/SurfaceFlinger.cpp b/services/surfaceflinger/SurfaceFlinger.cpp index 7d0dc93cf9..0dc8b05993 100644 --- a/services/surfaceflinger/SurfaceFlinger.cpp +++ b/services/surfaceflinger/SurfaceFlinger.cpp @@ -408,15 +408,8 @@ SurfaceFlinger::SurfaceFlinger(Factory& factory) : SurfaceFlinger(factory, SkipI      mDebugFlashDelay = base::GetUintProperty("debug.sf.showupdates"s, 0u); -    // DDMS debugging deprecated (b/120782499) -    property_get("debug.sf.ddms", value, "0"); -    int debugDdms = atoi(value); -    ALOGI_IF(debugDdms, "DDMS debugging not supported"); - -    property_get("debug.sf.enable_gl_backpressure", value, "1"); -    mPropagateBackpressureClientComposition = atoi(value); -    ALOGI_IF(mPropagateBackpressureClientComposition, -             "Enabling backpressure propagation for Client Composition"); +    mBackpressureGpuComposition = base::GetBoolProperty("debug.sf.enable_gl_backpressure"s, true); +    ALOGI_IF(mBackpressureGpuComposition, "Enabling backpressure for GPU composition");      property_get("ro.surface_flinger.supports_background_blur", value, "0");      bool supportsBlurs = atoi(value); @@ -2155,11 +2148,11 @@ bool SurfaceFlinger::commit(TimePoint frameTime, VsyncId vsyncId, TimePoint expe      const Period vsyncPeriod = mScheduler->getVsyncSchedule().period();      const FenceTimePtr& previousPresentFence = getPreviousPresentFence(frameTime, vsyncPeriod); -    // When Backpressure propagation is enabled we want to give a small grace period +    // When backpressure propagation is enabled, we want to give a small grace period of 1ms      // for the present fence to fire instead of just giving up on this frame to handle cases      // where present fence is just about to get signaled. -    const int graceTimeForPresentFenceMs = -            (mPropagateBackpressureClientComposition || !mHadClientComposition) ? 1 : 0; +    const int graceTimeForPresentFenceMs = static_cast<int>( +            mBackpressureGpuComposition || !mCompositionCoverage.test(CompositionCoverage::Gpu));      // Pending frames may trigger backpressure propagation.      const TracedOrdinal<bool> framePending = {"PrevFramePending", @@ -2182,9 +2175,14 @@ bool SurfaceFlinger::commit(TimePoint frameTime, VsyncId vsyncId, TimePoint expe                                                        (lastScheduledPresentTime.ns() <                                                         previousPresentTime - frameMissedSlop))};      const TracedOrdinal<bool> hwcFrameMissed = {"PrevHwcFrameMissed", -                                                mHadDeviceComposition && frameMissed}; +                                                frameMissed && +                                                        mCompositionCoverage.test( +                                                                CompositionCoverage::Hwc)}; +      const TracedOrdinal<bool> gpuFrameMissed = {"PrevGpuFrameMissed", -                                                mHadClientComposition && frameMissed}; +                                                frameMissed && +                                                        mCompositionCoverage.test( +                                                                CompositionCoverage::Gpu)};      if (frameMissed) {          mFrameMissedCount++; @@ -2222,7 +2220,7 @@ bool SurfaceFlinger::commit(TimePoint frameTime, VsyncId vsyncId, TimePoint expe      }      if (framePending) { -        if ((hwcFrameMissed && !gpuFrameMissed) || mPropagateBackpressureClientComposition) { +        if (mBackpressureGpuComposition || (hwcFrameMissed && !gpuFrameMissed)) {              scheduleCommit(FrameHint::kNone);              return false;          } @@ -2459,29 +2457,43 @@ void SurfaceFlinger::composite(TimePoint frameTime, VsyncId vsyncId)      postComposition(presentTime); -    const bool prevFrameHadClientComposition = mHadClientComposition; +    const bool hadGpuComposited = mCompositionCoverage.test(CompositionCoverage::Gpu); +    mCompositionCoverage.clear(); -    mHadClientComposition = mHadDeviceComposition = mReusedClientComposition = false;      TimeStats::ClientCompositionRecord clientCompositionRecord;      for (const auto& [_, display] : displays) {          const auto& state = display->getCompositionDisplay()->getState(); -        mHadClientComposition |= state.usesClientComposition && !state.reusedClientComposition; -        mHadDeviceComposition |= state.usesDeviceComposition; -        mReusedClientComposition |= state.reusedClientComposition; + +        if (state.usesDeviceComposition) { +            mCompositionCoverage |= CompositionCoverage::Hwc; +        } + +        if (state.reusedClientComposition) { +            mCompositionCoverage |= CompositionCoverage::GpuReuse; +        } else if (state.usesClientComposition) { +            mCompositionCoverage |= CompositionCoverage::Gpu; +        } +          clientCompositionRecord.predicted |=                  (state.strategyPrediction != CompositionStrategyPredictionState::DISABLED);          clientCompositionRecord.predictionSucceeded |=                  (state.strategyPrediction == CompositionStrategyPredictionState::SUCCESS);      } -    clientCompositionRecord.hadClientComposition = mHadClientComposition; -    clientCompositionRecord.reused = mReusedClientComposition; -    clientCompositionRecord.changed = prevFrameHadClientComposition != mHadClientComposition; +    const bool hasGpuComposited = mCompositionCoverage.test(CompositionCoverage::Gpu); + +    clientCompositionRecord.hadClientComposition = hasGpuComposited; +    clientCompositionRecord.reused = mCompositionCoverage.test(CompositionCoverage::GpuReuse); +    clientCompositionRecord.changed = hadGpuComposited != hasGpuComposited; +      mTimeStats->pushCompositionStrategyState(clientCompositionRecord); -    // TODO: b/160583065 Enable skip validation when SF caches all client composition layers -    const bool usedGpuComposition = mHadClientComposition || mReusedClientComposition; -    mScheduler->modulateVsync(&VsyncModulator::onDisplayRefresh, usedGpuComposition); +    using namespace ftl::flag_operators; + +    // TODO(b/160583065): Enable skip validation when SF caches all client composition layers. +    const bool hasGpuUseOrReuse = +            mCompositionCoverage.any(CompositionCoverage::Gpu | CompositionCoverage::GpuReuse); +    mScheduler->modulateVsync(&VsyncModulator::onDisplayRefresh, hasGpuUseOrReuse);      mLayersWithQueuedFrames.clear();      if (mLayerTracingEnabled && mLayerTracing.flagIsSet(LayerTracing::TRACE_COMPOSITION)) { |