aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer
diff options
context:
space:
mode:
Diffstat (limited to 'src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer')
-rw-r--r--src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateBufferAccessCommand.cs22
-rw-r--r--src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateHostBufferCommand.cs22
2 files changed, 44 insertions, 0 deletions
diff --git a/src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateBufferAccessCommand.cs b/src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateBufferAccessCommand.cs
new file mode 100644
index 00000000..ece98b70
--- /dev/null
+++ b/src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateBufferAccessCommand.cs
@@ -0,0 +1,22 @@
+namespace Ryujinx.Graphics.GAL.Multithreading.Commands.Renderer
+{
+ struct CreateBufferAccessCommand : IGALCommand, IGALCommand<CreateBufferAccessCommand>
+ {
+ public CommandType CommandType => CommandType.CreateBufferAccess;
+ private BufferHandle _threadedHandle;
+ private int _size;
+ private BufferAccess _access;
+
+ public void Set(BufferHandle threadedHandle, int size, BufferAccess access)
+ {
+ _threadedHandle = threadedHandle;
+ _size = size;
+ _access = access;
+ }
+
+ public static void Run(ref CreateBufferAccessCommand command, ThreadedRenderer threaded, IRenderer renderer)
+ {
+ threaded.Buffers.AssignBuffer(command._threadedHandle, renderer.CreateBuffer(command._size, command._access));
+ }
+ }
+}
diff --git a/src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateHostBufferCommand.cs b/src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateHostBufferCommand.cs
new file mode 100644
index 00000000..e25f8468
--- /dev/null
+++ b/src/Ryujinx.Graphics.GAL/Multithreading/Commands/Renderer/CreateHostBufferCommand.cs
@@ -0,0 +1,22 @@
+namespace Ryujinx.Graphics.GAL.Multithreading.Commands.Renderer
+{
+ struct CreateHostBufferCommand : IGALCommand, IGALCommand<CreateHostBufferCommand>
+ {
+ public CommandType CommandType => CommandType.CreateHostBuffer;
+ private BufferHandle _threadedHandle;
+ private nint _pointer;
+ private int _size;
+
+ public void Set(BufferHandle threadedHandle, nint pointer, int size)
+ {
+ _threadedHandle = threadedHandle;
+ _pointer = pointer;
+ _size = size;
+ }
+
+ public static void Run(ref CreateHostBufferCommand command, ThreadedRenderer threaded, IRenderer renderer)
+ {
+ threaded.Buffers.AssignBuffer(command._threadedHandle, renderer.CreateBuffer(command._pointer, command._size));
+ }
+ }
+}