diff options
| author | Ac_K <Acoustik666@gmail.com> | 2020-07-27 01:04:08 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-07-27 01:04:08 +0200 |
| commit | ca0d1f8205c3988d916033e2d950a421ddb995af (patch) | |
| tree | 84871d4501cba182a92be3e037c2fb3cae16d512 /Ryujinx.HLE/HOS/Services/Ns | |
| parent | d8515b603bff4712fe0e84113d7f7823a84c85eb (diff) | |
ns/nim: Stub eShop related calls (#1420)
* ns/nim: Stub eShop related calls
As we aren't able to process purchase on the eShop throught the emulator, I have:
- Stub IPurchaseEventManager::SetDefaultDeliveryTarget (with RE check).
- Implement IPurchaseEventManager::GetPurchasedEventReadableHandle (with RE check).
As we can't do any eShop async call throught the emulator, I have:
- Stub IShopServiceAccessServerInterface::CreateServerInterface
- Stub IShopServiceAccessServer::CreateAccessorInterface
- Stub IShopServiceAccessor::IShopServiceAsync
Close #1084 and #1322
* fix handle copy
* Fix align
* Fix readonly event
Diffstat (limited to 'Ryujinx.HLE/HOS/Services/Ns')
| -rw-r--r-- | Ryujinx.HLE/HOS/Services/Ns/IAddOnContentManager.cs | 4 | ||||
| -rw-r--r-- | Ryujinx.HLE/HOS/Services/Ns/IPurchaseEventManager.cs | 48 |
2 files changed, 48 insertions, 4 deletions
diff --git a/Ryujinx.HLE/HOS/Services/Ns/IAddOnContentManager.cs b/Ryujinx.HLE/HOS/Services/Ns/IAddOnContentManager.cs index 20d95cbb..e6e42c41 100644 --- a/Ryujinx.HLE/HOS/Services/Ns/IAddOnContentManager.cs +++ b/Ryujinx.HLE/HOS/Services/Ns/IAddOnContentManager.cs @@ -165,7 +165,7 @@ namespace Ryujinx.HLE.HOS.Services.Ns // CreateEcPurchasedEventManager() -> object<nn::ec::IPurchaseEventManager> public ResultCode CreateEcPurchasedEventManager(ServiceCtx context) { - MakeObject(context, new IPurchaseEventManager()); + MakeObject(context, new IPurchaseEventManager(context.Device.System)); Logger.PrintStub(LogClass.ServiceNs); @@ -178,7 +178,7 @@ namespace Ryujinx.HLE.HOS.Services.Ns { // Very similar to CreateEcPurchasedEventManager but with some extra code - MakeObject(context, new IPurchaseEventManager()); + MakeObject(context, new IPurchaseEventManager(context.Device.System)); Logger.PrintStub(LogClass.ServiceNs); diff --git a/Ryujinx.HLE/HOS/Services/Ns/IPurchaseEventManager.cs b/Ryujinx.HLE/HOS/Services/Ns/IPurchaseEventManager.cs index 6a512b7b..8bb05b04 100644 --- a/Ryujinx.HLE/HOS/Services/Ns/IPurchaseEventManager.cs +++ b/Ryujinx.HLE/HOS/Services/Ns/IPurchaseEventManager.cs @@ -1,8 +1,52 @@ +using Ryujinx.Common; +using Ryujinx.Common.Logging; +using Ryujinx.HLE.HOS.Ipc; +using Ryujinx.HLE.HOS.Kernel.Common; +using Ryujinx.HLE.HOS.Kernel.Threading; +using System; + namespace Ryujinx.HLE.HOS.Services.Ns { class IPurchaseEventManager : IpcService { - // TODO: Implement this - // Size seems to be atleast 0x7a8 + private readonly KEvent _purchasedEvent; + + public IPurchaseEventManager(Horizon system) + { + _purchasedEvent = new KEvent(system.KernelContext); + } + + [Command(0)] + // SetDefaultDeliveryTarget(pid, buffer<bytes, 5> unknown) + public ResultCode SetDefaultDeliveryTarget(ServiceCtx context) + { + long inBufferPosition = context.Request.SendBuff[0].Position; + long inBufferSize = context.Request.SendBuff[0].Size; + byte[] buffer = new byte[inBufferSize]; + + context.Memory.Read((ulong)inBufferPosition, buffer); + + // NOTE: Service use the pid to call arp:r GetApplicationLaunchProperty and store it in internal field. + // Then it seems to use the buffer content and compare it with a stored linked instrusive list. + // Since we don't support purchase from eShop, we can stub it. + + Logger.PrintStub(LogClass.ServiceNs); + + return ResultCode.Success; + } + + [Command(2)] + // GetPurchasedEventReadableHandle() -> handle<copy, event> + public ResultCode GetPurchasedEventReadableHandle(ServiceCtx context) + { + if (context.Process.HandleTable.GenerateHandle(_purchasedEvent.ReadableEvent, out int handle) != KernelResult.Success) + { + throw new InvalidOperationException("Out of handles!"); + } + + context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle); + + return ResultCode.Success; + } } }
\ No newline at end of file |
