mirror of
https://git.h3cjp.net/H3cJP/citra.git
synced 2024-12-31 23:46:47 +00:00
nvdrv: Cleanup CDMA Processor on device closure
Brings us a step closer to unifying all channels to share a common interface.
This commit is contained in:
parent
f234531f92
commit
bf1c1788ca
|
@ -32,11 +32,6 @@ NvResult nvhost_nvdec::Ioctl1(DeviceFD fd, Ioctl command, const std::vector<u8>&
|
||||||
case 0x9:
|
case 0x9:
|
||||||
return MapBuffer(input, output);
|
return MapBuffer(input, output);
|
||||||
case 0xa: {
|
case 0xa: {
|
||||||
if (command.length == 0x1c) {
|
|
||||||
LOG_INFO(Service_NVDRV, "NVDEC video stream ended");
|
|
||||||
Tegra::ChCommandHeaderList cmdlist{{0xDEADB33F}};
|
|
||||||
system.GPU().PushCommandBuffer(cmdlist);
|
|
||||||
}
|
|
||||||
return UnmapBuffer(input, output);
|
return UnmapBuffer(input, output);
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
@ -70,6 +65,9 @@ NvResult nvhost_nvdec::Ioctl3(DeviceFD fd, Ioctl command, const std::vector<u8>&
|
||||||
}
|
}
|
||||||
|
|
||||||
void nvhost_nvdec::OnOpen(DeviceFD fd) {}
|
void nvhost_nvdec::OnOpen(DeviceFD fd) {}
|
||||||
void nvhost_nvdec::OnClose(DeviceFD fd) {}
|
|
||||||
|
void nvhost_nvdec::OnClose(DeviceFD fd) {
|
||||||
|
system.GPU().ClearCommandBuffer();
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Service::Nvidia::Devices
|
} // namespace Service::Nvidia::Devices
|
||||||
|
|
|
@ -480,11 +480,7 @@ void GPU::PushCommandBuffer(Tegra::ChCommandHeaderList& entries) {
|
||||||
if (!use_nvdec) {
|
if (!use_nvdec) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// This condition fires when a video stream ends, clear all intermediary data
|
|
||||||
if (entries[0].raw == 0xDEADB33F) {
|
|
||||||
cdma_pusher.reset();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (!cdma_pusher) {
|
if (!cdma_pusher) {
|
||||||
cdma_pusher = std::make_unique<Tegra::CDmaPusher>(*this);
|
cdma_pusher = std::make_unique<Tegra::CDmaPusher>(*this);
|
||||||
}
|
}
|
||||||
|
@ -496,6 +492,13 @@ void GPU::PushCommandBuffer(Tegra::ChCommandHeaderList& entries) {
|
||||||
cdma_pusher->ProcessEntries(std::move(entries));
|
cdma_pusher->ProcessEntries(std::move(entries));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GPU::ClearCommandBuffer() {
|
||||||
|
// This condition fires when a video stream ends, clear all intermediary data
|
||||||
|
if (cdma_pusher) {
|
||||||
|
cdma_pusher.reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void GPU::SwapBuffers(const Tegra::FramebufferConfig* framebuffer) {
|
void GPU::SwapBuffers(const Tegra::FramebufferConfig* framebuffer) {
|
||||||
gpu_thread.SwapBuffers(framebuffer);
|
gpu_thread.SwapBuffers(framebuffer);
|
||||||
}
|
}
|
||||||
|
|
|
@ -324,6 +324,9 @@ public:
|
||||||
/// Push GPU command buffer entries to be processed
|
/// Push GPU command buffer entries to be processed
|
||||||
void PushCommandBuffer(Tegra::ChCommandHeaderList& entries);
|
void PushCommandBuffer(Tegra::ChCommandHeaderList& entries);
|
||||||
|
|
||||||
|
/// Frees the CDMAPusher to free up resources
|
||||||
|
void ClearCommandBuffer();
|
||||||
|
|
||||||
/// Swap buffers (render frame)
|
/// Swap buffers (render frame)
|
||||||
void SwapBuffers(const Tegra::FramebufferConfig* framebuffer);
|
void SwapBuffers(const Tegra::FramebufferConfig* framebuffer);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue