2018-10-17 19:15:50 +02:00
|
|
|
using Ryujinx.Common.Logging;
|
2018-08-17 01:47:36 +02:00
|
|
|
using Ryujinx.HLE.HOS.Ipc;
|
2018-05-26 22:49:21 +02:00
|
|
|
using System.Collections.Generic;
|
|
|
|
|
2018-08-17 01:47:36 +02:00
|
|
|
namespace Ryujinx.HLE.HOS.Services.Mm
|
2018-05-26 22:49:21 +02:00
|
|
|
{
|
|
|
|
class IRequest : IpcService
|
|
|
|
{
|
2018-12-05 01:52:39 +01:00
|
|
|
private Dictionary<int, ServiceProcessRequest> m_Commands;
|
2018-05-26 22:49:21 +02:00
|
|
|
|
2018-12-05 01:52:39 +01:00
|
|
|
public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
|
2018-05-26 22:49:21 +02:00
|
|
|
|
|
|
|
public IRequest()
|
|
|
|
{
|
2018-12-05 01:52:39 +01:00
|
|
|
m_Commands = new Dictionary<int, ServiceProcessRequest>()
|
2018-05-26 22:49:21 +02:00
|
|
|
{
|
2018-10-07 17:12:11 +02:00
|
|
|
{ 1, InitializeOld },
|
|
|
|
{ 4, Initialize },
|
2018-12-03 03:38:47 +01:00
|
|
|
{ 5, Finalize },
|
2018-10-07 17:12:11 +02:00
|
|
|
{ 6, SetAndWait },
|
|
|
|
{ 7, Get }
|
2018-05-26 22:49:21 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2018-10-07 17:12:11 +02:00
|
|
|
// InitializeOld(u32, u32, u32)
|
2018-12-05 01:52:39 +01:00
|
|
|
public long InitializeOld(ServiceCtx Context)
|
2018-10-07 17:12:11 +02:00
|
|
|
{
|
2018-12-05 01:52:39 +01:00
|
|
|
int Unknown0 = Context.RequestData.ReadInt32();
|
|
|
|
int Unknown1 = Context.RequestData.ReadInt32();
|
|
|
|
int Unknown2 = Context.RequestData.ReadInt32();
|
2018-10-07 17:12:11 +02:00
|
|
|
|
2018-10-17 19:15:50 +02:00
|
|
|
Logger.PrintStub(LogClass.ServiceMm, "Stubbed.");
|
2018-10-07 17:12:11 +02:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-12-05 01:52:39 +01:00
|
|
|
public long Initialize(ServiceCtx Context)
|
2018-05-26 22:49:21 +02:00
|
|
|
{
|
2018-10-17 19:15:50 +02:00
|
|
|
Logger.PrintStub(LogClass.ServiceMm, "Stubbed.");
|
2018-05-26 22:49:21 +02:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-12-05 01:52:39 +01:00
|
|
|
public long Finalize(ServiceCtx Context)
|
2018-12-03 03:38:47 +01:00
|
|
|
{
|
2018-12-05 01:52:39 +01:00
|
|
|
Context.Device.Gpu.UninitializeVideoDecoder();
|
2018-12-03 03:38:47 +01:00
|
|
|
|
|
|
|
Logger.PrintStub(LogClass.ServiceMm, "Stubbed.");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-12-05 01:52:39 +01:00
|
|
|
public long SetAndWait(ServiceCtx Context)
|
2018-05-26 22:49:21 +02:00
|
|
|
{
|
2018-10-17 19:15:50 +02:00
|
|
|
Logger.PrintStub(LogClass.ServiceMm, "Stubbed.");
|
2018-05-26 22:49:21 +02:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-12-05 01:52:39 +01:00
|
|
|
public long Get(ServiceCtx Context)
|
2018-05-26 22:49:21 +02:00
|
|
|
{
|
2018-12-05 01:52:39 +01:00
|
|
|
Context.ResponseData.Write(0);
|
2018-05-26 22:49:21 +02:00
|
|
|
|
2018-10-17 19:15:50 +02:00
|
|
|
Logger.PrintStub(LogClass.ServiceMm, "Stubbed.");
|
2018-05-26 22:49:21 +02:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|