diff options
| author | TSR Berry <20988865+TSRBerry@users.noreply.github.com> | 2023-04-08 01:22:00 +0200 |
|---|---|---|
| committer | Mary <thog@protonmail.com> | 2023-04-27 23:51:14 +0200 |
| commit | cee712105850ac3385cd0091a923438167433f9f (patch) | |
| tree | 4a5274b21d8b7f938c0d0ce18736d3f2993b11b1 /Ryujinx.Audio/Backends/Common | |
| parent | cd124bda587ef09668a971fa1cac1c3f0cfc9f21 (diff) | |
Move solution and projects to src
Diffstat (limited to 'Ryujinx.Audio/Backends/Common')
| -rw-r--r-- | Ryujinx.Audio/Backends/Common/BackendHelper.cs | 26 | ||||
| -rw-r--r-- | Ryujinx.Audio/Backends/Common/DynamicRingBuffer.cs | 166 | ||||
| -rw-r--r-- | Ryujinx.Audio/Backends/Common/HardwareDeviceSessionOutputBase.cs | 79 |
3 files changed, 0 insertions, 271 deletions
diff --git a/Ryujinx.Audio/Backends/Common/BackendHelper.cs b/Ryujinx.Audio/Backends/Common/BackendHelper.cs deleted file mode 100644 index 30db340f..00000000 --- a/Ryujinx.Audio/Backends/Common/BackendHelper.cs +++ /dev/null @@ -1,26 +0,0 @@ -using Ryujinx.Audio.Common; -using System; - -namespace Ryujinx.Audio.Backends.Common -{ - public static class BackendHelper - { - public static int GetSampleSize(SampleFormat format) - { - return format switch - { - SampleFormat.PcmInt8 => sizeof(byte), - SampleFormat.PcmInt16 => sizeof(ushort), - SampleFormat.PcmInt24 => 3, - SampleFormat.PcmInt32 => sizeof(int), - SampleFormat.PcmFloat => sizeof(float), - _ => throw new ArgumentException($"{format}"), - }; - } - - public static int GetSampleCount(SampleFormat format, int channelCount, int bufferSize) - { - return bufferSize / GetSampleSize(format) / channelCount; - } - } -}
\ No newline at end of file diff --git a/Ryujinx.Audio/Backends/Common/DynamicRingBuffer.cs b/Ryujinx.Audio/Backends/Common/DynamicRingBuffer.cs deleted file mode 100644 index 9bf20d4b..00000000 --- a/Ryujinx.Audio/Backends/Common/DynamicRingBuffer.cs +++ /dev/null @@ -1,166 +0,0 @@ -using Ryujinx.Common; -using System; - -namespace Ryujinx.Audio.Backends.Common -{ - /// <summary> - /// A ring buffer that grow if data written to it is too big to fit. - /// </summary> - public class DynamicRingBuffer - { - private const int RingBufferAlignment = 2048; - - private object _lock = new object(); - - private byte[] _buffer; - private int _size; - private int _headOffset; - private int _tailOffset; - - public int Length => _size; - - public DynamicRingBuffer(int initialCapacity = RingBufferAlignment) - { - _buffer = new byte[initialCapacity]; - } - - public void Clear() - { - _size = 0; - _headOffset = 0; - _tailOffset = 0; - } - - public void Clear(int size) - { - lock (_lock) - { - if (size > _size) - { - size = _size; - } - - if (size == 0) - { - return; - } - - _headOffset = (_headOffset + size) % _buffer.Length; - _size -= size; - - if (_size == 0) - { - _headOffset = 0; - _tailOffset = 0; - } - } - } - - private void SetCapacityLocked(int capacity) - { - byte[] buffer = new byte[capacity]; - - if (_size > 0) - { - if (_headOffset < _tailOffset) - { - Buffer.BlockCopy(_buffer, _headOffset, buffer, 0, _size); - } - else - { - Buffer.BlockCopy(_buffer, _headOffset, buffer, 0, _buffer.Length - _headOffset); - Buffer.BlockCopy(_buffer, 0, buffer, _buffer.Length - _headOffset, _tailOffset); - } - } - - _buffer = buffer; - _headOffset = 0; - _tailOffset = _size; - } - - - public void Write<T>(T[] buffer, int index, int count) - { - if (count == 0) - { - return; - } - - lock (_lock) - { - if ((_size + count) > _buffer.Length) - { - SetCapacityLocked(BitUtils.AlignUp(_size + count, RingBufferAlignment)); - } - - if (_headOffset < _tailOffset) - { - int tailLength = _buffer.Length - _tailOffset; - - if (tailLength >= count) - { - Buffer.BlockCopy(buffer, index, _buffer, _tailOffset, count); - } - else - { - Buffer.BlockCopy(buffer, index, _buffer, _tailOffset, tailLength); - Buffer.BlockCopy(buffer, index + tailLength, _buffer, 0, count - tailLength); - } - } - else - { - Buffer.BlockCopy(buffer, index, _buffer, _tailOffset, count); - } - - _size += count; - _tailOffset = (_tailOffset + count) % _buffer.Length; - } - } - - public int Read<T>(T[] buffer, int index, int count) - { - lock (_lock) - { - if (count > _size) - { - count = _size; - } - - if (count == 0) - { - return 0; - } - - if (_headOffset < _tailOffset) - { - Buffer.BlockCopy(_buffer, _headOffset, buffer, index, count); - } - else - { - int tailLength = _buffer.Length - _headOffset; - - if (tailLength >= count) - { - Buffer.BlockCopy(_buffer, _headOffset, buffer, index, count); - } - else - { - Buffer.BlockCopy(_buffer, _headOffset, buffer, index, tailLength); - Buffer.BlockCopy(_buffer, 0, buffer, index + tailLength, count - tailLength); - } - } - - _size -= count; - _headOffset = (_headOffset + count) % _buffer.Length; - - if (_size == 0) - { - _headOffset = 0; - _tailOffset = 0; - } - - return count; - } - } - } -}
\ No newline at end of file diff --git a/Ryujinx.Audio/Backends/Common/HardwareDeviceSessionOutputBase.cs b/Ryujinx.Audio/Backends/Common/HardwareDeviceSessionOutputBase.cs deleted file mode 100644 index 6fb3bee0..00000000 --- a/Ryujinx.Audio/Backends/Common/HardwareDeviceSessionOutputBase.cs +++ /dev/null @@ -1,79 +0,0 @@ -using Ryujinx.Audio.Common; -using Ryujinx.Audio.Integration; -using Ryujinx.Memory; -using System.Runtime.CompilerServices; - -namespace Ryujinx.Audio.Backends.Common -{ - public abstract class HardwareDeviceSessionOutputBase : IHardwareDeviceSession - { - public IVirtualMemoryManager MemoryManager { get; } - public SampleFormat RequestedSampleFormat { get; } - public uint RequestedSampleRate { get; } - public uint RequestedChannelCount { get; } - - public HardwareDeviceSessionOutputBase(IVirtualMemoryManager memoryManager, SampleFormat requestedSampleFormat, uint requestedSampleRate, uint requestedChannelCount) - { - MemoryManager = memoryManager; - RequestedSampleFormat = requestedSampleFormat; - RequestedSampleRate = requestedSampleRate; - RequestedChannelCount = requestedChannelCount; - } - - private byte[] GetBufferSamples(AudioBuffer buffer) - { - if (buffer.DataPointer == 0) - { - return null; - } - - byte[] data = new byte[buffer.DataSize]; - - MemoryManager.Read(buffer.DataPointer, data); - - return data; - } - - protected ulong GetSampleCount(AudioBuffer buffer) - { - return GetSampleCount((int)buffer.DataSize); - } - - [MethodImpl(MethodImplOptions.AggressiveInlining)] - protected ulong GetSampleCount(int dataSize) - { - return (ulong)BackendHelper.GetSampleCount(RequestedSampleFormat, (int)RequestedChannelCount, dataSize); - } - - public abstract void Dispose(); - public abstract void PrepareToClose(); - public abstract void QueueBuffer(AudioBuffer buffer); - public abstract void SetVolume(float volume); - public abstract float GetVolume(); - public abstract void Start(); - public abstract void Stop(); - public abstract ulong GetPlayedSampleCount(); - public abstract bool WasBufferFullyConsumed(AudioBuffer buffer); - public virtual bool RegisterBuffer(AudioBuffer buffer) - { - return RegisterBuffer(buffer, GetBufferSamples(buffer)); - } - - public virtual bool RegisterBuffer(AudioBuffer buffer, byte[] samples) - { - if (samples == null) - { - return false; - } - - if (buffer.Data == null) - { - buffer.Data = samples; - } - - return true; - } - - public virtual void UnregisterBuffer(AudioBuffer buffer) { } - } -}
\ No newline at end of file |
