diff options
Diffstat (limited to 'dxr3audio-alsa.c')
-rw-r--r-- | dxr3audio-alsa.c | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/dxr3audio-alsa.c b/dxr3audio-alsa.c index a946d2f..23af170 100644 --- a/dxr3audio-alsa.c +++ b/dxr3audio-alsa.c @@ -92,9 +92,17 @@ void cAudioAlsa::setup(int channels, int samplerate) } // set access type - err = snd_pcm_hw_params_set_access(handle, alsa_hwparams, SND_PCM_ACCESS_RW_INTERLEAVED); + pcm_write_func = &snd_pcm_mmap_writei; + err = snd_pcm_hw_params_set_access(handle, alsa_hwparams, SND_PCM_ACCESS_MMAP_INTERLEAVED); if (err < 0) { - esyslog("[dxr3-audio-alsa] Unable to set access type: %s", snd_strerror(err)); + esyslog("[dxr3-audio-alsa] mmap not available, attempting to fall back to slow writes"); + + pcm_write_func = &snd_pcm_writei; + err = snd_pcm_hw_params_set_access(handle, alsa_hwparams, SND_PCM_ACCESS_RW_INTERLEAVED); + if (err < 0) { + esyslog("[dxr3-audio-alsa] Unable to set access type: %s", snd_strerror(err)); + exit(-2); + } } // set format @@ -228,10 +236,10 @@ void cAudioAlsa::write(uchar* data, size_t size) snd_pcm_sframes_t res = 0; while (frames > 0) { - res = snd_pcm_writei(handle, output_samples, frames); + res = pcm_write_func(handle, output_samples, frames); if (res == -EAGAIN) { - snd_pcm_wait(handle, 500); + snd_pcm_wait(handle, 10); } else if (res == -EINTR) { // nothing to do res = 0; |