From b57193fff903d4ef4ab8ebb2f2345832be84591d Mon Sep 17 00:00:00 2001 From: Starlet Date: Fri, 13 Jul 2018 21:37:59 -0400 Subject: [PATCH] Initial stubs --- .../Services/Am/IApplicationFunctions.cs | 21 +++++++++++++++ .../OsHle/Services/Nifm/IGeneralService.cs | 27 ++++++++++++++++++- .../Services/Pctl/IParentalControlService.cs | 10 ++++++- 3 files changed, 56 insertions(+), 2 deletions(-) diff --git a/Ryujinx.HLE/OsHle/Services/Am/IApplicationFunctions.cs b/Ryujinx.HLE/OsHle/Services/Am/IApplicationFunctions.cs index e25b524ab..78a9a187d 100644 --- a/Ryujinx.HLE/OsHle/Services/Am/IApplicationFunctions.cs +++ b/Ryujinx.HLE/OsHle/Services/Am/IApplicationFunctions.cs @@ -19,6 +19,8 @@ namespace Ryujinx.HLE.OsHle.Services.Am { 21, GetDesiredLanguage }, { 22, SetTerminateResult }, { 23, GetDisplayVersion }, + { 25, ExtendSaveData }, + { 26, GetSaveDataSize }, { 40, NotifyRunning }, { 50, GetPseudoDeviceId }, { 66, InitializeGamePlayRecording }, @@ -81,6 +83,25 @@ namespace Ryujinx.HLE.OsHle.Services.Am return 0; } + public long ExtendSaveData(ServiceCtx Context) + { + Context.Ns.Log.PrintStub(LogClass.ServiceAm, "Stubbed."); + + Context.ResponseData.Write(0x400L); + + return 0; + } + + public long GetSaveDataSize(ServiceCtx Context) + { + Context.Ns.Log.PrintStub(LogClass.ServiceAm, "Stubbed."); + + Context.ResponseData.Write(0L); + Context.ResponseData.Write(0x200L); + + return 0; + } + public long NotifyRunning(ServiceCtx Context) { Context.ResponseData.Write(1); diff --git a/Ryujinx.HLE/OsHle/Services/Nifm/IGeneralService.cs b/Ryujinx.HLE/OsHle/Services/Nifm/IGeneralService.cs index e289a8db8..e16d24184 100644 --- a/Ryujinx.HLE/OsHle/Services/Nifm/IGeneralService.cs +++ b/Ryujinx.HLE/OsHle/Services/Nifm/IGeneralService.cs @@ -14,7 +14,9 @@ namespace Ryujinx.HLE.OsHle.Services.Nifm { m_Commands = new Dictionary() { - { 4, CreateRequest } + { 4, CreateRequest }, + { 5, GetCurrentNetworkProfile }, + { 12, GetCurrentIpAddress } }; } @@ -29,5 +31,28 @@ namespace Ryujinx.HLE.OsHle.Services.Nifm return 0; } + + public long GetCurrentNetworkProfile(ServiceCtx Context) + { + (long Position, long Size) = Context.Request.GetBufferType0x21(); + + Context.Ns.Log.PrintStub(LogClass.ServiceNifm, "Stubbed."); + + for (int Index = 0; Index < Size; Index++) + { + Context.Memory.WriteByte(Position + Index, 0); + } + + return 0; + } + + public long GetCurrentIpAddress(ServiceCtx Context) + { + Context.Ns.Log.PrintStub(LogClass.ServiceNifm, "Stubbed."); + + Context.ResponseData.Write(0); + + return 0; + } } } \ No newline at end of file diff --git a/Ryujinx.HLE/OsHle/Services/Pctl/IParentalControlService.cs b/Ryujinx.HLE/OsHle/Services/Pctl/IParentalControlService.cs index 60a69f58c..0fb620b66 100644 --- a/Ryujinx.HLE/OsHle/Services/Pctl/IParentalControlService.cs +++ b/Ryujinx.HLE/OsHle/Services/Pctl/IParentalControlService.cs @@ -18,7 +18,8 @@ namespace Ryujinx.HLE.OsHle.Services.Pctl { m_Commands = new Dictionary() { - { 1, Initialize } + { 1, Initialize }, + { 1001, CheckFreeCommunicationPermission } }; this.NeedInitialize = NeedInitialize; @@ -37,5 +38,12 @@ namespace Ryujinx.HLE.OsHle.Services.Pctl return 0; } + + public long CheckFreeCommunicationPermission(ServiceCtx Context) + { + Context.Ns.Log.PrintStub(LogClass.ServicePctl, "Stubbed."); + + return 0; + } } } \ No newline at end of file