forked from Mirror/Ryujinx
nim: Implement IsLargeResourceAvailable (#1821)
* nim: Implement IsLargeResourceAvailable * Fix comments
This commit is contained in:
parent
f5d64b4d68
commit
eae39f80e7
2 changed files with 31 additions and 0 deletions
|
@ -1,4 +1,6 @@
|
||||||
using Ryujinx.Common.Logging;
|
using Ryujinx.Common.Logging;
|
||||||
|
using Ryujinx.HLE.FileSystem;
|
||||||
|
using Ryujinx.HLE.HOS.Services.Arp;
|
||||||
using Ryujinx.HLE.HOS.Services.Nim.ShopServiceAccessServerInterface;
|
using Ryujinx.HLE.HOS.Services.Nim.ShopServiceAccessServerInterface;
|
||||||
|
|
||||||
namespace Ryujinx.HLE.HOS.Services.Nim
|
namespace Ryujinx.HLE.HOS.Services.Nim
|
||||||
|
@ -18,5 +20,22 @@ namespace Ryujinx.HLE.HOS.Services.Nim
|
||||||
|
|
||||||
return ResultCode.Success;
|
return ResultCode.Success;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Command(4)] // 10.0.0+
|
||||||
|
// IsLargeResourceAvailable(pid) -> b8
|
||||||
|
public ResultCode IsLargeResourceAvailable(ServiceCtx context)
|
||||||
|
{
|
||||||
|
// TODO: Service calls arp:r GetApplicationInstanceId (10.0.0+) then if it fails it calls arp:r GetMicroApplicationInstanceId (10.0.0+)
|
||||||
|
// then if it fails it returns the arp:r result code.
|
||||||
|
|
||||||
|
// NOTE: Firmare 10.0.0+ don't use the Pid here anymore, but the returned InstanceId. We don't support that for now so we can just use the Pid instead.
|
||||||
|
StorageId baseStorageId = (StorageId)ApplicationLaunchProperty.GetByPid(context).BaseGameStorageId;
|
||||||
|
|
||||||
|
// NOTE: Service returns ResultCode.InvalidArgument if baseStorageId is null, doesn't occur in our case.
|
||||||
|
|
||||||
|
context.ResponseData.Write(baseStorageId == StorageId.Host);
|
||||||
|
|
||||||
|
return ResultCode.Success;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
12
Ryujinx.HLE/HOS/Services/Nim/ResultCode.cs
Normal file
12
Ryujinx.HLE/HOS/Services/Nim/ResultCode.cs
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
namespace Ryujinx.HLE.HOS.Services.Nim
|
||||||
|
{
|
||||||
|
enum ResultCode
|
||||||
|
{
|
||||||
|
ModuleId = 137,
|
||||||
|
ErrorCodeShift = 9,
|
||||||
|
|
||||||
|
Success = 0,
|
||||||
|
|
||||||
|
NullArgument = (90 << ErrorCodeShift) | ModuleId
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue