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

Commit 357e39a7 authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Android (Google) Code Review
Browse files

Merge "FramebufferSurface: fix for limitFramebufferSize" into sc-dev

parents bcf94191 4a92f55e
Loading
Loading
Loading
Loading
+13 −9
Original line number Diff line number Diff line
@@ -76,14 +76,14 @@ FramebufferSurface::FramebufferSurface(HWComposer& hwc, PhysicalDisplayId displa
    mConsumer->setConsumerUsageBits(GRALLOC_USAGE_HW_FB |
                                       GRALLOC_USAGE_HW_RENDER |
                                       GRALLOC_USAGE_HW_COMPOSER);
    const auto limitedSize = limitFramebufferSize(size);
    const auto limitedSize = limitSize(size);
    mConsumer->setDefaultBufferSize(limitedSize.width, limitedSize.height);
    mConsumer->setMaxAcquiredBufferCount(
            SurfaceFlinger::maxFrameBufferAcquiredBuffers - 1);
}

void FramebufferSurface::resizeBuffers(const ui::Size& newSize) {
    const auto limitedSize = limitFramebufferSize(newSize);
    const auto limitedSize = limitSize(newSize);
    mConsumer->setDefaultBufferSize(limitedSize.width, limitedSize.height);
}

@@ -179,19 +179,23 @@ void FramebufferSurface::onFrameCommitted() {
    }
}

ui::Size FramebufferSurface::limitFramebufferSize(const ui::Size& size) {
ui::Size FramebufferSurface::limitSize(const ui::Size& size) {
    return limitSizeInternal(size, mMaxSize);
}

ui::Size FramebufferSurface::limitSizeInternal(const ui::Size& size, const ui::Size& maxSize) {
    ui::Size limitedSize = size;
    bool wasLimited = false;
    if (size.width > mMaxSize.width && mMaxSize.width != 0) {
    if (size.width > maxSize.width && maxSize.width != 0) {
        const float aspectRatio = static_cast<float>(size.width) / size.height;
        limitedSize.height = mMaxSize.width / aspectRatio;
        limitedSize.width = mMaxSize.width;
        limitedSize.height = maxSize.width / aspectRatio;
        limitedSize.width = maxSize.width;
        wasLimited = true;
    }
    if (size.height > mMaxSize.height && mMaxSize.height != 0) {
    if (limitedSize.height > maxSize.height && maxSize.height != 0) {
        const float aspectRatio = static_cast<float>(size.width) / size.height;
        limitedSize.height = mMaxSize.height;
        limitedSize.width = mMaxSize.height * aspectRatio;
        limitedSize.height = maxSize.height;
        limitedSize.width = maxSize.height * aspectRatio;
        wasLimited = true;
    }
    ALOGI_IF(wasLimited, "framebuffer size has been limited to [%dx%d] from [%dx%d]",
+8 −3
Original line number Diff line number Diff line
@@ -55,15 +55,20 @@ public:
    virtual const sp<Fence>& getClientTargetAcquireFence() const override;

private:
    friend class FramebufferSurfaceTest;

    // Limits the width and height by the maximum width specified.
    ui::Size limitSize(const ui::Size&);

    // Used for testing purposes.
    static ui::Size limitSizeInternal(const ui::Size&, const ui::Size& maxSize);

    virtual ~FramebufferSurface() { }; // this class cannot be overloaded

    virtual void freeBufferLocked(int slotIndex);

    virtual void dumpLocked(String8& result, const char* prefix) const;

    // Limits the width and height by the maximum width specified in the constructor.
    ui::Size limitFramebufferSize(const ui::Size&);

    // nextBuffer waits for and then latches the next buffer from the
    // BufferQueue and releases the previously latched buffer to the
    // BufferQueue.  The new buffer is returned in the 'buffer' argument.
+1 −0
Original line number Diff line number Diff line
@@ -55,6 +55,7 @@ cc_test {
        "EventThreadTest.cpp",
        "FpsReporterTest.cpp",
        "FpsTest.cpp",
        "FramebufferSurfaceTest.cpp",
        "FrameTimelineTest.cpp",
        "HWComposerTest.cpp",
        "OneShotTimerTest.cpp",
+40 −0
Original line number Diff line number Diff line
/*
 * Copyright 2021 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include "DisplayHardware/FramebufferSurface.h"

#include <gmock/gmock.h>
#include <gtest/gtest.h>

namespace android {

class FramebufferSurfaceTest : public testing::Test {
public:
    ui::Size limitSize(const ui::Size& size, const ui::Size maxSize) {
        return FramebufferSurface::limitSizeInternal(size, maxSize);
    }
};

TEST_F(FramebufferSurfaceTest, limitSize) {
    const ui::Size kMaxSize(1920, 1080);
    EXPECT_EQ(ui::Size(1920, 1080), limitSize({3840, 2160}, kMaxSize));
    EXPECT_EQ(ui::Size(1920, 1080), limitSize({1920, 1080}, kMaxSize));
    EXPECT_EQ(ui::Size(1920, 1012), limitSize({4096, 2160}, kMaxSize));
    EXPECT_EQ(ui::Size(1080, 1080), limitSize({3840, 3840}, kMaxSize));
    EXPECT_EQ(ui::Size(1280, 720), limitSize({1280, 720}, kMaxSize));
}

} // namespace android