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.HLE.FileSystem;
|
||||
using Ryujinx.HLE.HOS.Services.Arp;
|
||||
using Ryujinx.HLE.HOS.Services.Nim.ShopServiceAccessServerInterface;
|
||||
|
||||
namespace Ryujinx.HLE.HOS.Services.Nim
|
||||
|
@ -18,5 +20,22 @@ namespace Ryujinx.HLE.HOS.Services.Nim
|
|||
|
||||
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