aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Horizon/Sdk/Audio/Detail/AudioInManager.cs
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2024-02-22 16:58:33 -0300
committerGitHub <noreply@github.com>2024-02-22 16:58:33 -0300
commitd4d0a48bfe89d6e8e12ce16829bb2c440b56007c (patch)
tree2376566ed2c06181b3dbc547b1f99f5b533d918b /src/Ryujinx.Horizon/Sdk/Audio/Detail/AudioInManager.cs
parent57d8afd0c99bb43d1ba1e3cc630d257c5da92741 (diff)
Migrate Audio service to new IPC (#6285)
* Migrate audren to new IPC * Migrate audout * Migrate audin * Migrate hwopus * Bye bye old audio service * Switch volume control to IHardwareDeviceDriver * Somewhat unrelated changes * Remove Concentus reference from HLE * Implement OpenAudioRendererForManualExecution * Remove SetVolume/GetVolume methods that are not necessary * Remove SetVolume/GetVolume methods that are not necessary (2) * Fix incorrect volume update * PR feedback * PR feedback * Stub audrec * Init outParameter * Make FinalOutputRecorderParameter/Internal readonly * Make FinalOutputRecorder IDisposable * Fix HardwareOpusDecoderManager parameter buffers * Opus work buffer size and error handling improvements * Add AudioInProtocolName enum * Fix potential divisions by zero
Diffstat (limited to 'src/Ryujinx.Horizon/Sdk/Audio/Detail/AudioInManager.cs')
-rw-r--r--src/Ryujinx.Horizon/Sdk/Audio/Detail/AudioInManager.cs130
1 files changed, 130 insertions, 0 deletions
diff --git a/src/Ryujinx.Horizon/Sdk/Audio/Detail/AudioInManager.cs b/src/Ryujinx.Horizon/Sdk/Audio/Detail/AudioInManager.cs
new file mode 100644
index 00000000..d5d04720
--- /dev/null
+++ b/src/Ryujinx.Horizon/Sdk/Audio/Detail/AudioInManager.cs
@@ -0,0 +1,130 @@
+using Ryujinx.Audio;
+using Ryujinx.Audio.Common;
+using Ryujinx.Audio.Input;
+using Ryujinx.Horizon.Common;
+using Ryujinx.Horizon.Sdk.Applet;
+using Ryujinx.Horizon.Sdk.Sf;
+using Ryujinx.Horizon.Sdk.Sf.Hipc;
+using System;
+
+namespace Ryujinx.Horizon.Sdk.Audio.Detail
+{
+ partial class AudioInManager : IAudioInManager
+ {
+ private readonly AudioInputManager _impl;
+
+ public AudioInManager(AudioInputManager impl)
+ {
+ _impl = impl;
+ }
+
+ [CmifCommand(0)]
+ public Result ListAudioIns(out int count, [Buffer(HipcBufferFlags.Out | HipcBufferFlags.MapAlias)] Span<DeviceName> names)
+ {
+ string[] deviceNames = _impl.ListAudioIns(filtered: false);
+
+ count = 0;
+
+ foreach (string deviceName in deviceNames)
+ {
+ if (count >= names.Length)
+ {
+ break;
+ }
+
+ names[count++] = new DeviceName(deviceName);
+ }
+
+ return Result.Success;
+ }
+
+ [CmifCommand(1)]
+ public Result OpenAudioIn(
+ out AudioOutputConfiguration outputConfiguration,
+ out IAudioIn audioIn,
+ [Buffer(HipcBufferFlags.Out | HipcBufferFlags.MapAlias)] Span<DeviceName> outName,
+ AudioInputConfiguration parameter,
+ AppletResourceUserId appletResourceId,
+ [CopyHandle] int processHandle,
+ [Buffer(HipcBufferFlags.In | HipcBufferFlags.MapAlias)] ReadOnlySpan<DeviceName> name,
+ [ClientProcessId] ulong pid)
+ {
+ var clientMemoryManager = HorizonStatic.Syscall.GetMemoryManagerByProcessHandle(processHandle);
+
+ ResultCode rc = _impl.OpenAudioIn(
+ out string outputDeviceName,
+ out outputConfiguration,
+ out AudioInputSystem inSystem,
+ clientMemoryManager,
+ name.Length > 0 ? name[0].ToString() : string.Empty,
+ SampleFormat.PcmInt16,
+ ref parameter);
+
+ if (rc == ResultCode.Success && outName.Length > 0)
+ {
+ outName[0] = new DeviceName(outputDeviceName);
+ }
+
+ audioIn = new AudioIn(inSystem, processHandle);
+
+ return new Result((int)rc);
+ }
+
+ [CmifCommand(2)] // 3.0.0+
+ public Result ListAudioInsAuto(out int count, [Buffer(HipcBufferFlags.Out | HipcBufferFlags.AutoSelect)] Span<DeviceName> names)
+ {
+ return ListAudioIns(out count, names);
+ }
+
+ [CmifCommand(3)] // 3.0.0+
+ public Result OpenAudioInAuto(
+ out AudioOutputConfiguration outputConfig,
+ out IAudioIn audioIn,
+ [Buffer(HipcBufferFlags.Out | HipcBufferFlags.AutoSelect)] Span<DeviceName> outName,
+ AudioInputConfiguration parameter,
+ AppletResourceUserId appletResourceId,
+ [CopyHandle] int processHandle,
+ [Buffer(HipcBufferFlags.In | HipcBufferFlags.AutoSelect)] ReadOnlySpan<DeviceName> name,
+ [ClientProcessId] ulong pid)
+ {
+ return OpenAudioIn(out outputConfig, out audioIn, outName, parameter, appletResourceId, processHandle, name, pid);
+ }
+
+ [CmifCommand(4)] // 3.0.0+
+ public Result ListAudioInsAutoFiltered(out int count, [Buffer(HipcBufferFlags.Out | HipcBufferFlags.AutoSelect)] Span<DeviceName> names)
+ {
+ string[] deviceNames = _impl.ListAudioIns(filtered: true);
+
+ count = 0;
+
+ foreach (string deviceName in deviceNames)
+ {
+ if (count >= names.Length)
+ {
+ break;
+ }
+
+ names[count++] = new DeviceName(deviceName);
+ }
+
+ return Result.Success;
+ }
+
+ [CmifCommand(5)] // 5.0.0+
+ public Result OpenAudioInProtocolSpecified(
+ out AudioOutputConfiguration outputConfig,
+ out IAudioIn audioIn,
+ [Buffer(HipcBufferFlags.Out | HipcBufferFlags.MapAlias)] Span<DeviceName> outName,
+ AudioInProtocol protocol,
+ AudioInputConfiguration parameter,
+ AppletResourceUserId appletResourceId,
+ [CopyHandle] int processHandle,
+ [Buffer(HipcBufferFlags.In | HipcBufferFlags.MapAlias)] ReadOnlySpan<DeviceName> name,
+ [ClientProcessId] ulong pid)
+ {
+ // NOTE: We always assume that only the default device will be plugged (we never report any USB Audio Class type devices).
+
+ return OpenAudioIn(out outputConfig, out audioIn, outName, parameter, appletResourceId, processHandle, name, pid);
+ }
+ }
+}