mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-11 23:34:50 +00:00
kern: Add 4.x InitialProcessIdRange to SvcGetInfo
This commit is contained in:
parent
91fa0d651f
commit
3289b45408
1 changed files with 33 additions and 16 deletions
|
@ -21,6 +21,23 @@ namespace ams::kern::svc {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
Result GetInitialProcessIdRange(u64 *out, ams::svc::InitialProcessIdRangeInfo info) {
|
||||||
|
switch (info) {
|
||||||
|
case ams::svc::InitialProcessIdRangeInfo_Minimum:
|
||||||
|
MESOSPHERE_ABORT_UNLESS(GetInitialProcessIdMin() <= GetInitialProcessIdMax());
|
||||||
|
*out = GetInitialProcessIdMin();
|
||||||
|
break;
|
||||||
|
case ams::svc::InitialProcessIdRangeInfo_Maximum:
|
||||||
|
MESOSPHERE_ABORT_UNLESS(GetInitialProcessIdMin() <= GetInitialProcessIdMax());
|
||||||
|
*out = GetInitialProcessIdMax();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return svc::ResultInvalidCombination();
|
||||||
|
}
|
||||||
|
|
||||||
|
return ResultSuccess();
|
||||||
|
}
|
||||||
|
|
||||||
Result GetInfo(u64 *out, ams::svc::InfoType info_type, ams::svc::Handle handle, u64 info_subtype) {
|
Result GetInfo(u64 *out, ams::svc::InfoType info_type, ams::svc::Handle handle, u64 info_subtype) {
|
||||||
switch (info_type) {
|
switch (info_type) {
|
||||||
case ams::svc::InfoType_CoreMask:
|
case ams::svc::InfoType_CoreMask:
|
||||||
|
@ -38,7 +55,6 @@ namespace ams::kern::svc {
|
||||||
case ams::svc::InfoType_SystemResourceSizeTotal:
|
case ams::svc::InfoType_SystemResourceSizeTotal:
|
||||||
case ams::svc::InfoType_SystemResourceSizeUsed:
|
case ams::svc::InfoType_SystemResourceSizeUsed:
|
||||||
case ams::svc::InfoType_ProgramId:
|
case ams::svc::InfoType_ProgramId:
|
||||||
case ams::svc::InfoType_InitialProcessIdRange:
|
|
||||||
case ams::svc::InfoType_UserExceptionContextAddress:
|
case ams::svc::InfoType_UserExceptionContextAddress:
|
||||||
case ams::svc::InfoType_TotalNonSystemMemorySize:
|
case ams::svc::InfoType_TotalNonSystemMemorySize:
|
||||||
case ams::svc::InfoType_UsedNonSystemMemorySize:
|
case ams::svc::InfoType_UsedNonSystemMemorySize:
|
||||||
|
@ -97,9 +113,6 @@ namespace ams::kern::svc {
|
||||||
case ams::svc::InfoType_ProgramId:
|
case ams::svc::InfoType_ProgramId:
|
||||||
*out = process->GetProgramId();
|
*out = process->GetProgramId();
|
||||||
break;
|
break;
|
||||||
case ams::svc::InfoType_InitialProcessIdRange:
|
|
||||||
/* TODO: Detect exactly 4.0.0 target firmware, do the right thing. */
|
|
||||||
return svc::ResultInvalidEnumValue();
|
|
||||||
case ams::svc::InfoType_UserExceptionContextAddress:
|
case ams::svc::InfoType_UserExceptionContextAddress:
|
||||||
*out = GetInteger(process->GetProcessLocalRegionAddress());
|
*out = GetInteger(process->GetProcessLocalRegionAddress());
|
||||||
break;
|
break;
|
||||||
|
@ -178,6 +191,18 @@ namespace ams::kern::svc {
|
||||||
*out = GetCurrentProcess().GetRandomEntropy(info_subtype);
|
*out = GetCurrentProcess().GetRandomEntropy(info_subtype);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case ams::svc::InfoType_InitialProcessIdRange:
|
||||||
|
{
|
||||||
|
/* NOTE: This info type was added in 4.0.0, and removed in 5.0.0. */
|
||||||
|
R_UNLESS(GetTargetFirmware() < TargetFirmware_5_0_0, svc::ResultInvalidEnumValue());
|
||||||
|
|
||||||
|
/* Verify the input handle is invalid. */
|
||||||
|
R_UNLESS(handle == ams::svc::InvalidHandle, svc::ResultInvalidHandle());
|
||||||
|
|
||||||
|
/* Get the process id range. */
|
||||||
|
R_TRY(GetInitialProcessIdRange(out, static_cast<ams::svc::InitialProcessIdRangeInfo>(info_subtype)));
|
||||||
|
}
|
||||||
|
break;
|
||||||
case ams::svc::InfoType_ThreadTickCount:
|
case ams::svc::InfoType_ThreadTickCount:
|
||||||
{
|
{
|
||||||
/* Verify the requested core is valid. */
|
/* Verify the requested core is valid. */
|
||||||
|
@ -262,19 +287,11 @@ namespace ams::kern::svc {
|
||||||
break;
|
break;
|
||||||
case ams::svc::SystemInfoType_InitialProcessIdRange:
|
case ams::svc::SystemInfoType_InitialProcessIdRange:
|
||||||
{
|
{
|
||||||
|
/* Verify the handle is invalid. */
|
||||||
R_UNLESS(handle == ams::svc::InvalidHandle, svc::ResultInvalidHandle());
|
R_UNLESS(handle == ams::svc::InvalidHandle, svc::ResultInvalidHandle());
|
||||||
switch (static_cast<ams::svc::InitialProcessIdRangeInfo>(info_subtype)) {
|
|
||||||
case ams::svc::InitialProcessIdRangeInfo_Minimum:
|
/* Get the process id range. */
|
||||||
MESOSPHERE_ABORT_UNLESS(GetInitialProcessIdMin() <= GetInitialProcessIdMax());
|
R_TRY(GetInitialProcessIdRange(out, static_cast<ams::svc::InitialProcessIdRangeInfo>(info_subtype)));
|
||||||
*out = GetInitialProcessIdMin();
|
|
||||||
break;
|
|
||||||
case ams::svc::InitialProcessIdRangeInfo_Maximum:
|
|
||||||
MESOSPHERE_ABORT_UNLESS(GetInitialProcessIdMin() <= GetInitialProcessIdMax());
|
|
||||||
*out = GetInitialProcessIdMax();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return svc::ResultInvalidCombination();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in a new issue