2021-11-12 03:46:56 +01:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
// Copyright 2021 yuzu Emulator Project
|
|
|
|
// Copyright 2012 The Android Open Source Project
|
|
|
|
// Parts of this implementation were base on:
|
|
|
|
// https://cs.android.com/android/platform/superproject/+/android-5.1.1_r38:frameworks/native/libs/gui/BufferItemConsumer.cpp
|
|
|
|
|
|
|
|
#include "common/assert.h"
|
|
|
|
#include "common/logging/log.h"
|
|
|
|
#include "core/hle/service/nvflinger/buffer_item.h"
|
|
|
|
#include "core/hle/service/nvflinger/buffer_item_consumer.h"
|
|
|
|
#include "core/hle/service/nvflinger/buffer_queue_consumer.h"
|
|
|
|
|
2022-03-20 05:51:16 +01:00
|
|
|
namespace Service::android {
|
2021-11-12 03:46:56 +01:00
|
|
|
|
|
|
|
BufferItemConsumer::BufferItemConsumer(std::unique_ptr<BufferQueueConsumer> consumer_)
|
|
|
|
: ConsumerBase{std::move(consumer_)} {}
|
|
|
|
|
2022-03-20 05:52:08 +01:00
|
|
|
Status BufferItemConsumer::AcquireBuffer(BufferItem* item, std::chrono::nanoseconds present_when,
|
2021-11-12 03:46:56 +01:00
|
|
|
bool wait_for_fence) {
|
|
|
|
if (!item) {
|
|
|
|
return Status::BadValue;
|
|
|
|
}
|
|
|
|
|
2022-03-26 06:59:06 +01:00
|
|
|
std::scoped_lock lock(mutex);
|
2021-11-12 03:46:56 +01:00
|
|
|
|
2022-03-20 05:52:08 +01:00
|
|
|
if (const auto status = AcquireBufferLocked(item, present_when); status != Status::NoError) {
|
2021-11-12 03:46:56 +01:00
|
|
|
if (status != Status::NoBufferAvailable) {
|
|
|
|
LOG_ERROR(Service_NVFlinger, "Failed to acquire buffer: {}", status);
|
|
|
|
}
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (wait_for_fence) {
|
|
|
|
UNIMPLEMENTED();
|
|
|
|
}
|
|
|
|
|
|
|
|
item->graphic_buffer = slots[item->slot].graphic_buffer;
|
|
|
|
|
|
|
|
return Status::NoError;
|
|
|
|
}
|
|
|
|
|
|
|
|
Status BufferItemConsumer::ReleaseBuffer(const BufferItem& item, Fence& release_fence) {
|
2022-03-26 06:59:06 +01:00
|
|
|
std::scoped_lock lock(mutex);
|
2021-11-12 03:46:56 +01:00
|
|
|
|
|
|
|
if (const auto status = AddReleaseFenceLocked(item.buf, item.graphic_buffer, release_fence);
|
|
|
|
status != Status::NoError) {
|
|
|
|
LOG_ERROR(Service_NVFlinger, "Failed to add fence: {}", status);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (const auto status = ReleaseBufferLocked(item.buf, item.graphic_buffer);
|
|
|
|
status != Status::NoError) {
|
|
|
|
LOG_WARNING(Service_NVFlinger, "Failed to release buffer: {}", status);
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Status::NoError;
|
|
|
|
}
|
|
|
|
|
2022-03-20 05:51:16 +01:00
|
|
|
} // namespace Service::android
|