* alsa-sink: if "PCM" is not found as mixer track name, fallback to "Master"
authorLennart Poettering <lennart@poettering.net>
Tue, 30 May 2006 22:48:17 +0000 (22:48 +0000)
committerLennart Poettering <lennart@poettering.net>
Tue, 30 May 2006 22:48:17 +0000 (22:48 +0000)
* alsa-source: if "Capture" is not found as mixer track name, fallback to "Mic"

git-svn-id: file:///home/lennart/svn/public/pulseaudio/trunk@993 fefdeb5f-60dc-0310-8127-8f9354f1896f

src/modules/alsa-util.c
src/modules/alsa-util.h
src/modules/module-alsa-sink.c
src/modules/module-alsa-source.c

index 22e623f..be0fc06 100644 (file)
@@ -337,18 +337,29 @@ int pa_alsa_prepare_mixer(snd_mixer_t *mixer, const char *dev) {
     return 0;
 }
 
-snd_mixer_elem_t *pa_alsa_find_elem(snd_mixer_t *mixer, const char *name) {
+snd_mixer_elem_t *pa_alsa_find_elem(snd_mixer_t *mixer, const char *name, const char *fallback) {
     snd_mixer_elem_t *elem;
-    snd_mixer_selem_id_t *sid;
+    snd_mixer_selem_id_t *sid = NULL;
     snd_mixer_selem_id_alloca(&sid);
 
-    assert(mixer && name);
+    assert(mixer);
+    assert(name);
 
     snd_mixer_selem_id_set_name(sid, name);
 
-    elem = snd_mixer_find_selem(mixer, sid);
-    if (!elem)
-        pa_log_warn(__FILE__": Cannot find mixer control %s", snd_mixer_selem_id_get_name(sid));
+    if (!(elem = snd_mixer_find_selem(mixer, sid))) {
+        pa_log_warn(__FILE__": Cannot find mixer control \"%s\".", snd_mixer_selem_id_get_name(sid));
+
+        if (fallback) {
+            snd_mixer_selem_id_set_name(sid, fallback);
+            
+            if (!(elem = snd_mixer_find_selem(mixer, sid)))
+                pa_log_warn(__FILE__": Cannot find fallback mixer control \"%s\".", snd_mixer_selem_id_get_name(sid));
+        }
+    }
+
+    if (elem)
+        pa_log_warn(__FILE__": Using mixer control \"%s\".", snd_mixer_selem_id_get_name(sid));
 
     return elem;
 }
index 4bee862..83d1481 100644 (file)
@@ -40,6 +40,6 @@ int pa_alsa_fdlist_init_mixer(struct pa_alsa_fdlist *fdl, snd_mixer_t *mixer_han
 int pa_alsa_set_hw_params(snd_pcm_t *pcm_handle, pa_sample_spec *ss, uint32_t *periods, snd_pcm_uframes_t *period_size);
 
 int pa_alsa_prepare_mixer(snd_mixer_t *mixer, const char *dev);
-snd_mixer_elem_t *pa_alsa_find_elem(snd_mixer_t *mixer, const char *name);
+snd_mixer_elem_t *pa_alsa_find_elem(snd_mixer_t *mixer, const char *name, const char *fallback);
 
 #endif
index a0b6dc0..620047b 100644 (file)
@@ -373,7 +373,7 @@ int pa__init(pa_core *c, pa_module*m) {
     }
 
     if ((pa_alsa_prepare_mixer(u->mixer_handle, dev) < 0) ||
-        !(u->mixer_elem = pa_alsa_find_elem(u->mixer_handle, "PCM"))) {
+        !(u->mixer_elem = pa_alsa_find_elem(u->mixer_handle, "PCM", "Master"))) {
         snd_mixer_close(u->mixer_handle);
         u->mixer_handle = NULL;
     }
index 10b98f7..0999c65 100644 (file)
@@ -366,7 +366,7 @@ int pa__init(pa_core *c, pa_module*m) {
     }
 
     if ((pa_alsa_prepare_mixer(u->mixer_handle, dev) < 0) ||
-        !(u->mixer_elem = pa_alsa_find_elem(u->mixer_handle, "Capture"))) {
+        !(u->mixer_elem = pa_alsa_find_elem(u->mixer_handle, "Capture", "Mic"))) {
         snd_mixer_close(u->mixer_handle);
         u->mixer_handle = NULL;
     }