Atmosphere/stratosphere/pm/source/pm_shell.cpp

114 lines
3.6 KiB
C++
Raw Normal View History

/*
2019-04-08 04:00:49 +02:00
* Copyright (c) 2018-2019 Atmosphère-NX
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
2018-05-05 02:25:26 +02:00
#include <switch.h>
#include <stratosphere.hpp>
2018-05-05 02:25:26 +02:00
#include "pm_registration.hpp"
#include "pm_resource_limits.hpp"
2018-05-05 02:25:26 +02:00
#include "pm_shell.hpp"
2018-07-27 11:23:53 +02:00
#include "pm_boot2.hpp"
2018-05-05 02:25:26 +02:00
static bool g_has_boot_finished = false;
Result ShellService::LaunchProcess(Out<u64> pid, Registration::TidSid tid_sid, u32 launch_flags) {
return Registration::LaunchProcessByTidSid(tid_sid, launch_flags, pid.GetPointer());
2018-05-05 02:25:26 +02:00
}
Result ShellService::TerminateProcessId(u64 pid) {
std::scoped_lock<ProcessList &> lk(Registration::GetProcessList());
auto proc = Registration::GetProcess(pid);
if (proc != nullptr) {
return svcTerminateProcess(proc->handle);
} else {
return ResultPmProcessNotFound;
}
2018-05-05 02:25:26 +02:00
}
Result ShellService::TerminateTitleId(u64 tid) {
std::scoped_lock<ProcessList &> lk(Registration::GetProcessList());
auto proc = Registration::GetProcessByTitleId(tid);
if (proc != NULL) {
return svcTerminateProcess(proc->handle);
} else {
return ResultPmProcessNotFound;
}
2018-05-05 02:25:26 +02:00
}
void ShellService::GetProcessWaitEvent(Out<CopiedHandle> event) {
event.SetValue(Registration::GetProcessEventHandle());
2018-05-05 02:25:26 +02:00
}
void ShellService::GetProcessEventType(Out<u64> type, Out<u64> pid) {
Registration::GetProcessEventType(pid.GetPointer(), type.GetPointer());
2018-05-05 02:25:26 +02:00
}
Result ShellService::FinalizeExitedProcess(u64 pid) {
std::scoped_lock<ProcessList &> lk(Registration::GetProcessList());
auto proc = Registration::GetProcess(pid);
if (proc == NULL) {
return ResultPmProcessNotFound;
} else if (proc->state != ProcessState_Exited) {
return ResultPmNotExited;
} else {
Registration::FinalizeExitedProcess(proc);
2019-03-29 06:39:39 +01:00
return ResultSuccess;
}
2018-05-05 02:25:26 +02:00
}
Result ShellService::ClearProcessNotificationFlag(u64 pid) {
std::scoped_lock<ProcessList &> lk(Registration::GetProcessList());
auto proc = Registration::GetProcess(pid);
if (proc != NULL) {
proc->flags &= ~PROCESSFLAGS_CRASHED;
2019-03-29 06:39:39 +01:00
return ResultSuccess;
} else {
return ResultPmProcessNotFound;
}
2018-05-05 02:25:26 +02:00
}
void ShellService::NotifyBootFinished() {
2018-05-05 02:25:26 +02:00
if (!g_has_boot_finished) {
g_has_boot_finished = true;
2018-07-27 11:23:53 +02:00
EmbeddedBoot2::Main();
2018-05-05 02:25:26 +02:00
}
}
Result ShellService::GetApplicationProcessId(Out<u64> pid) {
std::scoped_lock<ProcessList &> lk(Registration::GetProcessList());
std::shared_ptr<Registration::Process> app_proc;
if (Registration::HasApplicationProcess(&app_proc)) {
pid.SetValue(app_proc->pid);
2019-03-29 06:39:39 +01:00
return ResultSuccess;
}
return ResultPmProcessNotFound;
2018-05-05 02:25:26 +02:00
}
Result ShellService::BoostSystemMemoryResourceLimit(u64 sysmem_size) {
return ResourceLimitUtils::BoostSystemMemoryResourceLimit(sysmem_size);
2018-05-05 02:25:26 +02:00
}
2019-01-31 12:32:47 +01:00
Result ShellService::BoostSystemThreadsResourceLimit() {
/* Starting in 7.0.0, Nintendo reduces the number of system threads from 0x260 to 0x60, */
/* Until this command is called to double that amount to 0xC0. */
/* We will simply not reduce the number of system threads available for no reason. */
2019-03-29 06:39:39 +01:00
return ResultSuccess;
2019-01-31 12:32:47 +01:00
}