/*************************************************************************** * * * 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 "../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(); virtual String Driver(); static String Name(); static String Description(); static String Version(); /** Device Parameter 'CARD' * * Used to select the desired ALSA sound card. */ class ParameterCard : public DeviceCreationParameterString { public: ParameterCard(); ParameterCard(String s) throw (LinuxSamplerException); virtual String Description(); virtual bool Fix(); virtual bool Mandatory(); virtual std::map DependsAsParameters(); virtual optional DefaultAsString(std::map Parameters); virtual std::vector PossibilitiesAsString(std::map Parameters); virtual void OnSetValue(String s) throw (LinuxSamplerException); static String Name(); }; /** Device Parameter 'FRAGMENTS' * * Used to select the number of audio fragments / periods. */ class ParameterFragments : public DeviceCreationParameterInt { public: ParameterFragments(); ParameterFragments(String s) throw (LinuxSamplerException); virtual String Description(); virtual bool Fix(); virtual bool Mandatory(); virtual std::map DependsAsParameters(); virtual optional DefaultAsInt(std::map Parameters); virtual optional RangeMinAsInt(std::map Parameters); virtual optional RangeMaxAsInt(std::map Parameters); virtual std::vector PossibilitiesAsInt(std::map Parameters); virtual void OnSetValue(int i) throw (LinuxSamplerException); static String Name(); }; /** Device Parameter 'FRAGMENTSIZE' * * Used to set the audio fragment size / period size. */ class ParameterFragmentSize : public DeviceCreationParameterInt { public: ParameterFragmentSize(); ParameterFragmentSize(String s) throw (LinuxSamplerException); virtual String Description(); virtual bool Fix(); virtual bool Mandatory(); virtual std::map DependsAsParameters(); virtual optional DefaultAsInt(std::map Parameters); virtual optional RangeMinAsInt(std::map Parameters); virtual optional RangeMaxAsInt(std::map Parameters); virtual std::vector PossibilitiesAsInt(std::map Parameters); virtual void OnSetValue(int i) throw (LinuxSamplerException); static String Name(); }; protected: int Main(); ///< Implementation of virtual method from class Thread 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__