 f556c80d02
			
		
	
	
		f556c80d02
		
			
		
	
	
	
	
		
			
			* Haydn: Part 1 Based on my reverse of audio 11.0.0. As always, core implementation under LGPLv3 for the same reasons as for Amadeus. This place the bases of a more flexible audio system while making audout & audin accurate. This have the following improvements: - Complete reimplementation of audout and audin. - Audin currently only have a dummy backend. - Dramatically reduce CPU usage by up to 50% in common cases (SoundIO and OpenAL). - Audio Renderer now can output to 5.1 devices when supported. - Audio Renderer init its backend on demand instead of keeping two up all the time. - All backends implementation are now in their own project. - Ryujinx.Audio.Renderer was renamed Ryujinx.Audio and was refactored because of this. As a note, games having issues with OpenAL haven't improved and will not because of OpenAL design (stopping when buffers finish playing causing possible audio "pops" when buffers are very small). * Update for latest hexkyz's edits on Switchbrew * audren: Rollback channel configuration changes * Address gdkchan's comments * Fix typo in OpenAL backend driver * Address last comments * Fix a nit * Address gdkchan's comments
		
			
				
	
	
		
			93 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //
 | |
| // Copyright (c) 2019-2021 Ryujinx
 | |
| //
 | |
| // This program is free software: you can redistribute it and/or modify
 | |
| // it under the terms of the GNU Lesser General Public License as published by
 | |
| // the Free Software Foundation, either version 3 of the License, or
 | |
| // (at your option) any later version.
 | |
| //
 | |
| // This program is distributed in the hope that it will be useful,
 | |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| // GNU Lesser General Public License for more details.
 | |
| //
 | |
| // You should have received a copy of the GNU Lesser General Public License
 | |
| // along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | |
| //
 | |
| 
 | |
| using Ryujinx.Audio.Common;
 | |
| using Ryujinx.Audio.Renderer.Common;
 | |
| using System;
 | |
| using static Ryujinx.Audio.Renderer.Parameter.VoiceInParameter;
 | |
| 
 | |
| namespace Ryujinx.Audio.Renderer.Dsp.Command
 | |
| {
 | |
|     public class PcmFloatDataSourceCommandVersion1 : ICommand
 | |
|     {
 | |
|         public bool Enabled { get; set; }
 | |
| 
 | |
|         public int NodeId { get; }
 | |
| 
 | |
|         public CommandType CommandType => CommandType.PcmFloatDataSourceVersion1;
 | |
| 
 | |
|         public ulong EstimatedProcessingTime { get; set; }
 | |
| 
 | |
|         public ushort OutputBufferIndex { get; }
 | |
|         public uint SampleRate { get; }
 | |
|         public uint ChannelIndex { get; }
 | |
| 
 | |
|         public uint ChannelCount { get; }
 | |
| 
 | |
|         public float Pitch { get; }
 | |
| 
 | |
|         public WaveBuffer[] WaveBuffers { get; }
 | |
| 
 | |
|         public Memory<VoiceUpdateState> State { get; }
 | |
|         public DecodingBehaviour DecodingBehaviour { get; }
 | |
| 
 | |
|         public PcmFloatDataSourceCommandVersion1(ref Server.Voice.VoiceState serverState, Memory<VoiceUpdateState> state, ushort outputBufferIndex, ushort channelIndex, int nodeId)
 | |
|         {
 | |
|             Enabled = true;
 | |
|             NodeId = nodeId;
 | |
| 
 | |
|             OutputBufferIndex = (ushort)(channelIndex + outputBufferIndex);
 | |
|             SampleRate = serverState.SampleRate;
 | |
|             ChannelIndex = channelIndex;
 | |
|             ChannelCount = serverState.ChannelsCount;
 | |
|             Pitch = serverState.Pitch;
 | |
| 
 | |
|             WaveBuffers = new WaveBuffer[Constants.VoiceWaveBufferCount];
 | |
| 
 | |
|             for (int i = 0; i < WaveBuffers.Length; i++)
 | |
|             {
 | |
|                 ref Server.Voice.WaveBuffer voiceWaveBuffer = ref serverState.WaveBuffers[i];
 | |
| 
 | |
|                 WaveBuffers[i] = voiceWaveBuffer.ToCommon(1);
 | |
|             }
 | |
| 
 | |
|             State = state;
 | |
|             DecodingBehaviour = serverState.DecodingBehaviour;
 | |
|         }
 | |
| 
 | |
|         public void Process(CommandList context)
 | |
|         {
 | |
|             Span<float> outputBuffer = context.GetBuffer(OutputBufferIndex);
 | |
| 
 | |
|             DataSourceHelper.WaveBufferInformation info = new DataSourceHelper.WaveBufferInformation()
 | |
|             {
 | |
|                 State = State,
 | |
|                 SourceSampleRate = SampleRate,
 | |
|                 SampleFormat = SampleFormat.PcmInt16,
 | |
|                 Pitch = Pitch,
 | |
|                 DecodingBehaviour = DecodingBehaviour,
 | |
|                 WaveBuffers = WaveBuffers,
 | |
|                 ExtraParameter = 0,
 | |
|                 ExtraParameterSize = 0,
 | |
|                 ChannelIndex = (int)ChannelIndex,
 | |
|                 ChannelCount = (int)ChannelCount,
 | |
|             };
 | |
| 
 | |
|             DataSourceHelper.ProcessWaveBuffers(context.MemoryManager, outputBuffer, info, context.SampleRate, (int)context.SampleCount);
 | |
|         }
 | |
|     }
 | |
| }
 |