diff options
| -rw-r--r-- | libs/gui/LayerState.cpp | 6 | ||||
| -rw-r--r-- | libs/gui/SurfaceComposerClient.cpp | 14 | ||||
| -rw-r--r-- | libs/gui/include/gui/LayerState.h | 6 | ||||
| -rw-r--r-- | libs/gui/include/gui/SurfaceComposerClient.h | 1 | ||||
| -rw-r--r-- | services/surfaceflinger/BufferStateLayer.cpp | 7 | ||||
| -rw-r--r-- | services/surfaceflinger/CompositionEngine/include/compositionengine/LayerFECompositionState.h | 3 | ||||
| -rw-r--r-- | services/surfaceflinger/CompositionEngine/src/LayerFECompositionState.cpp | 1 | ||||
| -rw-r--r-- | services/surfaceflinger/CompositionEngine/src/OutputLayer.cpp | 3 | ||||
| -rw-r--r-- | services/surfaceflinger/CompositionEngine/tests/OutputLayerTest.cpp | 7 | ||||
| -rw-r--r-- | services/surfaceflinger/Layer.cpp | 12 | ||||
| -rw-r--r-- | services/surfaceflinger/Layer.h | 4 | ||||
| -rw-r--r-- | services/surfaceflinger/SurfaceFlinger.cpp | 3 | 
12 files changed, 64 insertions, 3 deletions
| diff --git a/libs/gui/LayerState.cpp b/libs/gui/LayerState.cpp index 49b669eb3f..9d4d99fddc 100644 --- a/libs/gui/LayerState.cpp +++ b/libs/gui/LayerState.cpp @@ -134,6 +134,7 @@ status_t layer_state_t::write(Parcel& output) const      SAFE_PARCEL(output.writeByte, changeFrameRateStrategy);      SAFE_PARCEL(output.writeUint32, fixedTransformHint);      SAFE_PARCEL(output.writeBool, autoRefresh); +    SAFE_PARCEL(output.writeBool, dimmingEnabled);      SAFE_PARCEL(output.writeUint32, blurRegions.size());      for (auto region : blurRegions) { @@ -243,6 +244,7 @@ status_t layer_state_t::read(const Parcel& input)      SAFE_PARCEL(input.readUint32, &tmpUint32);      fixedTransformHint = static_cast<ui::Transform::RotationFlags>(tmpUint32);      SAFE_PARCEL(input.readBool, &autoRefresh); +    SAFE_PARCEL(input.readBool, &dimmingEnabled);      uint32_t numRegions = 0;      SAFE_PARCEL(input.readUint32, &numRegions); @@ -598,6 +600,10 @@ void layer_state_t::merge(const layer_state_t& other) {          what |= eColorSpaceAgnosticChanged;          colorSpaceAgnostic = other.colorSpaceAgnostic;      } +    if (other.what & eDimmingEnabledChanged) { +        what |= eDimmingEnabledChanged; +        dimmingEnabled = other.dimmingEnabled; +    }      if ((other.what & what) != other.what) {          ALOGE("Unmerged SurfaceComposer Transaction properties. LayerState::merge needs updating? "                "other.what=0x%" PRIX64 " what=0x%" PRIX64 " unmerged flags=0x%" PRIX64, diff --git a/libs/gui/SurfaceComposerClient.cpp b/libs/gui/SurfaceComposerClient.cpp index c916abee33..7182dc7de0 100644 --- a/libs/gui/SurfaceComposerClient.cpp +++ b/libs/gui/SurfaceComposerClient.cpp @@ -1224,6 +1224,20 @@ SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setTrans      return *this;  } +SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setDimmingEnabled( +        const sp<SurfaceControl>& sc, bool dimmingEnabled) { +    layer_state_t* s = getLayerState(sc); +    if (!s) { +        mStatus = BAD_INDEX; +        return *this; +    } +    s->what |= layer_state_t::eDimmingEnabledChanged; +    s->dimmingEnabled = dimmingEnabled; + +    registerSurfaceControlForCallback(sc); +    return *this; +} +  SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setAlpha(          const sp<SurfaceControl>& sc, float alpha) {      layer_state_t* s = getLayerState(sc); diff --git a/libs/gui/include/gui/LayerState.h b/libs/gui/include/gui/LayerState.h index 0f37dab53c..4ca8d68142 100644 --- a/libs/gui/include/gui/LayerState.h +++ b/libs/gui/include/gui/LayerState.h @@ -150,7 +150,7 @@ struct layer_state_t {          eTransparentRegionChanged = 0x00000020,          eFlagsChanged = 0x00000040,          eLayerStackChanged = 0x00000080, -        /* unused 0x00000400, */ +        eDimmingEnabledChanged = 0x00000400,          eShadowRadiusChanged = 0x00000800,          /* unused 0x00001000, */          eBufferCropChanged = 0x00002000, @@ -187,7 +187,7 @@ struct layer_state_t {          eAutoRefreshChanged = 0x1000'00000000,          eStretchChanged = 0x2000'00000000,          eTrustedOverlayChanged = 0x4000'00000000, -        eDropInputModeChanged = 0x8000'00000000, +        eDropInputModeChanged = 0x8000'00000000      };      layer_state_t(); @@ -298,6 +298,8 @@ struct layer_state_t {      // Force inputflinger to drop all input events for the layer and its children.      gui::DropInputMode dropInputMode; + +    bool dimmingEnabled;  };  struct ComposerState { diff --git a/libs/gui/include/gui/SurfaceComposerClient.h b/libs/gui/include/gui/SurfaceComposerClient.h index 9d03f58aa5..0cc43d85bf 100644 --- a/libs/gui/include/gui/SurfaceComposerClient.h +++ b/libs/gui/include/gui/SurfaceComposerClient.h @@ -491,6 +491,7 @@ public:                  uint32_t flags, uint32_t mask);          Transaction& setTransparentRegionHint(const sp<SurfaceControl>& sc,                  const Region& transparentRegion); +        Transaction& setDimmingEnabled(const sp<SurfaceControl>& sc, bool dimmingEnabled);          Transaction& setAlpha(const sp<SurfaceControl>& sc,                  float alpha);          Transaction& setMatrix(const sp<SurfaceControl>& sc, diff --git a/services/surfaceflinger/BufferStateLayer.cpp b/services/surfaceflinger/BufferStateLayer.cpp index bcae8d9564..c5d7a601c5 100644 --- a/services/surfaceflinger/BufferStateLayer.cpp +++ b/services/surfaceflinger/BufferStateLayer.cpp @@ -1098,6 +1098,13 @@ bool BufferStateLayer::simpleBufferUpdate(const layer_state_t& s) const {          }      } +    if (s.what & layer_state_t::eDimmingEnabledChanged) { +        if (mDrawingState.dimmingEnabled != s.dimmingEnabled) { +            ALOGV("%s: false [eDimmingEnabledChanged changed]", __func__); +            return false; +        } +    } +      ALOGV("%s: true", __func__);      return true;  } diff --git a/services/surfaceflinger/CompositionEngine/include/compositionengine/LayerFECompositionState.h b/services/surfaceflinger/CompositionEngine/include/compositionengine/LayerFECompositionState.h index 283fe86f43..974f7c6134 100644 --- a/services/surfaceflinger/CompositionEngine/include/compositionengine/LayerFECompositionState.h +++ b/services/surfaceflinger/CompositionEngine/include/compositionengine/LayerFECompositionState.h @@ -207,6 +207,9 @@ struct LayerFECompositionState {      // framerate of the layer as measured by LayerHistory      float fps; +    // The dimming flag +    bool dimmingEnabled{true}; +      virtual ~LayerFECompositionState();      // Debugging diff --git a/services/surfaceflinger/CompositionEngine/src/LayerFECompositionState.cpp b/services/surfaceflinger/CompositionEngine/src/LayerFECompositionState.cpp index ff7d430531..6631a2772c 100644 --- a/services/surfaceflinger/CompositionEngine/src/LayerFECompositionState.cpp +++ b/services/surfaceflinger/CompositionEngine/src/LayerFECompositionState.cpp @@ -121,6 +121,7 @@ void LayerFECompositionState::dump(std::string& out) const {      dumpVal(out, "isColorspaceAgnostic", isColorspaceAgnostic);      dumpVal(out, "dataspace", toString(dataspace), dataspace);      dumpVal(out, "hdr metadata types", hdrMetadata.validTypes); +    dumpVal(out, "dimming enabled", dimmingEnabled);      dumpVal(out, "colorTransform", colorTransform);      out.append("\n"); diff --git a/services/surfaceflinger/CompositionEngine/src/OutputLayer.cpp b/services/surfaceflinger/CompositionEngine/src/OutputLayer.cpp index 723593d7ac..3289d55870 100644 --- a/services/surfaceflinger/CompositionEngine/src/OutputLayer.cpp +++ b/services/surfaceflinger/CompositionEngine/src/OutputLayer.cpp @@ -324,9 +324,10 @@ void OutputLayer::updateCompositionState(      // For hdr content, treat the white point as the display brightness - HDR content should not be      // boosted or dimmed. +    // If the layer explicitly requests to disable dimming, then don't dim either.      if (isHdrDataspace(state.dataspace) ||          getOutput().getState().displayBrightnessNits == getOutput().getState().sdrWhitePointNits || -        getOutput().getState().displayBrightnessNits == 0.f) { +        getOutput().getState().displayBrightnessNits == 0.f || !layerFEState->dimmingEnabled) {          state.dimmingRatio = 1.f;          state.whitePointNits = getOutput().getState().displayBrightnessNits;      } else { diff --git a/services/surfaceflinger/CompositionEngine/tests/OutputLayerTest.cpp b/services/surfaceflinger/CompositionEngine/tests/OutputLayerTest.cpp index 8eb1946b67..ceee48c1ef 100644 --- a/services/surfaceflinger/CompositionEngine/tests/OutputLayerTest.cpp +++ b/services/surfaceflinger/CompositionEngine/tests/OutputLayerTest.cpp @@ -668,6 +668,13 @@ TEST_F(OutputLayerUpdateCompositionStateTest, setsWhitePointNitsAndDimmingRatioC      EXPECT_EQ(mOutputState.sdrWhitePointNits / mOutputState.displayBrightnessNits,                mOutputLayer.getState().dimmingRatio); +    mLayerFEState.dimmingEnabled = false; +    mOutputLayer.updateCompositionState(false, false, ui::Transform::RotationFlags::ROT_0); +    EXPECT_EQ(mOutputState.displayBrightnessNits, mOutputLayer.getState().whitePointNits); +    EXPECT_EQ(1.f, mOutputLayer.getState().dimmingRatio); + +    // change dimmingEnabled back to true. +    mLayerFEState.dimmingEnabled = true;      mLayerFEState.dataspace = ui::Dataspace::BT2020_ITU_PQ;      mLayerFEState.isColorspaceAgnostic = false;      mOutputLayer.updateCompositionState(false, false, ui::Transform::RotationFlags::ROT_0); diff --git a/services/surfaceflinger/Layer.cpp b/services/surfaceflinger/Layer.cpp index aeaf1e1a14..624d11ec13 100644 --- a/services/surfaceflinger/Layer.cpp +++ b/services/surfaceflinger/Layer.cpp @@ -139,6 +139,7 @@ Layer::Layer(const LayerCreationArgs& args)      mDrawingState.destinationFrame.makeInvalid();      mDrawingState.isTrustedOverlay = false;      mDrawingState.dropInputMode = gui::DropInputMode::NONE; +    mDrawingState.dimmingEnabled = true;      if (args.flags & ISurfaceComposerClient::eNoColorFill) {          // Set an invalid color so there is no color fill. @@ -477,6 +478,7 @@ void Layer::preparePerFrameCompositionState() {      compositionState->colorTransformIsIdentity = !hasColorTransform();      compositionState->surfaceDamage = surfaceDamageRegion;      compositionState->hasProtectedContent = isProtected(); +    compositionState->dimmingEnabled = isDimmingEnabled();      const bool usesRoundedCorners = getRoundedCornerState().radius != 0.f; @@ -1030,6 +1032,16 @@ bool Layer::setColorSpaceAgnostic(const bool agnostic) {      return true;  } +bool Layer::setDimmingEnabled(const bool dimmingEnabled) { +    if (mDrawingState.dimmingEnabled == dimmingEnabled) return false; + +    mDrawingState.sequence++; +    mDrawingState.dimmingEnabled = dimmingEnabled; +    mDrawingState.modified = true; +    setTransactionFlags(eTransactionNeeded); +    return true; +} +  bool Layer::setFrameRateSelectionPriority(int32_t priority) {      if (mDrawingState.frameRateSelectionPriority == priority) return false;      mDrawingState.frameRateSelectionPriority = priority; diff --git a/services/surfaceflinger/Layer.h b/services/surfaceflinger/Layer.h index 48a9bc50c4..1842da45d5 100644 --- a/services/surfaceflinger/Layer.h +++ b/services/surfaceflinger/Layer.h @@ -281,6 +281,8 @@ public:          gui::DropInputMode dropInputMode;          bool autoRefresh = false; + +        bool dimmingEnabled = true;      };      /* @@ -411,6 +413,7 @@ public:      virtual mat4 getColorTransform() const;      virtual bool hasColorTransform() const;      virtual bool isColorSpaceAgnostic() const { return mDrawingState.colorSpaceAgnostic; } +    virtual bool isDimmingEnabled() const { return getDrawingState().dimmingEnabled; };      // Used only to set BufferStateLayer state      virtual bool setTransform(uint32_t /*transform*/) { return false; }; @@ -437,6 +440,7 @@ public:      }      virtual bool setBackgroundColor(const half3& color, float alpha, ui::Dataspace dataspace);      virtual bool setColorSpaceAgnostic(const bool agnostic); +    virtual bool setDimmingEnabled(const bool dimmingEnabled);      virtual bool setFrameRateSelectionPriority(int32_t priority);      virtual bool setFixedTransformHint(ui::Transform::RotationFlags fixedTransformHint);      virtual void setAutoRefresh(bool /* autoRefresh */) {} diff --git a/services/surfaceflinger/SurfaceFlinger.cpp b/services/surfaceflinger/SurfaceFlinger.cpp index bd7fba48c4..3e70ac6680 100644 --- a/services/surfaceflinger/SurfaceFlinger.cpp +++ b/services/surfaceflinger/SurfaceFlinger.cpp @@ -4523,6 +4523,9 @@ uint32_t SurfaceFlinger::setClientStateLocked(const FrameTimelineInfo& frameTime      if (what & layer_state_t::eAutoRefreshChanged) {          layer->setAutoRefresh(s.autoRefresh);      } +    if (what & layer_state_t::eDimmingEnabledChanged) { +        if (layer->setDimmingEnabled(s.dimmingEnabled)) flags |= eTraversalNeeded; +    }      if (what & layer_state_t::eTrustedOverlayChanged) {          if (layer->setTrustedOverlay(s.isTrustedOverlay)) {              flags |= eTraversalNeeded; |