/*************************************************************************** * * * 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" namespace LinuxSampler { /** ALSA audio output driver * * Implements audio output to the Advanced Linux Sound Architecture (ALSA). */ class AudioOutputDeviceAlsa : public AudioOutputDevice, protected Thread { public: AudioOutputDeviceAlsa(uint Channels = 2, uint Samplerate = 44100, uint Fragments = 3, uint FragmentSize = 512, String Card = "0,0"); ~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(); 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(uint channels, int samplerate, uint numfragments, uint fragmentsize); }; } #endif // __LS_AUDIOOUTPUTDEVICEALSA_H__