//
// 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.Renderer.Common;
using Ryujinx.Common.Utilities;
using System;
using System.Runtime.InteropServices;
namespace Ryujinx.Audio.Renderer.Parameter
{
/// <summary>
/// Input information for an effect.
/// </summary>
[StructLayout(LayoutKind.Sequential, Pack = 1)]
public struct EffectInParameter
/// Type of the effect.
public EffectType Type;
/// Set to true if the effect is new.
[MarshalAs(UnmanagedType.I1)]
public bool IsNew;
/// Set to true if the effect must be active.
public bool IsEnabled;
/// Reserved/padding.
private byte _reserved1;
/// The target mix id of the effect.
public int MixId;
/// Address of the processing workbuffer.
/// <remarks>This is additional data that could be required by the effect processing.</remarks>
public ulong BufferBase;
/// Size of the processing workbuffer.
public ulong BufferSize;
/// Position of the effect while processing effects.
public uint ProcessingOrder;
private uint _reserved2;
/// Specific data storage.
private SpecificDataStruct _specificDataStart;
[StructLayout(LayoutKind.Sequential, Size = 0xA0, Pack = 1)]
private struct SpecificDataStruct { }
/// Specific data changing depending of the <see cref="Type"/>. See also the <see cref="Effect"/> namespace.
public Span<byte> SpecificData => SpanHelpers.AsSpan<SpecificDataStruct, byte>(ref _specificDataStart);
/// Check if the given channel count is valid.
/// <param name="channelCount">The channel count to check</param>
/// <returns>Returns true if the channel count is valid.</returns>
public static bool IsChannelCountValid(int channelCount)
return channelCount == 1 || channelCount == 2 || channelCount == 4 || channelCount == 6;
}