diff options
author | waker <wakeroid@gmail.com> | 2011-05-21 22:23:01 +0200 |
---|---|---|
committer | waker <wakeroid@gmail.com> | 2011-05-21 22:23:01 +0200 |
commit | 5cb20cc33eb974948d6f431bcee2bff8fffe99d7 (patch) | |
tree | a350eb3417f8785bab39174d11c175fd911876fc /plugins/alsa | |
parent | ae4462a1675651d38d0de3d714846779a2bd2c90 (diff) |
improved alsa channels setting
Diffstat (limited to 'plugins/alsa')
-rw-r--r-- | plugins/alsa/alsa.c | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/plugins/alsa/alsa.c b/plugins/alsa/alsa.c index 4ae6386c..ad2ebb89 100644 --- a/plugins/alsa/alsa.c +++ b/plugins/alsa/alsa.c @@ -126,7 +126,6 @@ retry: } snd_pcm_format_t sample_fmt; - switch (plugin.fmt.bps) { case 8: sample_fmt = SND_PCM_FORMAT_S8; @@ -221,17 +220,22 @@ retry: plugin.fmt.samplerate = val; trace ("chosen samplerate: %d Hz\n", val); - int nchan; - snd_pcm_hw_params_get_channels (hw_params, &nchan); + int chanmin, chanmax; + snd_pcm_hw_params_get_channels_min (hw_params, &chanmin); + snd_pcm_hw_params_get_channels_max (hw_params, &chanmax); - if ((err = snd_pcm_hw_params_set_channels (audio, hw_params, plugin.fmt.channels)) < 0) { - fprintf (stderr, "cannot set channel count (%s), trying to set channels=%d\n", - snd_strerror (err), nchan); - if ((err = snd_pcm_hw_params_set_channels (audio, hw_params, nchan)) < 0) { - fprintf (stderr, "cannot set channel count (%s)\n", - snd_strerror (err)); - goto error; - } + trace ("minchan: %d, maxchan: %d\n", chanmin, chanmax); + int nchan = plugin.fmt.channels; + if (nchan > chanmax) { + nchan = chanmax; + } + else if (nchan < chanmin) { + nchan = chanmin; + } + trace ("setting chan=%d\n", nchan); + if ((err = snd_pcm_hw_params_set_channels (audio, hw_params, nchan)) < 0) { + fprintf (stderr, "cannot set channel count (%s)\n", + snd_strerror (err)); } snd_pcm_hw_params_get_channels (hw_params, &nchan); |