olsc: Add service olsc:u and stub some calls (#1734)

This commit is contained in:
Ac_K 2020-11-19 23:56:23 +01:00 committed by GitHub
parent f8f23bf899
commit c2356a7653
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 67 additions and 0 deletions

View File

@ -42,6 +42,7 @@ namespace Ryujinx.Common.Logging
ServiceNs, ServiceNs,
ServiceNsd, ServiceNsd,
ServiceNv, ServiceNv,
ServiceOlsc,
ServicePctl, ServicePctl,
ServicePl, ServicePl,
ServicePrepo, ServicePrepo,

View File

@ -0,0 +1,53 @@
using Ryujinx.Common;
using Ryujinx.Common.Logging;
using Ryujinx.HLE.HOS.Services.Account.Acc;
namespace Ryujinx.HLE.HOS.Services.Olsc
{
[Service("olsc:u")] // 10.0.0+
class IOlscServiceForApplication : IpcService
{
private bool _initialized;
public IOlscServiceForApplication(ServiceCtx context) { }
[Command(0)]
// Initialize(pid)
public ResultCode Initialize(ServiceCtx context)
{
// NOTE: Service call arp:r GetApplicationInstanceUnregistrationNotifier with the pid and initialize some internal struct.
// Since we will not support online savedata backup. It's fine to stub it for now.
_initialized = true;
Logger.Stub?.PrintStub(LogClass.ServiceOlsc);
return ResultCode.Success;
}
[Command(14)]
// SetSaveDataBackupSettingEnabled(nn::account::Uid, bool)
public ResultCode SetSaveDataBackupSettingEnabled(ServiceCtx context)
{
UserId userId = context.RequestData.ReadStruct<UserId>();
ulong saveDataBackupSettingEnabled = context.RequestData.ReadUInt64();
if (!_initialized)
{
return ResultCode.NotInitialized;
}
if (userId.IsNull)
{
return ResultCode.NullArgument;
}
// NOTE: Service store the UserId and the boolean in an internal SaveDataBackupSettingDatabase object.
// Since we will not support online savedata backup. It's fine to stub it for now.
Logger.Stub?.PrintStub(LogClass.ServiceOlsc, new { userId, saveDataBackupSettingEnabled });
return ResultCode.Success;
}
}
}

View File

@ -0,0 +1,13 @@
namespace Ryujinx.HLE.HOS.Services.Olsc
{
enum ResultCode
{
ModuleId = 179,
ErrorCodeShift = 9,
Success = 0,
NullArgument = (100 << ErrorCodeShift) | ModuleId,
NotInitialized = (101 << ErrorCodeShift) | ModuleId
}
}