/*************************************************************************** * * * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 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 General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the Free Software * * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * * MA 02111-1307 USA * ***************************************************************************/ #ifndef __LS_AUDIOOUTPUTDEVICEALSA_H__ #define __LS_AUDIOOUTPUTDEVICEALSA_H__ #include #include #include "../common/global.h" #include "../common/Thread.h" #include "AudioOutputDevice.h" #include "AudioChannel.h" #include "../drivers/DeviceParameter.h" namespace LinuxSampler { /** ALSA audio output driver * * Implements audio output to the Advanced Linux Sound Architecture (ALSA). */ class AudioOutputDeviceAlsa : public AudioOutputDevice, protected Thread { public: AudioOutputDeviceAlsa(std::map Parameters); ~AudioOutputDeviceAlsa(); // derived abstract methods from class 'AudioOutputDevice' virtual void Play(); virtual bool IsPlaying(); virtual void Stop(); virtual void AcquireChannels(uint Channels); virtual uint MaxSamplesPerCycle(); virtual uint SampleRate(); static String Description(); static String Version(); static std::map AvailableParameters(); class ParameterCard : public DeviceCreationParameterString { public: ParameterCard(AudioOutputDevice* pDevice) { this->pDevice = pDevice; } ParameterCard(AudioOutputDevice* pDevice, String card) throw (LinuxSamplerException) : DeviceCreationParameterString(card) { this->pDevice = pDevice; } virtual String Description() { return "Sound card to be used"; } virtual bool Fix() { return true; } virtual bool Mandatory() { return false; } virtual std::map DependsAsParameters() { return std::map(); } virtual optional Default(std::map Parameters) { return "0,0"; /* first card by default */ } virtual std::vector PossibilitiesAsString(std::map Parameters) { return std::vector(); /*TODO: return possible cards*/ } virtual void OnSetValue(String s) throw (LinuxSamplerException) { /* not posssible, as parameter is fix */ } protected: AudioOutputDevice* pDevice; }; class ParameterFragments : public DeviceCreationParameterInt { public: ParameterFragments(AudioOutputDevice* pDevice) { this->pDevice = pDevice; } ParameterFragments(AudioOutputDevice* pDevice, String val) throw (LinuxSamplerException) : DeviceCreationParameterInt(val) { this->pDevice = pDevice; } virtual String Description() { return "Number of buffer fragments"; } virtual bool Fix() { return true; } virtual bool Mandatory() { return false; } virtual std::map DependsAsParameters() { return std::map(); } //TODO: should return dependency to CARD virtual optional DefaultAsInt(std::map Parameters) { return optional::nothing; } virtual optional RangeMinAsInt(std::map Parameters) { return optional::nothing; } virtual optional RangeMaxAsInt(std::map Parameters) { return optional::nothing; } virtual std::vector PossibilitiesAsInt(std::map Parameters) { return std::vector(); } virtual void OnSetValue(int i) throw (LinuxSamplerException) { /* not posssible, as parameter is fix */ } protected: AudioOutputDevice* pDevice; }; class ParameterFragmentSize : public DeviceCreationParameterInt { public: ParameterFragmentSize(AudioOutputDevice* pDevice) { this->pDevice = pDevice; } ParameterFragmentSize(AudioOutputDevice* pDevice, String val) throw (LinuxSamplerException) : DeviceCreationParameterInt(val) { this->pDevice = pDevice; } virtual String Description() { return "Size of each buffer fragment"; } virtual bool Fix() { return true; } virtual bool Mandatory() { return false; } virtual std::map DependsAsParameters() { return std::map(); } //TODO: should return dependency to CARD virtual optional DefaultAsInt(std::map Parameters) { return optional::nothing; } virtual optional RangeMinAsInt(std::map Parameters) { return optional::nothing; } virtual optional RangeMaxAsInt(std::map Parameters) { return optional::nothing; } virtual std::vector PossibilitiesAsInt(std::map Parameters) { return std::vector(); } virtual void OnSetValue(int i) throw (LinuxSamplerException) { /* not posssible, as parameter is fix */ } protected: AudioOutputDevice* pDevice; }; protected: int Main(); ///< Implementation of virtual method from class Thread AudioOutputDeviceAlsa(uint Channels = 2, uint Samplerate = 44100, uint Fragments = 2, uint FragmentSize = 128, String Card = "0,0"); std::map CreateParameters(std::map Parameters); private: uint uiAlsaChannels; uint uiSamplerate; uint FragmentSize; int16_t* pAlsaOutputBuffer; ///< This is the buffer where the final mix will be copied to and send to the sound card String pcm_name; ///< Name of the PCM device, like plughw:0,0 the first number is the number of the soundcard, the second number is the number of the device. snd_pcm_t* pcm_handle; ///< Handle for the PCM device snd_pcm_stream_t stream; snd_pcm_hw_params_t* hwparams; ///< This structure contains information about the hardware and can be used to specify the configuration to be used for the PCM stream. snd_pcm_sw_params_t* swparams; int Output(); bool HardwareParametersSupported(String card, uint channels, int samplerate, uint numfragments, uint fragmentsize); }; } #endif // __LS_AUDIOOUTPUTDEVICEALSA_H__