NvHost/Core: Address Feedback.
This commit is contained in:
parent
198c6ad0d7
commit
53cf91d151
3 changed files with 27 additions and 19 deletions
|
@ -163,19 +163,19 @@ struct System::Impl {
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
void stallForGPU(bool pause) {
|
std::unique_lock<std::mutex> StallCPU() {
|
||||||
if (pause) {
|
std::unique_lock<std::mutex> lk(suspend_guard);
|
||||||
suspend_guard.lock();
|
kernel.Suspend(true);
|
||||||
kernel.Suspend(pause);
|
core_timing.SyncPause(true);
|
||||||
core_timing.SyncPause(pause);
|
cpu_manager.Pause(true);
|
||||||
cpu_manager.Pause(pause);
|
return lk;
|
||||||
} else {
|
|
||||||
if (!is_paused) {
|
|
||||||
core_timing.SyncPause(pause);
|
|
||||||
kernel.Suspend(pause);
|
|
||||||
cpu_manager.Pause(pause);
|
|
||||||
}
|
}
|
||||||
suspend_guard.unlock();
|
|
||||||
|
void UnstallCPU() {
|
||||||
|
if (!is_paused) {
|
||||||
|
core_timing.SyncPause(false);
|
||||||
|
kernel.Suspend(false);
|
||||||
|
cpu_manager.Pause(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -487,8 +487,12 @@ void System::Shutdown() {
|
||||||
impl->Shutdown();
|
impl->Shutdown();
|
||||||
}
|
}
|
||||||
|
|
||||||
void System::stallForGPU(bool pause) {
|
std::unique_lock<std::mutex> System::StallCPU() {
|
||||||
impl->stallForGPU(pause);
|
return impl->StallCPU();
|
||||||
|
}
|
||||||
|
|
||||||
|
void System::UnstallCPU() {
|
||||||
|
impl->UnstallCPU();
|
||||||
}
|
}
|
||||||
|
|
||||||
SystemResultStatus System::Load(Frontend::EmuWindow& emu_window, const std::string& filepath,
|
SystemResultStatus System::Load(Frontend::EmuWindow& emu_window, const std::string& filepath,
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
#include <mutex>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
@ -160,7 +161,8 @@ public:
|
||||||
/// Shutdown the emulated system.
|
/// Shutdown the emulated system.
|
||||||
void Shutdown();
|
void Shutdown();
|
||||||
|
|
||||||
void stallForGPU(bool pause);
|
std::unique_lock<std::mutex> StallCPU();
|
||||||
|
void UnstallCPU();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load an executable application.
|
* Load an executable application.
|
||||||
|
|
|
@ -150,9 +150,11 @@ NvResult nvhost_ctrl::IocCtrlEventWait(const std::vector<u8>& input, std::vector
|
||||||
params.value |= event_id;
|
params.value |= event_id;
|
||||||
event.event->GetWritableEvent().Clear();
|
event.event->GetWritableEvent().Clear();
|
||||||
if (events_interface.failed[event_id]) {
|
if (events_interface.failed[event_id]) {
|
||||||
system.stallForGPU(true);
|
{
|
||||||
|
auto lk = system.StallCPU();
|
||||||
gpu.WaitFence(params.syncpt_id, target_value);
|
gpu.WaitFence(params.syncpt_id, target_value);
|
||||||
system.stallForGPU(false);
|
system.UnstallCPU();
|
||||||
|
}
|
||||||
std::memcpy(output.data(), ¶ms, sizeof(params));
|
std::memcpy(output.data(), ¶ms, sizeof(params));
|
||||||
events_interface.failed[event_id] = false;
|
events_interface.failed[event_id] = false;
|
||||||
return NvResult::Success;
|
return NvResult::Success;
|
||||||
|
|
Loading…
Reference in a new issue