Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 692e0834 authored by Chia-I Wu's avatar Chia-I Wu
Browse files

surfaceflinger: force client composition for Y410

When the pixel format is Y410 masquerading as RGBA_1010102, always
force client composition.

Bug: 80509363
Test: no effect on Pixel devices
Change-Id: I31996eeda1559b0557a5acb53d593fd4f395ccaf
parent 169dd11c
Loading
Loading
Loading
Loading
+8 −3
Original line number Diff line number Diff line
@@ -803,6 +803,13 @@ bool BufferLayer::getOpacityForFormat(uint32_t format) {
    return true;
}

bool BufferLayer::isHdrY410() const {
    // pixel format is HDR Y410 masquerading as RGBA_1010102
    return (mCurrentDataSpace == ui::Dataspace::BT2020_ITU_PQ &&
            mConsumer->getCurrentApi() == NATIVE_WINDOW_API_MEDIA &&
            getBE().compositionInfo.mBuffer->getPixelFormat() == HAL_PIXEL_FORMAT_RGBA_1010102);
}

void BufferLayer::drawWithOpenGL(const RenderArea& renderArea, bool useIdentityTransform) const {
    ATRACE_CALL();
    const State& s(getDrawingState());
@@ -856,9 +863,7 @@ void BufferLayer::drawWithOpenGL(const RenderArea& renderArea, bool useIdentityT
                              getColor());
    engine.setSourceDataSpace(mCurrentDataSpace);

    if (mCurrentDataSpace == ui::Dataspace::BT2020_ITU_PQ &&
        mConsumer->getCurrentApi() == NATIVE_WINDOW_API_MEDIA &&
        getBE().compositionInfo.mBuffer->getPixelFormat() == HAL_PIXEL_FORMAT_RGBA_1010102) {
    if (isHdrY410()) {
        engine.setSourceY410BT2020(true);
    }

+2 −0
Original line number Diff line number Diff line
@@ -129,6 +129,8 @@ public:
    bool isBufferLatched() const override { return mRefreshPending; }
    void setDefaultBufferSize(uint32_t w, uint32_t h) override;

    bool isHdrY410() const override;

    void setPerFrameData(const sp<const DisplayDevice>& display) override;

    bool isOpaque(const Layer::State& s) const override;
+2 −0
Original line number Diff line number Diff line
@@ -315,6 +315,8 @@ protected:
public:
    virtual void setDefaultBufferSize(uint32_t /*w*/, uint32_t /*h*/) {}

    virtual bool isHdrY410() const { return false; }

    void setGeometry(const sp<const DisplayDevice>& display, uint32_t z);
    void forceClientComposition(int32_t displayId);
    bool getForceClientComposition(int32_t displayId);
+8 −7
Original line number Diff line number Diff line
@@ -1950,12 +1950,13 @@ void SurfaceFlinger::setUpHWComposer() {
                     displayId, result);
        }
        for (auto& layer : display->getVisibleLayersSortedByZ()) {
            if ((layer->getDataSpace() == Dataspace::BT2020_PQ ||
            if (layer->isHdrY410()) {
                layer->forceClientComposition(displayId);
            } else if ((layer->getDataSpace() == Dataspace::BT2020_PQ ||
                        layer->getDataSpace() == Dataspace::BT2020_ITU_PQ) &&
                    !display->hasHDR10Support()) {
                layer->forceClientComposition(displayId);
            }
            if ((layer->getDataSpace() == Dataspace::BT2020_HLG ||
            } else if ((layer->getDataSpace() == Dataspace::BT2020_HLG ||
                        layer->getDataSpace() == Dataspace::BT2020_ITU_HLG) &&
                    !display->hasHLGSupport()) {
                layer->forceClientComposition(displayId);