diff options
author | Lioncash <mathew1800@gmail.com> | 2019-02-21 17:31:53 +0100 |
---|---|---|
committer | Lioncash <mathew1800@gmail.com> | 2019-02-22 04:09:46 +0100 |
commit | 90528f132678ea7dfa9ac4588ae2b8c7808d4685 (patch) | |
tree | 57a37cad480b9ec528914a8fc67b699ec8ad016d /src/core/hle/service/nvflinger/nvflinger.cpp | |
parent | service/vi/vi_layer: Convert Layer struct into a class (diff) | |
download | yuzu-90528f132678ea7dfa9ac4588ae2b8c7808d4685.tar yuzu-90528f132678ea7dfa9ac4588ae2b8c7808d4685.tar.gz yuzu-90528f132678ea7dfa9ac4588ae2b8c7808d4685.tar.bz2 yuzu-90528f132678ea7dfa9ac4588ae2b8c7808d4685.tar.lz yuzu-90528f132678ea7dfa9ac4588ae2b8c7808d4685.tar.xz yuzu-90528f132678ea7dfa9ac4588ae2b8c7808d4685.tar.zst yuzu-90528f132678ea7dfa9ac4588ae2b8c7808d4685.zip |
Diffstat (limited to 'src/core/hle/service/nvflinger/nvflinger.cpp')
-rw-r--r-- | src/core/hle/service/nvflinger/nvflinger.cpp | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/src/core/hle/service/nvflinger/nvflinger.cpp b/src/core/hle/service/nvflinger/nvflinger.cpp index 95bb55bbb..56f31e2ac 100644 --- a/src/core/hle/service/nvflinger/nvflinger.cpp +++ b/src/core/hle/service/nvflinger/nvflinger.cpp @@ -78,9 +78,8 @@ std::optional<u64> NVFlinger::CreateLayer(u64 display_id) { const u64 layer_id = next_layer_id++; const u32 buffer_queue_id = next_buffer_queue_id++; - auto buffer_queue = std::make_shared<BufferQueue>(buffer_queue_id, layer_id); - display->CreateLayer(layer_id, buffer_queue); - buffer_queues.emplace_back(std::move(buffer_queue)); + buffer_queues.emplace_back(buffer_queue_id, layer_id); + display->CreateLayer(layer_id, buffer_queues.back()); return layer_id; } @@ -104,9 +103,17 @@ Kernel::SharedPtr<Kernel::ReadableEvent> NVFlinger::FindVsyncEvent(u64 display_i return display->GetVSyncEvent(); } -std::shared_ptr<BufferQueue> NVFlinger::FindBufferQueue(u32 id) const { +BufferQueue& NVFlinger::FindBufferQueue(u32 id) { const auto itr = std::find_if(buffer_queues.begin(), buffer_queues.end(), - [&](const auto& queue) { return queue->GetId() == id; }); + [id](const auto& queue) { return queue.GetId() == id; }); + + ASSERT(itr != buffer_queues.end()); + return *itr; +} + +const BufferQueue& NVFlinger::FindBufferQueue(u32 id) const { + const auto itr = std::find_if(buffer_queues.begin(), buffer_queues.end(), + [id](const auto& queue) { return queue.GetId() == id; }); ASSERT(itr != buffer_queues.end()); return *itr; |