diff options
author | bunnei <bunneidev@gmail.com> | 2018-03-19 01:27:15 +0100 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2018-03-19 01:56:35 +0100 |
commit | c1c92c30f9951e41a2091770cc5bf1354fba7794 (patch) | |
tree | 2304ea66a7dbca1f1848c316976a24203c24a5c6 /src/core/hle/service/vi | |
parent | hle_ipc: Add SleepClientThread to block current thread within HLE routines. (diff) | |
download | yuzu-c1c92c30f9951e41a2091770cc5bf1354fba7794.tar yuzu-c1c92c30f9951e41a2091770cc5bf1354fba7794.tar.gz yuzu-c1c92c30f9951e41a2091770cc5bf1354fba7794.tar.bz2 yuzu-c1c92c30f9951e41a2091770cc5bf1354fba7794.tar.lz yuzu-c1c92c30f9951e41a2091770cc5bf1354fba7794.tar.xz yuzu-c1c92c30f9951e41a2091770cc5bf1354fba7794.tar.zst yuzu-c1c92c30f9951e41a2091770cc5bf1354fba7794.zip |
Diffstat (limited to 'src/core/hle/service/vi')
-rw-r--r-- | src/core/hle/service/vi/vi.cpp | 30 |
1 files changed, 24 insertions, 6 deletions
diff --git a/src/core/hle/service/vi/vi.cpp b/src/core/hle/service/vi/vi.cpp index 0aa621dfe..7b6453447 100644 --- a/src/core/hle/service/vi/vi.cpp +++ b/src/core/hle/service/vi/vi.cpp @@ -486,12 +486,30 @@ private: ctx.WriteBuffer(response.Serialize()); } else if (transaction == TransactionId::DequeueBuffer) { IGBPDequeueBufferRequestParcel request{ctx.ReadBuffer()}; - - u32 slot = buffer_queue->DequeueBuffer(request.data.pixel_format, request.data.width, - request.data.height); - - IGBPDequeueBufferResponseParcel response{slot}; - ctx.WriteBuffer(response.Serialize()); + const u32 width{request.data.width}; + const u32 height{request.data.height}; + boost::optional<u32> slot = buffer_queue->DequeueBuffer(width, height); + + if (slot != boost::none) { + // Buffer is available + IGBPDequeueBufferResponseParcel response{*slot}; + ctx.WriteBuffer(response.Serialize()); + } else { + // Wait the current thread until a buffer becomes available + auto wait_event = ctx.SleepClientThread( + Kernel::GetCurrentThread(), "IHOSBinderDriver::DequeueBuffer", -1, + [=](Kernel::SharedPtr<Kernel::Thread> thread, Kernel::HLERequestContext& ctx, + ThreadWakeupReason reason) { + // Repeat TransactParcel DequeueBuffer when a buffer is available + auto buffer_queue = nv_flinger->GetBufferQueue(id); + boost::optional<u32> slot = buffer_queue->DequeueBuffer(width, height); + IGBPDequeueBufferResponseParcel response{*slot}; + ctx.WriteBuffer(response.Serialize()); + IPC::ResponseBuilder rb{ctx, 2}; + rb.Push(RESULT_SUCCESS); + }); + buffer_queue->SetBufferWaitEvent(std::move(wait_event)); + } } else if (transaction == TransactionId::RequestBuffer) { IGBPRequestBufferRequestParcel request{ctx.ReadBuffer()}; |