aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Graphics.Vulkan/TextureBuffer.cs
diff options
context:
space:
mode:
authorTSR Berry <20988865+TSRBerry@users.noreply.github.com>2023-04-08 01:22:00 +0200
committerMary <thog@protonmail.com>2023-04-27 23:51:14 +0200
commitcee712105850ac3385cd0091a923438167433f9f (patch)
tree4a5274b21d8b7f938c0d0ce18736d3f2993b11b1 /Ryujinx.Graphics.Vulkan/TextureBuffer.cs
parentcd124bda587ef09668a971fa1cac1c3f0cfc9f21 (diff)
Move solution and projects to src
Diffstat (limited to 'Ryujinx.Graphics.Vulkan/TextureBuffer.cs')
-rw-r--r--Ryujinx.Graphics.Vulkan/TextureBuffer.cs160
1 files changed, 0 insertions, 160 deletions
diff --git a/Ryujinx.Graphics.Vulkan/TextureBuffer.cs b/Ryujinx.Graphics.Vulkan/TextureBuffer.cs
deleted file mode 100644
index 738bf57d..00000000
--- a/Ryujinx.Graphics.Vulkan/TextureBuffer.cs
+++ /dev/null
@@ -1,160 +0,0 @@
-using Ryujinx.Common.Memory;
-using Ryujinx.Graphics.GAL;
-using Silk.NET.Vulkan;
-using System;
-using System.Collections.Generic;
-using VkFormat = Silk.NET.Vulkan.Format;
-
-namespace Ryujinx.Graphics.Vulkan
-{
- class TextureBuffer : ITexture
- {
- private readonly VulkanRenderer _gd;
-
- private BufferHandle _bufferHandle;
- private int _offset;
- private int _size;
- private Auto<DisposableBufferView> _bufferView;
- private Dictionary<GAL.Format, Auto<DisposableBufferView>> _selfManagedViews;
-
- private int _bufferCount;
-
- public int Width { get; }
- public int Height { get; }
-
- public VkFormat VkFormat { get; }
-
- public float ScaleFactor { get; }
-
- public TextureBuffer(VulkanRenderer gd, TextureCreateInfo info, float scale)
- {
- _gd = gd;
- Width = info.Width;
- Height = info.Height;
- VkFormat = FormatTable.GetFormat(info.Format);
- ScaleFactor = scale;
-
- gd.Textures.Add(this);
- }
-
- public void CopyTo(ITexture destination, int firstLayer, int firstLevel)
- {
- throw new NotSupportedException();
- }
-
- public void CopyTo(ITexture destination, int srcLayer, int dstLayer, int srcLevel, int dstLevel)
- {
- throw new NotSupportedException();
- }
-
- public void CopyTo(ITexture destination, Extents2D srcRegion, Extents2D dstRegion, bool linearFilter)
- {
- throw new NotSupportedException();
- }
-
- public ITexture CreateView(TextureCreateInfo info, int firstLayer, int firstLevel)
- {
- throw new NotSupportedException();
- }
-
- public PinnedSpan<byte> GetData()
- {
- return _gd.GetBufferData(_bufferHandle, _offset, _size);
- }
-
- public PinnedSpan<byte> GetData(int layer, int level)
- {
- return GetData();
- }
-
- public void Release()
- {
- if (_gd.Textures.Remove(this))
- {
- ReleaseImpl();
- }
- }
-
- private void ReleaseImpl()
- {
- if (_selfManagedViews != null)
- {
- foreach (var bufferView in _selfManagedViews.Values)
- {
- bufferView.Dispose();
- }
-
- _selfManagedViews = null;
- }
-
- _bufferView?.Dispose();
- _bufferView = null;
- }
-
- public void SetData(SpanOrArray<byte> data)
- {
- _gd.SetBufferData(_bufferHandle, _offset, data);
- }
-
- public void SetData(SpanOrArray<byte> data, int layer, int level)
- {
- throw new NotSupportedException();
- }
-
- public void SetData(SpanOrArray<byte> data, int layer, int level, Rectangle<int> region)
- {
- throw new NotSupportedException();
- }
-
- public void SetStorage(BufferRange buffer)
- {
- if (_bufferHandle == buffer.Handle &&
- _offset == buffer.Offset &&
- _size == buffer.Size &&
- _bufferCount == _gd.BufferManager.BufferCount)
- {
- return;
- }
-
- _bufferHandle = buffer.Handle;
- _offset = buffer.Offset;
- _size = buffer.Size;
- _bufferCount = _gd.BufferManager.BufferCount;
-
- ReleaseImpl();
- }
-
- public BufferView GetBufferView(CommandBufferScoped cbs)
- {
- if (_bufferView == null)
- {
- _bufferView = _gd.BufferManager.CreateView(_bufferHandle, VkFormat, _offset, _size, ReleaseImpl);
- }
-
- return _bufferView?.Get(cbs, _offset, _size).Value ?? default;
- }
-
- public BufferView GetBufferView(CommandBufferScoped cbs, GAL.Format format)
- {
- var vkFormat = FormatTable.GetFormat(format);
- if (vkFormat == VkFormat)
- {
- return GetBufferView(cbs);
- }
-
- if (_selfManagedViews != null && _selfManagedViews.TryGetValue(format, out var bufferView))
- {
- return bufferView.Get(cbs, _offset, _size).Value;
- }
-
- bufferView = _gd.BufferManager.CreateView(_bufferHandle, vkFormat, _offset, _size, ReleaseImpl);
-
- if (bufferView != null)
- {
- (_selfManagedViews ??= new Dictionary<GAL.Format, Auto<DisposableBufferView>>()).Add(format, bufferView);
- }
-
- return bufferView?.Get(cbs, _offset, _size).Value ?? default;
- }
- }
-}