forked from suyu/suyu
general: rename CurrentProcess to ApplicationProcess
This commit is contained in:
parent
4363ca304a
commit
ceda2d280e
41 changed files with 169 additions and 164 deletions
|
@ -127,7 +127,7 @@ Result System::Initialize(const AudioRendererParameterInternal& params,
|
||||||
render_device = params.rendering_device;
|
render_device = params.rendering_device;
|
||||||
execution_mode = params.execution_mode;
|
execution_mode = params.execution_mode;
|
||||||
|
|
||||||
core.Memory().ZeroBlock(*core.Kernel().CurrentProcess(), transfer_memory->GetSourceAddress(),
|
core.Memory().ZeroBlock(*core.ApplicationProcess(), transfer_memory->GetSourceAddress(),
|
||||||
transfer_memory_size);
|
transfer_memory_size);
|
||||||
|
|
||||||
// Note: We're not actually using the transfer memory because it's a pain to code for.
|
// Note: We're not actually using the transfer memory because it's a pain to code for.
|
||||||
|
|
|
@ -270,7 +270,7 @@ void SinkStream::Stall() {
|
||||||
if (stalled_lock) {
|
if (stalled_lock) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
stalled_lock = system.StallProcesses();
|
stalled_lock = system.StallApplication();
|
||||||
}
|
}
|
||||||
|
|
||||||
void SinkStream::Unstall() {
|
void SinkStream::Unstall() {
|
||||||
|
@ -278,7 +278,7 @@ void SinkStream::Unstall() {
|
||||||
if (!stalled_lock) {
|
if (!stalled_lock) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
system.UnstallProcesses();
|
system.UnstallApplication();
|
||||||
stalled_lock.unlock();
|
stalled_lock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,9 +43,9 @@ void ARM_Interface::SymbolicateBacktrace(Core::System& system, std::vector<Backt
|
||||||
|
|
||||||
std::map<std::string, Symbols::Symbols> symbols;
|
std::map<std::string, Symbols::Symbols> symbols;
|
||||||
for (const auto& module : modules) {
|
for (const auto& module : modules) {
|
||||||
symbols.insert_or_assign(module.second,
|
symbols.insert_or_assign(
|
||||||
Symbols::GetSymbols(module.first, system.Memory(),
|
module.second, Symbols::GetSymbols(module.first, system.Memory(),
|
||||||
system.CurrentProcess()->Is64BitProcess()));
|
system.ApplicationProcess()->Is64BitProcess()));
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto& entry : out) {
|
for (auto& entry : out) {
|
||||||
|
|
|
@ -186,7 +186,7 @@ struct System::Impl {
|
||||||
void Run() {
|
void Run() {
|
||||||
std::unique_lock<std::mutex> lk(suspend_guard);
|
std::unique_lock<std::mutex> lk(suspend_guard);
|
||||||
|
|
||||||
kernel.Suspend(false);
|
kernel.SuspendApplication(false);
|
||||||
core_timing.SyncPause(false);
|
core_timing.SyncPause(false);
|
||||||
is_paused.store(false, std::memory_order_relaxed);
|
is_paused.store(false, std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
|
@ -195,7 +195,7 @@ struct System::Impl {
|
||||||
std::unique_lock<std::mutex> lk(suspend_guard);
|
std::unique_lock<std::mutex> lk(suspend_guard);
|
||||||
|
|
||||||
core_timing.SyncPause(true);
|
core_timing.SyncPause(true);
|
||||||
kernel.Suspend(true);
|
kernel.SuspendApplication(true);
|
||||||
is_paused.store(true, std::memory_order_relaxed);
|
is_paused.store(true, std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -203,17 +203,17 @@ struct System::Impl {
|
||||||
return is_paused.load(std::memory_order_relaxed);
|
return is_paused.load(std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_lock<std::mutex> StallProcesses() {
|
std::unique_lock<std::mutex> StallApplication() {
|
||||||
std::unique_lock<std::mutex> lk(suspend_guard);
|
std::unique_lock<std::mutex> lk(suspend_guard);
|
||||||
kernel.Suspend(true);
|
kernel.SuspendApplication(true);
|
||||||
core_timing.SyncPause(true);
|
core_timing.SyncPause(true);
|
||||||
return lk;
|
return lk;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UnstallProcesses() {
|
void UnstallApplication() {
|
||||||
if (!IsPaused()) {
|
if (!IsPaused()) {
|
||||||
core_timing.SyncPause(false);
|
core_timing.SyncPause(false);
|
||||||
kernel.Suspend(false);
|
kernel.SuspendApplication(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -221,7 +221,7 @@ struct System::Impl {
|
||||||
debugger = std::make_unique<Debugger>(system, port);
|
debugger = std::make_unique<Debugger>(system, port);
|
||||||
}
|
}
|
||||||
|
|
||||||
SystemResultStatus SetupForMainProcess(System& system, Frontend::EmuWindow& emu_window) {
|
SystemResultStatus SetupForApplicationProcess(System& system, Frontend::EmuWindow& emu_window) {
|
||||||
LOG_DEBUG(Core, "initialized OK");
|
LOG_DEBUG(Core, "initialized OK");
|
||||||
|
|
||||||
// Setting changes may require a full system reinitialization (e.g., disabling multicore).
|
// Setting changes may require a full system reinitialization (e.g., disabling multicore).
|
||||||
|
@ -273,7 +273,7 @@ struct System::Impl {
|
||||||
return SystemResultStatus::ErrorGetLoader;
|
return SystemResultStatus::ErrorGetLoader;
|
||||||
}
|
}
|
||||||
|
|
||||||
SystemResultStatus init_result{SetupForMainProcess(system, emu_window)};
|
SystemResultStatus init_result{SetupForApplicationProcess(system, emu_window)};
|
||||||
if (init_result != SystemResultStatus::Success) {
|
if (init_result != SystemResultStatus::Success) {
|
||||||
LOG_CRITICAL(Core, "Failed to initialize system (Error {})!",
|
LOG_CRITICAL(Core, "Failed to initialize system (Error {})!",
|
||||||
static_cast<int>(init_result));
|
static_cast<int>(init_result));
|
||||||
|
@ -302,7 +302,7 @@ struct System::Impl {
|
||||||
static_cast<u32>(SystemResultStatus::ErrorLoader) + static_cast<u32>(load_result));
|
static_cast<u32>(SystemResultStatus::ErrorLoader) + static_cast<u32>(load_result));
|
||||||
}
|
}
|
||||||
AddGlueRegistrationForProcess(*app_loader, *main_process);
|
AddGlueRegistrationForProcess(*app_loader, *main_process);
|
||||||
kernel.MakeCurrentProcess(main_process);
|
kernel.MakeApplicationProcess(main_process);
|
||||||
kernel.InitializeCores();
|
kernel.InitializeCores();
|
||||||
|
|
||||||
// Initialize cheat engine
|
// Initialize cheat engine
|
||||||
|
@ -585,12 +585,12 @@ void System::DetachDebugger() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_lock<std::mutex> System::StallProcesses() {
|
std::unique_lock<std::mutex> System::StallApplication() {
|
||||||
return impl->StallProcesses();
|
return impl->StallApplication();
|
||||||
}
|
}
|
||||||
|
|
||||||
void System::UnstallProcesses() {
|
void System::UnstallApplication() {
|
||||||
impl->UnstallProcesses();
|
impl->UnstallApplication();
|
||||||
}
|
}
|
||||||
|
|
||||||
void System::InitializeDebugger() {
|
void System::InitializeDebugger() {
|
||||||
|
@ -648,8 +648,8 @@ const Kernel::GlobalSchedulerContext& System::GlobalSchedulerContext() const {
|
||||||
return impl->kernel.GlobalSchedulerContext();
|
return impl->kernel.GlobalSchedulerContext();
|
||||||
}
|
}
|
||||||
|
|
||||||
Kernel::KProcess* System::CurrentProcess() {
|
Kernel::KProcess* System::ApplicationProcess() {
|
||||||
return impl->kernel.CurrentProcess();
|
return impl->kernel.ApplicationProcess();
|
||||||
}
|
}
|
||||||
|
|
||||||
Core::DeviceMemory& System::DeviceMemory() {
|
Core::DeviceMemory& System::DeviceMemory() {
|
||||||
|
@ -660,8 +660,8 @@ const Core::DeviceMemory& System::DeviceMemory() const {
|
||||||
return *impl->device_memory;
|
return *impl->device_memory;
|
||||||
}
|
}
|
||||||
|
|
||||||
const Kernel::KProcess* System::CurrentProcess() const {
|
const Kernel::KProcess* System::ApplicationProcess() const {
|
||||||
return impl->kernel.CurrentProcess();
|
return impl->kernel.ApplicationProcess();
|
||||||
}
|
}
|
||||||
|
|
||||||
ARM_Interface& System::ArmInterface(std::size_t core_index) {
|
ARM_Interface& System::ArmInterface(std::size_t core_index) {
|
||||||
|
@ -760,8 +760,8 @@ const Core::SpeedLimiter& System::SpeedLimiter() const {
|
||||||
return impl->speed_limiter;
|
return impl->speed_limiter;
|
||||||
}
|
}
|
||||||
|
|
||||||
u64 System::GetCurrentProcessProgramID() const {
|
u64 System::GetApplicationProcessProgramID() const {
|
||||||
return impl->kernel.CurrentProcess()->GetProgramID();
|
return impl->kernel.ApplicationProcess()->GetProgramID();
|
||||||
}
|
}
|
||||||
|
|
||||||
Loader::ResultStatus System::GetGameName(std::string& out) const {
|
Loader::ResultStatus System::GetGameName(std::string& out) const {
|
||||||
|
@ -880,11 +880,11 @@ bool System::GetExitLock() const {
|
||||||
return impl->exit_lock;
|
return impl->exit_lock;
|
||||||
}
|
}
|
||||||
|
|
||||||
void System::SetCurrentProcessBuildID(const CurrentBuildProcessID& id) {
|
void System::SetApplicationProcessBuildID(const CurrentBuildProcessID& id) {
|
||||||
impl->build_id = id;
|
impl->build_id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
const System::CurrentBuildProcessID& System::GetCurrentProcessBuildID() const {
|
const System::CurrentBuildProcessID& System::GetApplicationProcessBuildID() const {
|
||||||
return impl->build_id;
|
return impl->build_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -184,8 +184,8 @@ public:
|
||||||
/// Forcibly detach the debugger if it is running.
|
/// Forcibly detach the debugger if it is running.
|
||||||
void DetachDebugger();
|
void DetachDebugger();
|
||||||
|
|
||||||
std::unique_lock<std::mutex> StallProcesses();
|
std::unique_lock<std::mutex> StallApplication();
|
||||||
void UnstallProcesses();
|
void UnstallApplication();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize the debugger.
|
* Initialize the debugger.
|
||||||
|
@ -295,11 +295,11 @@ public:
|
||||||
/// Gets the manager for the guest device memory
|
/// Gets the manager for the guest device memory
|
||||||
[[nodiscard]] const Core::DeviceMemory& DeviceMemory() const;
|
[[nodiscard]] const Core::DeviceMemory& DeviceMemory() const;
|
||||||
|
|
||||||
/// Provides a pointer to the current process
|
/// Provides a pointer to the application process
|
||||||
[[nodiscard]] Kernel::KProcess* CurrentProcess();
|
[[nodiscard]] Kernel::KProcess* ApplicationProcess();
|
||||||
|
|
||||||
/// Provides a constant pointer to the current process.
|
/// Provides a constant pointer to the application process.
|
||||||
[[nodiscard]] const Kernel::KProcess* CurrentProcess() const;
|
[[nodiscard]] const Kernel::KProcess* ApplicationProcess() const;
|
||||||
|
|
||||||
/// Provides a reference to the core timing instance.
|
/// Provides a reference to the core timing instance.
|
||||||
[[nodiscard]] Timing::CoreTiming& CoreTiming();
|
[[nodiscard]] Timing::CoreTiming& CoreTiming();
|
||||||
|
@ -331,7 +331,7 @@ public:
|
||||||
/// Provides a constant reference to the speed limiter
|
/// Provides a constant reference to the speed limiter
|
||||||
[[nodiscard]] const Core::SpeedLimiter& SpeedLimiter() const;
|
[[nodiscard]] const Core::SpeedLimiter& SpeedLimiter() const;
|
||||||
|
|
||||||
[[nodiscard]] u64 GetCurrentProcessProgramID() const;
|
[[nodiscard]] u64 GetApplicationProcessProgramID() const;
|
||||||
|
|
||||||
/// Gets the name of the current game
|
/// Gets the name of the current game
|
||||||
[[nodiscard]] Loader::ResultStatus GetGameName(std::string& out) const;
|
[[nodiscard]] Loader::ResultStatus GetGameName(std::string& out) const;
|
||||||
|
@ -396,8 +396,8 @@ public:
|
||||||
void SetExitLock(bool locked);
|
void SetExitLock(bool locked);
|
||||||
[[nodiscard]] bool GetExitLock() const;
|
[[nodiscard]] bool GetExitLock() const;
|
||||||
|
|
||||||
void SetCurrentProcessBuildID(const CurrentBuildProcessID& id);
|
void SetApplicationProcessBuildID(const CurrentBuildProcessID& id);
|
||||||
[[nodiscard]] const CurrentBuildProcessID& GetCurrentProcessBuildID() const;
|
[[nodiscard]] const CurrentBuildProcessID& GetApplicationProcessBuildID() const;
|
||||||
|
|
||||||
/// Register a host thread as an emulated CPU Core.
|
/// Register a host thread as an emulated CPU Core.
|
||||||
void RegisterCoreThread(std::size_t id);
|
void RegisterCoreThread(std::size_t id);
|
||||||
|
|
|
@ -96,7 +96,7 @@ static std::string EscapeXML(std::string_view data) {
|
||||||
|
|
||||||
GDBStub::GDBStub(DebuggerBackend& backend_, Core::System& system_)
|
GDBStub::GDBStub(DebuggerBackend& backend_, Core::System& system_)
|
||||||
: DebuggerFrontend(backend_), system{system_} {
|
: DebuggerFrontend(backend_), system{system_} {
|
||||||
if (system.CurrentProcess()->Is64BitProcess()) {
|
if (system.ApplicationProcess()->Is64BitProcess()) {
|
||||||
arch = std::make_unique<GDBStubA64>();
|
arch = std::make_unique<GDBStubA64>();
|
||||||
} else {
|
} else {
|
||||||
arch = std::make_unique<GDBStubA32>();
|
arch = std::make_unique<GDBStubA32>();
|
||||||
|
@ -340,15 +340,15 @@ void GDBStub::HandleBreakpointInsert(std::string_view command) {
|
||||||
success = true;
|
success = true;
|
||||||
break;
|
break;
|
||||||
case BreakpointType::WriteWatch:
|
case BreakpointType::WriteWatch:
|
||||||
success = system.CurrentProcess()->InsertWatchpoint(system, addr, size,
|
success = system.ApplicationProcess()->InsertWatchpoint(system, addr, size,
|
||||||
Kernel::DebugWatchpointType::Write);
|
Kernel::DebugWatchpointType::Write);
|
||||||
break;
|
break;
|
||||||
case BreakpointType::ReadWatch:
|
case BreakpointType::ReadWatch:
|
||||||
success = system.CurrentProcess()->InsertWatchpoint(system, addr, size,
|
success = system.ApplicationProcess()->InsertWatchpoint(system, addr, size,
|
||||||
Kernel::DebugWatchpointType::Read);
|
Kernel::DebugWatchpointType::Read);
|
||||||
break;
|
break;
|
||||||
case BreakpointType::AccessWatch:
|
case BreakpointType::AccessWatch:
|
||||||
success = system.CurrentProcess()->InsertWatchpoint(
|
success = system.ApplicationProcess()->InsertWatchpoint(
|
||||||
system, addr, size, Kernel::DebugWatchpointType::ReadOrWrite);
|
system, addr, size, Kernel::DebugWatchpointType::ReadOrWrite);
|
||||||
break;
|
break;
|
||||||
case BreakpointType::Hardware:
|
case BreakpointType::Hardware:
|
||||||
|
@ -391,15 +391,15 @@ void GDBStub::HandleBreakpointRemove(std::string_view command) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case BreakpointType::WriteWatch:
|
case BreakpointType::WriteWatch:
|
||||||
success = system.CurrentProcess()->RemoveWatchpoint(system, addr, size,
|
success = system.ApplicationProcess()->RemoveWatchpoint(system, addr, size,
|
||||||
Kernel::DebugWatchpointType::Write);
|
Kernel::DebugWatchpointType::Write);
|
||||||
break;
|
break;
|
||||||
case BreakpointType::ReadWatch:
|
case BreakpointType::ReadWatch:
|
||||||
success = system.CurrentProcess()->RemoveWatchpoint(system, addr, size,
|
success = system.ApplicationProcess()->RemoveWatchpoint(system, addr, size,
|
||||||
Kernel::DebugWatchpointType::Read);
|
Kernel::DebugWatchpointType::Read);
|
||||||
break;
|
break;
|
||||||
case BreakpointType::AccessWatch:
|
case BreakpointType::AccessWatch:
|
||||||
success = system.CurrentProcess()->RemoveWatchpoint(
|
success = system.ApplicationProcess()->RemoveWatchpoint(
|
||||||
system, addr, size, Kernel::DebugWatchpointType::ReadOrWrite);
|
system, addr, size, Kernel::DebugWatchpointType::ReadOrWrite);
|
||||||
break;
|
break;
|
||||||
case BreakpointType::Hardware:
|
case BreakpointType::Hardware:
|
||||||
|
@ -482,7 +482,7 @@ static std::optional<std::string> GetNameFromThreadType64(Core::Memory::Memory&
|
||||||
|
|
||||||
static std::optional<std::string> GetThreadName(Core::System& system,
|
static std::optional<std::string> GetThreadName(Core::System& system,
|
||||||
const Kernel::KThread* thread) {
|
const Kernel::KThread* thread) {
|
||||||
if (system.CurrentProcess()->Is64BitProcess()) {
|
if (system.ApplicationProcess()->Is64BitProcess()) {
|
||||||
return GetNameFromThreadType64(system.Memory(), thread);
|
return GetNameFromThreadType64(system.Memory(), thread);
|
||||||
} else {
|
} else {
|
||||||
return GetNameFromThreadType32(system.Memory(), thread);
|
return GetNameFromThreadType32(system.Memory(), thread);
|
||||||
|
@ -555,7 +555,7 @@ void GDBStub::HandleQuery(std::string_view command) {
|
||||||
SendReply(fmt::format("TextSeg={:x}", main->first));
|
SendReply(fmt::format("TextSeg={:x}", main->first));
|
||||||
} else {
|
} else {
|
||||||
SendReply(fmt::format("TextSeg={:x}",
|
SendReply(fmt::format("TextSeg={:x}",
|
||||||
system.CurrentProcess()->PageTable().GetCodeRegionStart()));
|
system.ApplicationProcess()->PageTable().GetCodeRegionStart()));
|
||||||
}
|
}
|
||||||
} else if (command.starts_with("Xfer:libraries:read::")) {
|
} else if (command.starts_with("Xfer:libraries:read::")) {
|
||||||
Loader::AppLoader::Modules modules;
|
Loader::AppLoader::Modules modules;
|
||||||
|
@ -729,7 +729,7 @@ void GDBStub::HandleRcmd(const std::vector<u8>& command) {
|
||||||
std::string_view command_str{reinterpret_cast<const char*>(&command[0]), command.size()};
|
std::string_view command_str{reinterpret_cast<const char*>(&command[0]), command.size()};
|
||||||
std::string reply;
|
std::string reply;
|
||||||
|
|
||||||
auto* process = system.CurrentProcess();
|
auto* process = system.ApplicationProcess();
|
||||||
auto& page_table = process->PageTable();
|
auto& page_table = process->PageTable();
|
||||||
|
|
||||||
const char* commands = "Commands:\n"
|
const char* commands = "Commands:\n"
|
||||||
|
|
|
@ -172,7 +172,7 @@ std::string SaveDataFactory::GetFullPath(Core::System& system, VirtualDir dir,
|
||||||
// be interpreted as the title id of the current process.
|
// be interpreted as the title id of the current process.
|
||||||
if (type == SaveDataType::SaveData || type == SaveDataType::DeviceSaveData) {
|
if (type == SaveDataType::SaveData || type == SaveDataType::DeviceSaveData) {
|
||||||
if (title_id == 0) {
|
if (title_id == 0) {
|
||||||
title_id = system.GetCurrentProcessProgramID();
|
title_id = system.GetApplicationProcessProgramID();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -148,7 +148,7 @@ public:
|
||||||
if (context->GetManager()->IsDomain()) {
|
if (context->GetManager()->IsDomain()) {
|
||||||
context->AddDomainObject(std::move(iface));
|
context->AddDomainObject(std::move(iface));
|
||||||
} else {
|
} else {
|
||||||
kernel.CurrentProcess()->GetResourceLimit()->Reserve(
|
kernel.ApplicationProcess()->GetResourceLimit()->Reserve(
|
||||||
Kernel::LimitableResource::SessionCountMax, 1);
|
Kernel::LimitableResource::SessionCountMax, 1);
|
||||||
|
|
||||||
auto* session = Kernel::KSession::Create(kernel);
|
auto* session = Kernel::KSession::Create(kernel);
|
||||||
|
|
|
@ -61,7 +61,7 @@ bool KClientPort::IsSignaled() const {
|
||||||
Result KClientPort::CreateSession(KClientSession** out) {
|
Result KClientPort::CreateSession(KClientSession** out) {
|
||||||
// Reserve a new session from the resource limit.
|
// Reserve a new session from the resource limit.
|
||||||
//! FIXME: we are reserving this from the wrong resource limit!
|
//! FIXME: we are reserving this from the wrong resource limit!
|
||||||
KScopedResourceReservation session_reservation(kernel.CurrentProcess()->GetResourceLimit(),
|
KScopedResourceReservation session_reservation(kernel.ApplicationProcess()->GetResourceLimit(),
|
||||||
LimitableResource::SessionCountMax);
|
LimitableResource::SessionCountMax);
|
||||||
R_UNLESS(session_reservation.Succeeded(), ResultLimitReached);
|
R_UNLESS(session_reservation.Succeeded(), ResultLimitReached);
|
||||||
|
|
||||||
|
|
|
@ -90,7 +90,8 @@ public:
|
||||||
// Handle pseudo-handles.
|
// Handle pseudo-handles.
|
||||||
if constexpr (std::derived_from<KProcess, T>) {
|
if constexpr (std::derived_from<KProcess, T>) {
|
||||||
if (handle == Svc::PseudoHandle::CurrentProcess) {
|
if (handle == Svc::PseudoHandle::CurrentProcess) {
|
||||||
auto* const cur_process = GetCurrentProcessPointer(m_kernel);
|
//! FIXME: this is the wrong process!
|
||||||
|
auto* const cur_process = m_kernel.ApplicationProcess();
|
||||||
ASSERT(cur_process != nullptr);
|
ASSERT(cur_process != nullptr);
|
||||||
return cur_process;
|
return cur_process;
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@ void KSession::Initialize(KClientPort* port_, const std::string& name_) {
|
||||||
|
|
||||||
// Set our owner process.
|
// Set our owner process.
|
||||||
//! FIXME: this is the wrong process!
|
//! FIXME: this is the wrong process!
|
||||||
process = kernel.CurrentProcess();
|
process = kernel.ApplicationProcess();
|
||||||
process->Open();
|
process->Open();
|
||||||
|
|
||||||
// Set our port.
|
// Set our port.
|
||||||
|
|
|
@ -102,13 +102,13 @@ struct KernelCore::Impl {
|
||||||
|
|
||||||
void InitializeCores() {
|
void InitializeCores() {
|
||||||
for (u32 core_id = 0; core_id < Core::Hardware::NUM_CPU_CORES; core_id++) {
|
for (u32 core_id = 0; core_id < Core::Hardware::NUM_CPU_CORES; core_id++) {
|
||||||
cores[core_id]->Initialize((*current_process).Is64BitProcess());
|
cores[core_id]->Initialize((*application_process).Is64BitProcess());
|
||||||
system.Memory().SetCurrentPageTable(*current_process, core_id);
|
system.Memory().SetCurrentPageTable(*application_process, core_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CloseCurrentProcess() {
|
void CloseApplicationProcess() {
|
||||||
KProcess* old_process = current_process.exchange(nullptr);
|
KProcess* old_process = application_process.exchange(nullptr);
|
||||||
if (old_process == nullptr) {
|
if (old_process == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -182,7 +182,7 @@ struct KernelCore::Impl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CloseCurrentProcess();
|
CloseApplicationProcess();
|
||||||
|
|
||||||
// Track kernel objects that were not freed on shutdown
|
// Track kernel objects that were not freed on shutdown
|
||||||
{
|
{
|
||||||
|
@ -363,8 +363,8 @@ struct KernelCore::Impl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MakeCurrentProcess(KProcess* process) {
|
void MakeApplicationProcess(KProcess* process) {
|
||||||
current_process = process;
|
application_process = process;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline thread_local u32 host_thread_id = UINT32_MAX;
|
static inline thread_local u32 host_thread_id = UINT32_MAX;
|
||||||
|
@ -821,7 +821,7 @@ struct KernelCore::Impl {
|
||||||
|
|
||||||
// Lists all processes that exist in the current session.
|
// Lists all processes that exist in the current session.
|
||||||
std::vector<KProcess*> process_list;
|
std::vector<KProcess*> process_list;
|
||||||
std::atomic<KProcess*> current_process{};
|
std::atomic<KProcess*> application_process{};
|
||||||
std::unique_ptr<Kernel::GlobalSchedulerContext> global_scheduler_context;
|
std::unique_ptr<Kernel::GlobalSchedulerContext> global_scheduler_context;
|
||||||
std::unique_ptr<Kernel::KHardwareTimer> hardware_timer;
|
std::unique_ptr<Kernel::KHardwareTimer> hardware_timer;
|
||||||
|
|
||||||
|
@ -941,20 +941,20 @@ void KernelCore::AppendNewProcess(KProcess* process) {
|
||||||
impl->process_list.push_back(process);
|
impl->process_list.push_back(process);
|
||||||
}
|
}
|
||||||
|
|
||||||
void KernelCore::MakeCurrentProcess(KProcess* process) {
|
void KernelCore::MakeApplicationProcess(KProcess* process) {
|
||||||
impl->MakeCurrentProcess(process);
|
impl->MakeApplicationProcess(process);
|
||||||
}
|
}
|
||||||
|
|
||||||
KProcess* KernelCore::CurrentProcess() {
|
KProcess* KernelCore::ApplicationProcess() {
|
||||||
return impl->current_process;
|
return impl->application_process;
|
||||||
}
|
}
|
||||||
|
|
||||||
const KProcess* KernelCore::CurrentProcess() const {
|
const KProcess* KernelCore::ApplicationProcess() const {
|
||||||
return impl->current_process;
|
return impl->application_process;
|
||||||
}
|
}
|
||||||
|
|
||||||
void KernelCore::CloseCurrentProcess() {
|
void KernelCore::CloseApplicationProcess() {
|
||||||
impl->CloseCurrentProcess();
|
impl->CloseApplicationProcess();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::vector<KProcess*>& KernelCore::GetProcessList() const {
|
const std::vector<KProcess*>& KernelCore::GetProcessList() const {
|
||||||
|
@ -1202,12 +1202,12 @@ const Kernel::KSharedMemory& KernelCore::GetHidBusSharedMem() const {
|
||||||
return *impl->hidbus_shared_mem;
|
return *impl->hidbus_shared_mem;
|
||||||
}
|
}
|
||||||
|
|
||||||
void KernelCore::Suspend(bool suspended) {
|
void KernelCore::SuspendApplication(bool suspended) {
|
||||||
const bool should_suspend{exception_exited || suspended};
|
const bool should_suspend{exception_exited || suspended};
|
||||||
const auto activity = should_suspend ? ProcessActivity::Paused : ProcessActivity::Runnable;
|
const auto activity = should_suspend ? ProcessActivity::Paused : ProcessActivity::Runnable;
|
||||||
|
|
||||||
//! This refers to the application process, not the current process.
|
// Get the application process.
|
||||||
KScopedAutoObject<KProcess> process = CurrentProcess();
|
KScopedAutoObject<KProcess> process = ApplicationProcess();
|
||||||
if (process.IsNull()) {
|
if (process.IsNull()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1218,8 +1218,8 @@ void KernelCore::Suspend(bool suspended) {
|
||||||
// Wait for process execution to stop.
|
// Wait for process execution to stop.
|
||||||
bool must_wait{should_suspend};
|
bool must_wait{should_suspend};
|
||||||
|
|
||||||
// KernelCore::Suspend must be called from locked context, or we
|
// KernelCore::SuspendApplication must be called from locked context,
|
||||||
// could race another call to SetActivity, interfering with waiting.
|
// or we could race another call to SetActivity, interfering with waiting.
|
||||||
while (must_wait) {
|
while (must_wait) {
|
||||||
KScopedSchedulerLock sl{*this};
|
KScopedSchedulerLock sl{*this};
|
||||||
|
|
||||||
|
@ -1253,9 +1253,9 @@ bool KernelCore::IsShuttingDown() const {
|
||||||
return impl->IsShuttingDown();
|
return impl->IsShuttingDown();
|
||||||
}
|
}
|
||||||
|
|
||||||
void KernelCore::ExceptionalExit() {
|
void KernelCore::ExceptionalExitApplication() {
|
||||||
exception_exited = true;
|
exception_exited = true;
|
||||||
Suspend(true);
|
SuspendApplication(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void KernelCore::EnterSVCProfile() {
|
void KernelCore::EnterSVCProfile() {
|
||||||
|
|
|
@ -131,17 +131,17 @@ public:
|
||||||
/// Adds the given shared pointer to an internal list of active processes.
|
/// Adds the given shared pointer to an internal list of active processes.
|
||||||
void AppendNewProcess(KProcess* process);
|
void AppendNewProcess(KProcess* process);
|
||||||
|
|
||||||
/// Makes the given process the new current process.
|
/// Makes the given process the new application process.
|
||||||
void MakeCurrentProcess(KProcess* process);
|
void MakeApplicationProcess(KProcess* process);
|
||||||
|
|
||||||
/// Retrieves a pointer to the current process.
|
/// Retrieves a pointer to the application process.
|
||||||
KProcess* CurrentProcess();
|
KProcess* ApplicationProcess();
|
||||||
|
|
||||||
/// Retrieves a const pointer to the current process.
|
/// Retrieves a const pointer to the application process.
|
||||||
const KProcess* CurrentProcess() const;
|
const KProcess* ApplicationProcess() const;
|
||||||
|
|
||||||
/// Closes the current process.
|
/// Closes the application process.
|
||||||
void CloseCurrentProcess();
|
void CloseApplicationProcess();
|
||||||
|
|
||||||
/// Retrieves the list of processes.
|
/// Retrieves the list of processes.
|
||||||
const std::vector<KProcess*>& GetProcessList() const;
|
const std::vector<KProcess*>& GetProcessList() const;
|
||||||
|
@ -288,11 +288,11 @@ public:
|
||||||
/// Gets the shared memory object for HIDBus services.
|
/// Gets the shared memory object for HIDBus services.
|
||||||
const Kernel::KSharedMemory& GetHidBusSharedMem() const;
|
const Kernel::KSharedMemory& GetHidBusSharedMem() const;
|
||||||
|
|
||||||
/// Suspend/unsuspend all processes.
|
/// Suspend/unsuspend application process.
|
||||||
void Suspend(bool suspend);
|
void SuspendApplication(bool suspend);
|
||||||
|
|
||||||
/// Exceptional exit all processes.
|
/// Exceptional exit application process.
|
||||||
void ExceptionalExit();
|
void ExceptionalExitApplication();
|
||||||
|
|
||||||
/// Notify emulated CPU cores to shut down.
|
/// Notify emulated CPU cores to shut down.
|
||||||
void ShutdownCores();
|
void ShutdownCores();
|
||||||
|
|
|
@ -762,7 +762,7 @@ Result Module::Interface::InitializeApplicationInfoBase() {
|
||||||
// processes emulated. As we don't actually have pid support we should assume we're just using
|
// processes emulated. As we don't actually have pid support we should assume we're just using
|
||||||
// our own process
|
// our own process
|
||||||
const auto launch_property =
|
const auto launch_property =
|
||||||
system.GetARPManager().GetLaunchProperty(system.GetCurrentProcessProgramID());
|
system.GetARPManager().GetLaunchProperty(system.GetApplicationProcessProgramID());
|
||||||
|
|
||||||
if (launch_property.Failed()) {
|
if (launch_property.Failed()) {
|
||||||
LOG_ERROR(Service_ACC, "Failed to get launch property");
|
LOG_ERROR(Service_ACC, "Failed to get launch property");
|
||||||
|
@ -806,7 +806,7 @@ void Module::Interface::IsUserAccountSwitchLocked(Kernel::HLERequestContext& ctx
|
||||||
bool is_locked = false;
|
bool is_locked = false;
|
||||||
|
|
||||||
if (res != Loader::ResultStatus::Success) {
|
if (res != Loader::ResultStatus::Success) {
|
||||||
const FileSys::PatchManager pm{system.GetCurrentProcessProgramID(),
|
const FileSys::PatchManager pm{system.GetApplicationProcessProgramID(),
|
||||||
system.GetFileSystemController(),
|
system.GetFileSystemController(),
|
||||||
system.GetContentProvider()};
|
system.GetContentProvider()};
|
||||||
const auto nacp_unique = pm.GetControlMetadata().first;
|
const auto nacp_unique = pm.GetControlMetadata().first;
|
||||||
|
|
|
@ -79,7 +79,7 @@ IWindowController::IWindowController(Core::System& system_)
|
||||||
IWindowController::~IWindowController() = default;
|
IWindowController::~IWindowController() = default;
|
||||||
|
|
||||||
void IWindowController::GetAppletResourceUserId(Kernel::HLERequestContext& ctx) {
|
void IWindowController::GetAppletResourceUserId(Kernel::HLERequestContext& ctx) {
|
||||||
const u64 process_id = system.CurrentProcess()->GetProcessID();
|
const u64 process_id = system.ApplicationProcess()->GetProcessID();
|
||||||
|
|
||||||
LOG_DEBUG(Service_AM, "called. Process ID=0x{:016X}", process_id);
|
LOG_DEBUG(Service_AM, "called. Process ID=0x{:016X}", process_id);
|
||||||
|
|
||||||
|
@ -1252,7 +1252,7 @@ void ILibraryAppletCreator::CreateTransferMemoryStorage(Kernel::HLERequestContex
|
||||||
}
|
}
|
||||||
|
|
||||||
auto transfer_mem =
|
auto transfer_mem =
|
||||||
system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(handle);
|
system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(handle);
|
||||||
|
|
||||||
if (transfer_mem.IsNull()) {
|
if (transfer_mem.IsNull()) {
|
||||||
LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle);
|
LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle);
|
||||||
|
@ -1286,7 +1286,7 @@ void ILibraryAppletCreator::CreateHandleStorage(Kernel::HLERequestContext& ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
auto transfer_mem =
|
auto transfer_mem =
|
||||||
system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(handle);
|
system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(handle);
|
||||||
|
|
||||||
if (transfer_mem.IsNull()) {
|
if (transfer_mem.IsNull()) {
|
||||||
LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle);
|
LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle);
|
||||||
|
@ -1465,11 +1465,12 @@ void IApplicationFunctions::PopLaunchParameter(Kernel::HLERequestContext& ctx) {
|
||||||
const auto backend = BCAT::CreateBackendFromSettings(system, [this](u64 tid) {
|
const auto backend = BCAT::CreateBackendFromSettings(system, [this](u64 tid) {
|
||||||
return system.GetFileSystemController().GetBCATDirectory(tid);
|
return system.GetFileSystemController().GetBCATDirectory(tid);
|
||||||
});
|
});
|
||||||
const auto build_id_full = system.GetCurrentProcessBuildID();
|
const auto build_id_full = system.GetApplicationProcessBuildID();
|
||||||
u64 build_id{};
|
u64 build_id{};
|
||||||
std::memcpy(&build_id, build_id_full.data(), sizeof(u64));
|
std::memcpy(&build_id, build_id_full.data(), sizeof(u64));
|
||||||
|
|
||||||
auto data = backend->GetLaunchParameter({system.GetCurrentProcessProgramID(), build_id});
|
auto data =
|
||||||
|
backend->GetLaunchParameter({system.GetApplicationProcessProgramID(), build_id});
|
||||||
if (data.has_value()) {
|
if (data.has_value()) {
|
||||||
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
|
@ -1521,7 +1522,7 @@ void IApplicationFunctions::EnsureSaveData(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_AM, "called, uid={:016X}{:016X}", user_id[1], user_id[0]);
|
LOG_DEBUG(Service_AM, "called, uid={:016X}{:016X}", user_id[1], user_id[0]);
|
||||||
|
|
||||||
FileSys::SaveDataAttribute attribute{};
|
FileSys::SaveDataAttribute attribute{};
|
||||||
attribute.title_id = system.GetCurrentProcessProgramID();
|
attribute.title_id = system.GetApplicationProcessProgramID();
|
||||||
attribute.user_id = user_id;
|
attribute.user_id = user_id;
|
||||||
attribute.type = FileSys::SaveDataType::SaveData;
|
attribute.type = FileSys::SaveDataType::SaveData;
|
||||||
const auto res = system.GetFileSystemController().CreateSaveData(
|
const auto res = system.GetFileSystemController().CreateSaveData(
|
||||||
|
@ -1551,7 +1552,7 @@ void IApplicationFunctions::GetDisplayVersion(Kernel::HLERequestContext& ctx) {
|
||||||
std::array<u8, 0x10> version_string{};
|
std::array<u8, 0x10> version_string{};
|
||||||
|
|
||||||
const auto res = [this] {
|
const auto res = [this] {
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
|
|
||||||
const FileSys::PatchManager pm{title_id, system.GetFileSystemController(),
|
const FileSys::PatchManager pm{title_id, system.GetFileSystemController(),
|
||||||
system.GetContentProvider()};
|
system.GetContentProvider()};
|
||||||
|
@ -1588,7 +1589,7 @@ void IApplicationFunctions::GetDesiredLanguage(Kernel::HLERequestContext& ctx) {
|
||||||
u32 supported_languages = 0;
|
u32 supported_languages = 0;
|
||||||
|
|
||||||
const auto res = [this] {
|
const auto res = [this] {
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
|
|
||||||
const FileSys::PatchManager pm{title_id, system.GetFileSystemController(),
|
const FileSys::PatchManager pm{title_id, system.GetFileSystemController(),
|
||||||
system.GetContentProvider()};
|
system.GetContentProvider()};
|
||||||
|
@ -1696,7 +1697,8 @@ void IApplicationFunctions::ExtendSaveData(Kernel::HLERequestContext& ctx) {
|
||||||
static_cast<u8>(type), user_id[1], user_id[0], new_normal_size, new_journal_size);
|
static_cast<u8>(type), user_id[1], user_id[0], new_normal_size, new_journal_size);
|
||||||
|
|
||||||
system.GetFileSystemController().WriteSaveDataSize(
|
system.GetFileSystemController().WriteSaveDataSize(
|
||||||
type, system.GetCurrentProcessProgramID(), user_id, {new_normal_size, new_journal_size});
|
type, system.GetApplicationProcessProgramID(), user_id,
|
||||||
|
{new_normal_size, new_journal_size});
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 4};
|
IPC::ResponseBuilder rb{ctx, 4};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
|
@ -1720,7 +1722,7 @@ void IApplicationFunctions::GetSaveDataSize(Kernel::HLERequestContext& ctx) {
|
||||||
user_id[0]);
|
user_id[0]);
|
||||||
|
|
||||||
const auto size = system.GetFileSystemController().ReadSaveDataSize(
|
const auto size = system.GetFileSystemController().ReadSaveDataSize(
|
||||||
type, system.GetCurrentProcessProgramID(), user_id);
|
type, system.GetApplicationProcessProgramID(), user_id);
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 6};
|
IPC::ResponseBuilder rb{ctx, 6};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
|
|
|
@ -166,7 +166,7 @@ void Error::Execute() {
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto callback = [this] { DisplayCompleted(); };
|
const auto callback = [this] { DisplayCompleted(); };
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
const auto& reporter{system.GetReporter()};
|
const auto& reporter{system.GetReporter()};
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
|
|
|
@ -186,7 +186,7 @@ void PhotoViewer::Execute() {
|
||||||
const auto callback = [this] { ViewFinished(); };
|
const auto callback = [this] { ViewFinished(); };
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case PhotoViewerAppletMode::CurrentApp:
|
case PhotoViewerAppletMode::CurrentApp:
|
||||||
frontend.ShowPhotosForApplication(system.GetCurrentProcessProgramID(), callback);
|
frontend.ShowPhotosForApplication(system.GetApplicationProcessProgramID(), callback);
|
||||||
break;
|
break;
|
||||||
case PhotoViewerAppletMode::AllApps:
|
case PhotoViewerAppletMode::AllApps:
|
||||||
frontend.ShowAllPhotos(callback);
|
frontend.ShowAllPhotos(callback);
|
||||||
|
|
|
@ -393,7 +393,7 @@ void WebBrowser::InitializeOffline() {
|
||||||
switch (document_kind) {
|
switch (document_kind) {
|
||||||
case DocumentKind::OfflineHtmlPage:
|
case DocumentKind::OfflineHtmlPage:
|
||||||
default:
|
default:
|
||||||
title_id = system.GetCurrentProcessProgramID();
|
title_id = system.GetApplicationProcessProgramID();
|
||||||
nca_type = FileSys::ContentRecordType::HtmlDocument;
|
nca_type = FileSys::ContentRecordType::HtmlDocument;
|
||||||
additional_paths = "html-document";
|
additional_paths = "html-document";
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -155,7 +155,7 @@ void AOC_U::CountAddOnContent(Kernel::HLERequestContext& ctx) {
|
||||||
IPC::ResponseBuilder rb{ctx, 3};
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
|
|
||||||
const auto current = system.GetCurrentProcessProgramID();
|
const auto current = system.GetApplicationProcessProgramID();
|
||||||
|
|
||||||
const auto& disabled = Settings::values.disabled_addons[current];
|
const auto& disabled = Settings::values.disabled_addons[current];
|
||||||
if (std::find(disabled.begin(), disabled.end(), "DLC") != disabled.end()) {
|
if (std::find(disabled.begin(), disabled.end(), "DLC") != disabled.end()) {
|
||||||
|
@ -182,7 +182,7 @@ void AOC_U::ListAddOnContent(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_AOC, "called with offset={}, count={}, process_id={}", offset, count,
|
LOG_DEBUG(Service_AOC, "called with offset={}, count={}, process_id={}", offset, count,
|
||||||
process_id);
|
process_id);
|
||||||
|
|
||||||
const auto current = system.GetCurrentProcessProgramID();
|
const auto current = system.GetApplicationProcessProgramID();
|
||||||
|
|
||||||
std::vector<u32> out;
|
std::vector<u32> out;
|
||||||
const auto& disabled = Settings::values.disabled_addons[current];
|
const auto& disabled = Settings::values.disabled_addons[current];
|
||||||
|
@ -228,7 +228,7 @@ void AOC_U::GetAddOnContentBaseId(Kernel::HLERequestContext& ctx) {
|
||||||
IPC::ResponseBuilder rb{ctx, 4};
|
IPC::ResponseBuilder rb{ctx, 4};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
|
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
const FileSys::PatchManager pm{title_id, system.GetFileSystemController(),
|
const FileSys::PatchManager pm{title_id, system.GetFileSystemController(),
|
||||||
system.GetContentProvider()};
|
system.GetContentProvider()};
|
||||||
|
|
||||||
|
|
|
@ -455,7 +455,7 @@ void AudRenU::OpenAudioRenderer(Kernel::HLERequestContext& ctx) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto& handle_table{system.CurrentProcess()->GetHandleTable()};
|
const auto& handle_table{system.ApplicationProcess()->GetHandleTable()};
|
||||||
auto process{handle_table.GetObject<Kernel::KProcess>(process_handle)};
|
auto process{handle_table.GetObject<Kernel::KProcess>(process_handle)};
|
||||||
auto transfer_memory{
|
auto transfer_memory{
|
||||||
process->GetHandleTable().GetObject<Kernel::KTransferMemory>(transfer_memory_handle)};
|
process->GetHandleTable().GetObject<Kernel::KTransferMemory>(transfer_memory_handle)};
|
||||||
|
|
|
@ -176,8 +176,8 @@ private:
|
||||||
void RequestSyncDeliveryCache(Kernel::HLERequestContext& ctx) {
|
void RequestSyncDeliveryCache(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_BCAT, "called");
|
LOG_DEBUG(Service_BCAT, "called");
|
||||||
|
|
||||||
backend.Synchronize({system.GetCurrentProcessProgramID(),
|
backend.Synchronize({system.GetApplicationProcessProgramID(),
|
||||||
GetCurrentBuildID(system.GetCurrentProcessBuildID())},
|
GetCurrentBuildID(system.GetApplicationProcessBuildID())},
|
||||||
GetProgressBackend(SyncType::Normal));
|
GetProgressBackend(SyncType::Normal));
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
||||||
|
@ -193,8 +193,8 @@ private:
|
||||||
|
|
||||||
LOG_DEBUG(Service_BCAT, "called, name={}", name);
|
LOG_DEBUG(Service_BCAT, "called, name={}", name);
|
||||||
|
|
||||||
backend.SynchronizeDirectory({system.GetCurrentProcessProgramID(),
|
backend.SynchronizeDirectory({system.GetApplicationProcessProgramID(),
|
||||||
GetCurrentBuildID(system.GetCurrentProcessBuildID())},
|
GetCurrentBuildID(system.GetApplicationProcessBuildID())},
|
||||||
name, GetProgressBackend(SyncType::Directory));
|
name, GetProgressBackend(SyncType::Directory));
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
||||||
|
@ -554,7 +554,7 @@ private:
|
||||||
void Module::Interface::CreateDeliveryCacheStorageService(Kernel::HLERequestContext& ctx) {
|
void Module::Interface::CreateDeliveryCacheStorageService(Kernel::HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_BCAT, "called");
|
LOG_DEBUG(Service_BCAT, "called");
|
||||||
|
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
rb.PushIpcInterface<IDeliveryCacheStorageService>(system, fsc.GetBCATDirectory(title_id));
|
rb.PushIpcInterface<IDeliveryCacheStorageService>(system, fsc.GetBCATDirectory(title_id));
|
||||||
|
|
|
@ -63,7 +63,7 @@ enum class FatalType : u32 {
|
||||||
};
|
};
|
||||||
|
|
||||||
static void GenerateErrorReport(Core::System& system, Result error_code, const FatalInfo& info) {
|
static void GenerateErrorReport(Core::System& system, Result error_code, const FatalInfo& info) {
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
std::string crash_report = fmt::format(
|
std::string crash_report = fmt::format(
|
||||||
"Yuzu {}-{} crash report\n"
|
"Yuzu {}-{} crash report\n"
|
||||||
"Title ID: {:016x}\n"
|
"Title ID: {:016x}\n"
|
||||||
|
|
|
@ -317,7 +317,7 @@ ResultVal<FileSys::VirtualFile> FileSystemController::OpenRomFSCurrentProcess()
|
||||||
return ResultUnknown;
|
return ResultUnknown;
|
||||||
}
|
}
|
||||||
|
|
||||||
return romfs_factory->OpenCurrentProcess(system.GetCurrentProcessProgramID());
|
return romfs_factory->OpenCurrentProcess(system.GetApplicationProcessProgramID());
|
||||||
}
|
}
|
||||||
|
|
||||||
ResultVal<FileSys::VirtualFile> FileSystemController::OpenPatchedRomFS(
|
ResultVal<FileSys::VirtualFile> FileSystemController::OpenPatchedRomFS(
|
||||||
|
@ -502,7 +502,7 @@ FileSys::SaveDataSize FileSystemController::ReadSaveDataSize(FileSys::SaveDataTy
|
||||||
const auto res = system.GetAppLoader().ReadControlData(nacp);
|
const auto res = system.GetAppLoader().ReadControlData(nacp);
|
||||||
|
|
||||||
if (res != Loader::ResultStatus::Success) {
|
if (res != Loader::ResultStatus::Success) {
|
||||||
const FileSys::PatchManager pm{system.GetCurrentProcessProgramID(),
|
const FileSys::PatchManager pm{system.GetApplicationProcessProgramID(),
|
||||||
system.GetFileSystemController(),
|
system.GetFileSystemController(),
|
||||||
system.GetContentProvider()};
|
system.GetContentProvider()};
|
||||||
const auto metadata = pm.GetControlMetadata();
|
const auto metadata = pm.GetControlMetadata();
|
||||||
|
|
|
@ -1036,8 +1036,9 @@ void FSP_SRV::OpenDataStorageWithProgramIndex(Kernel::HLERequestContext& ctx) {
|
||||||
|
|
||||||
LOG_DEBUG(Service_FS, "called, program_index={}", program_index);
|
LOG_DEBUG(Service_FS, "called, program_index={}", program_index);
|
||||||
|
|
||||||
auto patched_romfs = fsc.OpenPatchedRomFSWithProgramIndex(
|
auto patched_romfs =
|
||||||
system.GetCurrentProcessProgramID(), program_index, FileSys::ContentRecordType::Program);
|
fsc.OpenPatchedRomFSWithProgramIndex(system.GetApplicationProcessProgramID(), program_index,
|
||||||
|
FileSys::ContentRecordType::Program);
|
||||||
|
|
||||||
if (patched_romfs.Failed()) {
|
if (patched_romfs.Failed()) {
|
||||||
// TODO: Find the right error code to use here
|
// TODO: Find the right error code to use here
|
||||||
|
|
|
@ -1830,7 +1830,7 @@ void Hid::InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {
|
||||||
ASSERT_MSG(t_mem_1_size == 0x1000, "t_mem_1_size is not 0x1000 bytes");
|
ASSERT_MSG(t_mem_1_size == 0x1000, "t_mem_1_size is not 0x1000 bytes");
|
||||||
ASSERT_MSG(t_mem_2_size == 0x7F000, "t_mem_2_size is not 0x7F000 bytes");
|
ASSERT_MSG(t_mem_2_size == 0x7F000, "t_mem_2_size is not 0x7F000 bytes");
|
||||||
|
|
||||||
auto t_mem_1 = system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
auto t_mem_1 = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
||||||
t_mem_1_handle);
|
t_mem_1_handle);
|
||||||
|
|
||||||
if (t_mem_1.IsNull()) {
|
if (t_mem_1.IsNull()) {
|
||||||
|
@ -1840,7 +1840,7 @@ void Hid::InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto t_mem_2 = system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
auto t_mem_2 = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
||||||
t_mem_2_handle);
|
t_mem_2_handle);
|
||||||
|
|
||||||
if (t_mem_2.IsNull()) {
|
if (t_mem_2.IsNull()) {
|
||||||
|
@ -2127,8 +2127,8 @@ void Hid::WritePalmaWaveEntry(Kernel::HLERequestContext& ctx) {
|
||||||
|
|
||||||
ASSERT_MSG(t_mem_size == 0x3000, "t_mem_size is not 0x3000 bytes");
|
ASSERT_MSG(t_mem_size == 0x3000, "t_mem_size is not 0x3000 bytes");
|
||||||
|
|
||||||
auto t_mem =
|
auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
||||||
system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(t_mem_handle);
|
t_mem_handle);
|
||||||
|
|
||||||
if (t_mem.IsNull()) {
|
if (t_mem.IsNull()) {
|
||||||
LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle);
|
LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle);
|
||||||
|
|
|
@ -449,8 +449,8 @@ void HidBus::EnableJoyPollingReceiveMode(Kernel::HLERequestContext& ctx) {
|
||||||
|
|
||||||
ASSERT_MSG(t_mem_size == 0x1000, "t_mem_size is not 0x1000 bytes");
|
ASSERT_MSG(t_mem_size == 0x1000, "t_mem_size is not 0x1000 bytes");
|
||||||
|
|
||||||
auto t_mem =
|
auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
||||||
system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(t_mem_handle);
|
t_mem_handle);
|
||||||
|
|
||||||
if (t_mem.IsNull()) {
|
if (t_mem.IsNull()) {
|
||||||
LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle);
|
LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle);
|
||||||
|
|
|
@ -196,8 +196,8 @@ void IRS::RunImageTransferProcessor(Kernel::HLERequestContext& ctx) {
|
||||||
const auto parameters{rp.PopRaw<Parameters>()};
|
const auto parameters{rp.PopRaw<Parameters>()};
|
||||||
const auto t_mem_handle{ctx.GetCopyHandle(0)};
|
const auto t_mem_handle{ctx.GetCopyHandle(0)};
|
||||||
|
|
||||||
auto t_mem =
|
auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
||||||
system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(t_mem_handle);
|
t_mem_handle);
|
||||||
|
|
||||||
if (t_mem.IsNull()) {
|
if (t_mem.IsNull()) {
|
||||||
LOG_ERROR(Service_IRS, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle);
|
LOG_ERROR(Service_IRS, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle);
|
||||||
|
@ -445,8 +445,8 @@ void IRS::RunImageTransferExProcessor(Kernel::HLERequestContext& ctx) {
|
||||||
const auto parameters{rp.PopRaw<Parameters>()};
|
const auto parameters{rp.PopRaw<Parameters>()};
|
||||||
const auto t_mem_handle{ctx.GetCopyHandle(0)};
|
const auto t_mem_handle{ctx.GetCopyHandle(0)};
|
||||||
|
|
||||||
auto t_mem =
|
auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(
|
||||||
system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(t_mem_handle);
|
t_mem_handle);
|
||||||
|
|
||||||
u8* transfer_memory = system.Memory().GetPointer(t_mem->GetSourceAddress());
|
u8* transfer_memory = system.Memory().GetPointer(t_mem->GetSourceAddress());
|
||||||
|
|
||||||
|
|
|
@ -353,9 +353,9 @@ public:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch using the handle table for the current process here,
|
// Fetch using the handle table for the application process here,
|
||||||
// since we are not multiprocess yet.
|
// since we are not multiprocess yet.
|
||||||
const auto& handle_table{system.CurrentProcess()->GetHandleTable()};
|
const auto& handle_table{system.ApplicationProcess()->GetHandleTable()};
|
||||||
|
|
||||||
auto process{handle_table.GetObject<Kernel::KProcess>(process_handle)};
|
auto process{handle_table.GetObject<Kernel::KProcess>(process_handle)};
|
||||||
if (process.IsNull()) {
|
if (process.IsNull()) {
|
||||||
|
|
|
@ -246,7 +246,7 @@ public:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (system.GetCurrentProcessProgramID() != header.application_id) {
|
if (system.GetApplicationProcessProgramID() != header.application_id) {
|
||||||
LOG_ERROR(Service_LDR,
|
LOG_ERROR(Service_LDR,
|
||||||
"Attempting to load NRR with title ID other than current process. (actual "
|
"Attempting to load NRR with title ID other than current process. (actual "
|
||||||
"{:016X})!",
|
"{:016X})!",
|
||||||
|
@ -542,15 +542,16 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
// Map memory for the NRO
|
// Map memory for the NRO
|
||||||
const auto map_result{MapNro(system.CurrentProcess(), nro_address, nro_size, bss_address,
|
const auto map_result{MapNro(system.ApplicationProcess(), nro_address, nro_size,
|
||||||
bss_size, nro_size + bss_size)};
|
bss_address, bss_size, nro_size + bss_size)};
|
||||||
if (map_result.Failed()) {
|
if (map_result.Failed()) {
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
rb.Push(map_result.Code());
|
rb.Push(map_result.Code());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load the NRO into the mapped memory
|
// Load the NRO into the mapped memory
|
||||||
if (const auto result{LoadNro(system.CurrentProcess(), header, nro_address, *map_result)};
|
if (const auto result{
|
||||||
|
LoadNro(system.ApplicationProcess(), header, nro_address, *map_result)};
|
||||||
result.IsError()) {
|
result.IsError()) {
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
rb.Push(map_result.Code());
|
rb.Push(map_result.Code());
|
||||||
|
@ -570,7 +571,7 @@ public:
|
||||||
|
|
||||||
Result UnmapNro(const NROInfo& info) {
|
Result UnmapNro(const NROInfo& info) {
|
||||||
// Each region must be unmapped separately to validate memory state
|
// Each region must be unmapped separately to validate memory state
|
||||||
auto& page_table{system.CurrentProcess()->PageTable()};
|
auto& page_table{system.ApplicationProcess()->PageTable()};
|
||||||
|
|
||||||
if (info.bss_size != 0) {
|
if (info.bss_size != 0) {
|
||||||
CASCADE_CODE(page_table.UnmapCodeMemory(
|
CASCADE_CODE(page_table.UnmapCodeMemory(
|
||||||
|
@ -641,7 +642,7 @@ public:
|
||||||
LOG_WARNING(Service_LDR, "(STUBBED) called");
|
LOG_WARNING(Service_LDR, "(STUBBED) called");
|
||||||
|
|
||||||
initialized = true;
|
initialized = true;
|
||||||
current_map_addr = system.CurrentProcess()->PageTable().GetAliasCodeRegionStart();
|
current_map_addr = system.ApplicationProcess()->PageTable().GetAliasCodeRegionStart();
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
|
|
|
@ -618,7 +618,7 @@ Result NfpDevice::RecreateApplicationArea(u32 access_id, std::span<const u8> dat
|
||||||
sizeof(ApplicationArea) - data.size());
|
sizeof(ApplicationArea) - data.size());
|
||||||
|
|
||||||
// TODO: Investigate why the title id needs to be moddified
|
// TODO: Investigate why the title id needs to be moddified
|
||||||
tag_data.title_id = system.GetCurrentProcessProgramID();
|
tag_data.title_id = system.GetApplicationProcessProgramID();
|
||||||
tag_data.title_id = tag_data.title_id | 0x30000000ULL;
|
tag_data.title_id = tag_data.title_id | 0x30000000ULL;
|
||||||
tag_data.settings.settings.appdata_initialized.Assign(1);
|
tag_data.settings.settings.appdata_initialized.Assign(1);
|
||||||
tag_data.application_area_id = access_id;
|
tag_data.application_area_id = access_id;
|
||||||
|
|
|
@ -150,9 +150,9 @@ NvResult nvhost_ctrl::IocCtrlEventWait(std::span<const u8> input, std::vector<u8
|
||||||
const auto check_failing = [&]() {
|
const auto check_failing = [&]() {
|
||||||
if (events[slot].fails > 2) {
|
if (events[slot].fails > 2) {
|
||||||
{
|
{
|
||||||
auto lk = system.StallProcesses();
|
auto lk = system.StallApplication();
|
||||||
host1x_syncpoint_manager.WaitHost(fence_id, target_value);
|
host1x_syncpoint_manager.WaitHost(fence_id, target_value);
|
||||||
system.UnstallProcesses();
|
system.UnstallApplication();
|
||||||
}
|
}
|
||||||
params.value.raw = target_value;
|
params.value.raw = target_value;
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -127,7 +127,7 @@ NvResult nvmap::IocAlloc(std::span<const u8> input, std::vector<u8>& output) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
bool is_out_io{};
|
bool is_out_io{};
|
||||||
ASSERT(system.CurrentProcess()
|
ASSERT(system.ApplicationProcess()
|
||||||
->PageTable()
|
->PageTable()
|
||||||
.LockForMapDeviceAddressSpace(&is_out_io, handle_description->address,
|
.LockForMapDeviceAddressSpace(&is_out_io, handle_description->address,
|
||||||
handle_description->size,
|
handle_description->size,
|
||||||
|
@ -254,7 +254,7 @@ NvResult nvmap::IocFree(std::span<const u8> input, std::vector<u8>& output) {
|
||||||
|
|
||||||
if (auto freeInfo{file.FreeHandle(params.handle, false)}) {
|
if (auto freeInfo{file.FreeHandle(params.handle, false)}) {
|
||||||
if (freeInfo->can_unlock) {
|
if (freeInfo->can_unlock) {
|
||||||
ASSERT(system.CurrentProcess()
|
ASSERT(system.ApplicationProcess()
|
||||||
->PageTable()
|
->PageTable()
|
||||||
.UnlockForDeviceAddressSpace(freeInfo->address, freeInfo->size)
|
.UnlockForDeviceAddressSpace(freeInfo->address, freeInfo->size)
|
||||||
.IsSuccess());
|
.IsSuccess());
|
||||||
|
|
|
@ -187,7 +187,7 @@ private:
|
||||||
|
|
||||||
// TODO(ogniK): Recovery flag initialization for pctl:r
|
// TODO(ogniK): Recovery flag initialization for pctl:r
|
||||||
|
|
||||||
const auto tid = system.GetCurrentProcessProgramID();
|
const auto tid = system.GetApplicationProcessProgramID();
|
||||||
if (tid != 0) {
|
if (tid != 0) {
|
||||||
const FileSys::PatchManager pm{tid, system.GetFileSystemController(),
|
const FileSys::PatchManager pm{tid, system.GetFileSystemController(),
|
||||||
system.GetContentProvider()};
|
system.GetContentProvider()};
|
||||||
|
|
|
@ -71,7 +71,7 @@ private:
|
||||||
Type, process_id, data1.size(), data2.size());
|
Type, process_id, data1.size(), data2.size());
|
||||||
|
|
||||||
const auto& reporter{system.GetReporter()};
|
const auto& reporter{system.GetReporter()};
|
||||||
reporter.SavePlayReport(Type, system.GetCurrentProcessProgramID(), {data1, data2},
|
reporter.SavePlayReport(Type, system.GetApplicationProcessProgramID(), {data1, data2},
|
||||||
process_id);
|
process_id);
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
|
@ -99,7 +99,7 @@ private:
|
||||||
Type, user_id[1], user_id[0], process_id, data1.size(), data2.size());
|
Type, user_id[1], user_id[0], process_id, data1.size(), data2.size());
|
||||||
|
|
||||||
const auto& reporter{system.GetReporter()};
|
const auto& reporter{system.GetReporter()};
|
||||||
reporter.SavePlayReport(Type, system.GetCurrentProcessProgramID(), {data1, data2},
|
reporter.SavePlayReport(Type, system.GetApplicationProcessProgramID(), {data1, data2},
|
||||||
process_id, user_id);
|
process_id, user_id);
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
|
|
|
@ -145,7 +145,7 @@ std::optional<VAddr> AppLoader_NSO::LoadModule(Kernel::KProcess& process, Core::
|
||||||
|
|
||||||
// Apply cheats if they exist and the program has a valid title ID
|
// Apply cheats if they exist and the program has a valid title ID
|
||||||
if (pm) {
|
if (pm) {
|
||||||
system.SetCurrentProcessBuildID(nso_header.build_id);
|
system.SetApplicationProcessBuildID(nso_header.build_id);
|
||||||
const auto cheats = pm->CreateCheatList(nso_header.build_id);
|
const auto cheats = pm->CreateCheatList(nso_header.build_id);
|
||||||
if (!cheats.empty()) {
|
if (!cheats.empty()) {
|
||||||
system.RegisterCheatList(cheats, nso_header.build_id, load_base, image_size);
|
system.RegisterCheatList(cheats, nso_header.build_id, load_base, image_size);
|
||||||
|
|
|
@ -247,11 +247,11 @@ struct Memory::Impl {
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReadBlock(const VAddr src_addr, void* dest_buffer, const std::size_t size) {
|
void ReadBlock(const VAddr src_addr, void* dest_buffer, const std::size_t size) {
|
||||||
ReadBlockImpl<false>(*system.CurrentProcess(), src_addr, dest_buffer, size);
|
ReadBlockImpl<false>(*system.ApplicationProcess(), src_addr, dest_buffer, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReadBlockUnsafe(const VAddr src_addr, void* dest_buffer, const std::size_t size) {
|
void ReadBlockUnsafe(const VAddr src_addr, void* dest_buffer, const std::size_t size) {
|
||||||
ReadBlockImpl<true>(*system.CurrentProcess(), src_addr, dest_buffer, size);
|
ReadBlockImpl<true>(*system.ApplicationProcess(), src_addr, dest_buffer, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool UNSAFE>
|
template <bool UNSAFE>
|
||||||
|
@ -279,11 +279,11 @@ struct Memory::Impl {
|
||||||
}
|
}
|
||||||
|
|
||||||
void WriteBlock(const VAddr dest_addr, const void* src_buffer, const std::size_t size) {
|
void WriteBlock(const VAddr dest_addr, const void* src_buffer, const std::size_t size) {
|
||||||
WriteBlockImpl<false>(*system.CurrentProcess(), dest_addr, src_buffer, size);
|
WriteBlockImpl<false>(*system.ApplicationProcess(), dest_addr, src_buffer, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WriteBlockUnsafe(const VAddr dest_addr, const void* src_buffer, const std::size_t size) {
|
void WriteBlockUnsafe(const VAddr dest_addr, const void* src_buffer, const std::size_t size) {
|
||||||
WriteBlockImpl<true>(*system.CurrentProcess(), dest_addr, src_buffer, size);
|
WriteBlockImpl<true>(*system.ApplicationProcess(), dest_addr, src_buffer, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ZeroBlock(const Kernel::KProcess& process, const VAddr dest_addr, const std::size_t size) {
|
void ZeroBlock(const Kernel::KProcess& process, const VAddr dest_addr, const std::size_t size) {
|
||||||
|
@ -711,7 +711,7 @@ void Memory::UnmapRegion(Common::PageTable& page_table, VAddr base, u64 size) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Memory::IsValidVirtualAddress(const VAddr vaddr) const {
|
bool Memory::IsValidVirtualAddress(const VAddr vaddr) const {
|
||||||
const Kernel::KProcess& process = *system.CurrentProcess();
|
const Kernel::KProcess& process = *system.ApplicationProcess();
|
||||||
const auto& page_table = process.PageTable().PageTableImpl();
|
const auto& page_table = process.PageTable().PageTableImpl();
|
||||||
const size_t page = vaddr >> YUZU_PAGEBITS;
|
const size_t page = vaddr >> YUZU_PAGEBITS;
|
||||||
if (page >= page_table.pointers.size()) {
|
if (page >= page_table.pointers.size()) {
|
||||||
|
|
|
@ -191,10 +191,10 @@ void CheatEngine::Initialize() {
|
||||||
});
|
});
|
||||||
core_timing.ScheduleLoopingEvent(CHEAT_ENGINE_NS, CHEAT_ENGINE_NS, event);
|
core_timing.ScheduleLoopingEvent(CHEAT_ENGINE_NS, CHEAT_ENGINE_NS, event);
|
||||||
|
|
||||||
metadata.process_id = system.CurrentProcess()->GetProcessID();
|
metadata.process_id = system.ApplicationProcess()->GetProcessID();
|
||||||
metadata.title_id = system.GetCurrentProcessProgramID();
|
metadata.title_id = system.GetApplicationProcessProgramID();
|
||||||
|
|
||||||
const auto& page_table = system.CurrentProcess()->PageTable();
|
const auto& page_table = system.ApplicationProcess()->PageTable();
|
||||||
metadata.heap_extents = {
|
metadata.heap_extents = {
|
||||||
.base = page_table.GetHeapRegionStart(),
|
.base = page_table.GetHeapRegionStart(),
|
||||||
.size = page_table.GetHeapRegionSize(),
|
.size = page_table.GetHeapRegionSize(),
|
||||||
|
|
|
@ -110,7 +110,7 @@ json GetProcessorStateData(const std::string& architecture, u64 entry_point, u64
|
||||||
}
|
}
|
||||||
|
|
||||||
json GetProcessorStateDataAuto(Core::System& system) {
|
json GetProcessorStateDataAuto(Core::System& system) {
|
||||||
const auto* process{system.CurrentProcess()};
|
const auto* process{system.ApplicationProcess()};
|
||||||
auto& arm{system.CurrentArmInterface()};
|
auto& arm{system.CurrentArmInterface()};
|
||||||
|
|
||||||
Core::ARM_Interface::ThreadContext64 context{};
|
Core::ARM_Interface::ThreadContext64 context{};
|
||||||
|
@ -234,7 +234,7 @@ void Reporter::SaveSvcBreakReport(u32 type, bool signal_debugger, u64 info1, u64
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto timestamp = GetTimestamp();
|
const auto timestamp = GetTimestamp();
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
auto out = GetFullDataAuto(timestamp, title_id, system);
|
auto out = GetFullDataAuto(timestamp, title_id, system);
|
||||||
|
|
||||||
auto break_out = json{
|
auto break_out = json{
|
||||||
|
@ -261,7 +261,7 @@ void Reporter::SaveUnimplementedFunctionReport(Kernel::HLERequestContext& ctx, u
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto timestamp = GetTimestamp();
|
const auto timestamp = GetTimestamp();
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
auto out = GetFullDataAuto(timestamp, title_id, system);
|
auto out = GetFullDataAuto(timestamp, title_id, system);
|
||||||
|
|
||||||
auto function_out = GetHLERequestContextData(ctx, system.Memory());
|
auto function_out = GetHLERequestContextData(ctx, system.Memory());
|
||||||
|
@ -283,7 +283,7 @@ void Reporter::SaveUnimplementedAppletReport(
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto timestamp = GetTimestamp();
|
const auto timestamp = GetTimestamp();
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
auto out = GetFullDataAuto(timestamp, title_id, system);
|
auto out = GetFullDataAuto(timestamp, title_id, system);
|
||||||
|
|
||||||
out["applet_common_args"] = {
|
out["applet_common_args"] = {
|
||||||
|
@ -376,7 +376,7 @@ void Reporter::SaveUserReport() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto timestamp = GetTimestamp();
|
const auto timestamp = GetTimestamp();
|
||||||
const auto title_id = system.GetCurrentProcessProgramID();
|
const auto title_id = system.GetApplicationProcessProgramID();
|
||||||
|
|
||||||
SaveToFile(GetFullDataAuto(timestamp, title_id, system),
|
SaveToFile(GetFullDataAuto(timestamp, title_id, system),
|
||||||
GetPath("user_report", title_id, timestamp));
|
GetPath("user_report", title_id, timestamp));
|
||||||
|
|
|
@ -67,7 +67,7 @@ void EmuThread::run() {
|
||||||
emit LoadProgress(VideoCore::LoadCallbackStage::Prepare, 0, 0);
|
emit LoadProgress(VideoCore::LoadCallbackStage::Prepare, 0, 0);
|
||||||
if (Settings::values.use_disk_shader_cache.GetValue()) {
|
if (Settings::values.use_disk_shader_cache.GetValue()) {
|
||||||
m_system.Renderer().ReadRasterizer()->LoadDiskResources(
|
m_system.Renderer().ReadRasterizer()->LoadDiskResources(
|
||||||
m_system.GetCurrentProcessProgramID(), stop_token,
|
m_system.GetApplicationProcessProgramID(), stop_token,
|
||||||
[this](VideoCore::LoadCallbackStage stage, std::size_t value, std::size_t total) {
|
[this](VideoCore::LoadCallbackStage stage, std::size_t value, std::size_t total) {
|
||||||
emit LoadProgress(stage, value, total);
|
emit LoadProgress(stage, value, total);
|
||||||
});
|
});
|
||||||
|
|
|
@ -1779,7 +1779,7 @@ void GMainWindow::BootGame(const QString& filename, u64 program_id, std::size_t
|
||||||
std::filesystem::path{Common::U16StringFromBuffer(filename.utf16(), filename.size())}
|
std::filesystem::path{Common::U16StringFromBuffer(filename.utf16(), filename.size())}
|
||||||
.filename());
|
.filename());
|
||||||
}
|
}
|
||||||
const bool is_64bit = system->Kernel().CurrentProcess()->Is64BitProcess();
|
const bool is_64bit = system->Kernel().ApplicationProcess()->Is64BitProcess();
|
||||||
const auto instruction_set_suffix = is_64bit ? tr("(64-bit)") : tr("(32-bit)");
|
const auto instruction_set_suffix = is_64bit ? tr("(64-bit)") : tr("(32-bit)");
|
||||||
title_name = tr("%1 %2", "%1 is the title name. %2 indicates if the title is 64-bit or 32-bit")
|
title_name = tr("%1 %2", "%1 is the title name. %2 indicates if the title is 64-bit or 32-bit")
|
||||||
.arg(QString::fromStdString(title_name), instruction_set_suffix)
|
.arg(QString::fromStdString(title_name), instruction_set_suffix)
|
||||||
|
@ -3532,7 +3532,7 @@ void GMainWindow::OnToggleGraphicsAPI() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void GMainWindow::OnConfigurePerGame() {
|
void GMainWindow::OnConfigurePerGame() {
|
||||||
const u64 title_id = system->GetCurrentProcessProgramID();
|
const u64 title_id = system->GetApplicationProcessProgramID();
|
||||||
OpenPerGameConfiguration(title_id, current_game_path.toStdString());
|
OpenPerGameConfiguration(title_id, current_game_path.toStdString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3691,7 +3691,7 @@ void GMainWindow::OnCaptureScreenshot() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const u64 title_id = system->GetCurrentProcessProgramID();
|
const u64 title_id = system->GetApplicationProcessProgramID();
|
||||||
const auto screenshot_path =
|
const auto screenshot_path =
|
||||||
QString::fromStdString(Common::FS::GetYuzuPathString(Common::FS::YuzuPath::ScreenshotsDir));
|
QString::fromStdString(Common::FS::GetYuzuPathString(Common::FS::YuzuPath::ScreenshotsDir));
|
||||||
const auto date =
|
const auto date =
|
||||||
|
|
|
@ -405,7 +405,7 @@ int main(int argc, char** argv) {
|
||||||
|
|
||||||
if (Settings::values.use_disk_shader_cache.GetValue()) {
|
if (Settings::values.use_disk_shader_cache.GetValue()) {
|
||||||
system.Renderer().ReadRasterizer()->LoadDiskResources(
|
system.Renderer().ReadRasterizer()->LoadDiskResources(
|
||||||
system.GetCurrentProcessProgramID(), std::stop_token{},
|
system.GetApplicationProcessProgramID(), std::stop_token{},
|
||||||
[](VideoCore::LoadCallbackStage, size_t value, size_t total) {});
|
[](VideoCore::LoadCallbackStage, size_t value, size_t total) {});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue