aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Core/OsHle/Objects/Vi
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2018-02-23 18:48:27 -0300
committergdkchan <gab.dark.100@gmail.com>2018-02-23 18:48:27 -0300
commit2ed733b1d5addad027f48acfdd407e64b71427fc (patch)
tree1254df3ab2bace8de561b5a3549f668fabcf4aa9 /Ryujinx.Core/OsHle/Objects/Vi
parenteafc58c9f2e2e0c19d22f0da2a93ab5372aeef29 (diff)
Somewhat better NvFlinger (I guess) (fixes #30)
Diffstat (limited to 'Ryujinx.Core/OsHle/Objects/Vi')
-rw-r--r--Ryujinx.Core/OsHle/Objects/Vi/IHOSBinderDriver.cs178
1 files changed, 20 insertions, 158 deletions
diff --git a/Ryujinx.Core/OsHle/Objects/Vi/IHOSBinderDriver.cs b/Ryujinx.Core/OsHle/Objects/Vi/IHOSBinderDriver.cs
index cfd271e8..bbea3368 100644
--- a/Ryujinx.Core/OsHle/Objects/Vi/IHOSBinderDriver.cs
+++ b/Ryujinx.Core/OsHle/Objects/Vi/IHOSBinderDriver.cs
@@ -1,34 +1,18 @@
using ChocolArm64.Memory;
-using Ryujinx.Core.OsHle.Handles;
using Ryujinx.Core.OsHle.Ipc;
-using Ryujinx.Core.OsHle.Utilities;
+using Ryujinx.Core.OsHle.Objects.Android;
using System;
using System.Collections.Generic;
-using System.IO;
-using System.Text;
-
-using static Ryujinx.Core.OsHle.Objects.Android.Parcel;
namespace Ryujinx.Core.OsHle.Objects.Vi
{
- class IHOSBinderDriver : IIpcInterface
+ class IHOSBinderDriver : IIpcInterface, IDisposable
{
- private delegate long ServiceProcessParcel(ServiceCtx Context, byte[] ParcelData);
-
private Dictionary<int, ServiceProcessRequest> m_Commands;
- private Dictionary<(string, int), ServiceProcessParcel> m_Methods;
-
- public IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
+ public IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
- private class BufferObj
- {
-
- }
-
- private IdPoolWithObj BufferSlots;
-
- private byte[] Gbfr;
+ private NvFlinger Flinger;
public IHOSBinderDriver()
{
@@ -39,18 +23,7 @@ namespace Ryujinx.Core.OsHle.Objects.Vi
{ 2, GetNativeHandle }
};
- m_Methods = new Dictionary<(string, int), ServiceProcessParcel>()
- {
- { ("android.gui.IGraphicBufferProducer", 0x1), GraphicBufferProducerRequestBuffer },
- { ("android.gui.IGraphicBufferProducer", 0x3), GraphicBufferProducerDequeueBuffer },
- { ("android.gui.IGraphicBufferProducer", 0x7), GraphicBufferProducerQueueBuffer },
- { ("android.gui.IGraphicBufferProducer", 0x8), GraphicBufferProducerCancelBuffer },
- { ("android.gui.IGraphicBufferProducer", 0x9), GraphicBufferProducerQuery },
- { ("android.gui.IGraphicBufferProducer", 0xa), GraphicBufferProducerConnect },
- { ("android.gui.IGraphicBufferProducer", 0xe), GraphicBufferPreallocateBuffer }
- };
-
- BufferSlots = new IdPoolWithObj();
+ Flinger = new NvFlinger();
}
public long TransactParcel(ServiceCtx Context)
@@ -63,133 +36,9 @@ namespace Ryujinx.Core.OsHle.Objects.Vi
byte[] Data = AMemoryHelper.ReadBytes(Context.Memory, DataPos, (int)DataSize);
- Data = GetParcelData(Data);
-
- using (MemoryStream MS = new MemoryStream(Data))
- {
- BinaryReader Reader = new BinaryReader(MS);
-
- MS.Seek(4, SeekOrigin.Current);
-
- int StrSize = Reader.ReadInt32();
-
- string InterfaceName = Encoding.Unicode.GetString(Data, 8, StrSize * 2);
-
- if (m_Methods.TryGetValue((InterfaceName, Code), out ServiceProcessParcel ProcReq))
- {
- return ProcReq(Context, Data);
- }
- else
- {
- throw new NotImplementedException($"{InterfaceName} {Code}");
- }
- }
- }
-
- private long GraphicBufferProducerRequestBuffer(ServiceCtx Context, byte[] ParcelData)
- {
- int GbfrSize = Gbfr?.Length ?? 0;
-
- byte[] Data = new byte[GbfrSize + 4];
-
- if (Gbfr != null)
- {
- Buffer.BlockCopy(Gbfr, 0, Data, 0, GbfrSize);
- }
-
- return MakeReplyParcel(Context, Data);
- }
-
- private long GraphicBufferProducerDequeueBuffer(ServiceCtx Context, byte[] ParcelData)
- {
- //Note: It seems that the maximum number of slots is 64, because if we return
- //a Slot number > 63, it seems to cause a buffer overrun and it reads garbage.
- //Note 2: The size of each object associated with the slot is 0x30.
- int Slot = BufferSlots.GenerateId(new BufferObj());
-
- return MakeReplyParcel(Context, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
- }
-
- private long GraphicBufferProducerQueueBuffer(ServiceCtx Context, byte[] ParcelData)
- {
- return MakeReplyParcel(Context, 1280, 720, 0, 0, 0);
- }
-
- private long GraphicBufferProducerCancelBuffer(ServiceCtx Context, byte[] ParcelData)
- {
- using (MemoryStream MS = new MemoryStream(ParcelData))
- {
- BinaryReader Reader = new BinaryReader(MS);
-
- MS.Seek(0x50, SeekOrigin.Begin);
-
- int Slot = Reader.ReadInt32();
-
- BufferSlots.Delete(Slot);
-
- return MakeReplyParcel(Context, 0);
- }
- }
-
- private long GraphicBufferProducerQuery(ServiceCtx Context, byte[] ParcelData)
- {
- return MakeReplyParcel(Context, 0, 0);
- }
+ Data = Parcel.GetParcelData(Data);
- private long GraphicBufferProducerConnect(ServiceCtx Context, byte[] ParcelData)
- {
- return MakeReplyParcel(Context, 1280, 720, 0, 0, 0);
- }
-
- private long GraphicBufferPreallocateBuffer(ServiceCtx Context, byte[] ParcelData)
- {
- int GbfrSize = ParcelData.Length - 0x54;
-
- Gbfr = new byte[GbfrSize];
-
- Buffer.BlockCopy(ParcelData, 0x54, Gbfr, 0, GbfrSize);
-
- using (MemoryStream MS = new MemoryStream(ParcelData))
- {
- BinaryReader Reader = new BinaryReader(MS);
-
- MS.Seek(0xd4, SeekOrigin.Begin);
-
- int Handle = Reader.ReadInt32();
-
- HNvMap NvMap = Context.Ns.Os.Handles.GetData<HNvMap>(Handle);
-
- Context.Ns.Gpu.Renderer.FrameBufferPtr = NvMap.Address;
- }
-
- return MakeReplyParcel(Context, 0);
- }
-
- private long MakeReplyParcel(ServiceCtx Context, params int[] Ints)
- {
- using (MemoryStream MS = new MemoryStream())
- {
- BinaryWriter Writer = new BinaryWriter(MS);
-
- foreach (int Int in Ints)
- {
- Writer.Write(Int);
- }
-
- return MakeReplyParcel(Context, MS.ToArray());
- }
- }
-
- private long MakeReplyParcel(ServiceCtx Context, byte[] Data)
- {
- long ReplyPos = Context.Request.ReceiveBuff[0].Position;
- long ReplySize = Context.Request.ReceiveBuff[0].Position;
-
- byte[] Reply = MakeParcel(Data, new byte[0]);
-
- AMemoryHelper.WriteBytes(Context.Memory, ReplyPos, Reply);
-
- return 0;
+ return Flinger.ProcessParcelRequest(Context, Data, Code);
}
public long AdjustRefcount(ServiceCtx Context)
@@ -210,5 +59,18 @@ namespace Ryujinx.Core.OsHle.Objects.Vi
return 0;
}
+
+ public void Dispose()
+ {
+ Dispose(true);
+ }
+
+ protected virtual void Dispose(bool disposing)
+ {
+ if (disposing)
+ {
+ Flinger.Dispose();
+ }
+ }
}
} \ No newline at end of file