diff --git a/Ryujinx.HLE/HOS/Services/Nifm/ResultCode.cs b/Ryujinx.HLE/HOS/Services/Nifm/ResultCode.cs index c661ee81f..73cadb114 100644 --- a/Ryujinx.HLE/HOS/Services/Nifm/ResultCode.cs +++ b/Ryujinx.HLE/HOS/Services/Nifm/ResultCode.cs @@ -7,6 +7,8 @@ namespace Ryujinx.HLE.HOS.Services.Nifm Success = 0, + Unknown112 = (112 << ErrorCodeShift) | ModuleId, // IRequest::GetResult + Unknown180 = (180 << ErrorCodeShift) | ModuleId, // IRequest::GetAppletInfo NoInternetConnection = (300 << ErrorCodeShift) | ModuleId, ObjectIsNull = (350 << ErrorCodeShift) | ModuleId } diff --git a/Ryujinx.HLE/HOS/Services/Nifm/StaticService/IRequest.cs b/Ryujinx.HLE/HOS/Services/Nifm/StaticService/IRequest.cs index cfc6b5169..395e976aa 100644 --- a/Ryujinx.HLE/HOS/Services/Nifm/StaticService/IRequest.cs +++ b/Ryujinx.HLE/HOS/Services/Nifm/StaticService/IRequest.cs @@ -38,6 +38,11 @@ namespace Ryujinx.HLE.HOS.Services.Nifm.StaticService { Logger.PrintStub(LogClass.ServiceNifm); + return GetResultImpl(); + } + + private ResultCode GetResultImpl() + { return ResultCode.Success; } @@ -86,5 +91,32 @@ namespace Ryujinx.HLE.HOS.Services.Nifm.StaticService return ResultCode.Success; } + + [Command(21)] + // GetAppletInfo(u32) -> (u32, u32, u32, buffer) + public ResultCode GetAppletInfo(ServiceCtx context) + { + uint themeColor = context.RequestData.ReadUInt32(); + + Logger.PrintStub(LogClass.ServiceNifm); + + ResultCode result = GetResultImpl(); + + if (result == ResultCode.Success || (ResultCode)((int)result & 0x3fffff) == ResultCode.Unknown112) + { + return ResultCode.Unknown180; + } + + // Returns appletId, libraryAppletMode, outSize and a buffer. + // Returned applet ids- (0x19, 0xf, 0xe) + // libraryAppletMode seems to be 0 for all applets supported. + + // TODO: check order + context.ResponseData.Write(0xe); // Use error applet as default for now + context.ResponseData.Write(0); // libraryAppletMode + context.ResponseData.Write(0); // outSize + + return ResultCode.Success; + } } } \ No newline at end of file