From 0c6062ece8e73986a031a22c440f2b2b5f5a9a12 Mon Sep 17 00:00:00 2001 From: =?utf8?q?R=C3=A9mi=20Denis-Courmont?= Date: Sat, 17 Jul 2010 20:25:35 +0300 Subject: [PATCH] udev: use ALSA to find capture device names This is a little bit more understandable than device numbers. Unfortunately, hot plug is as flaky as before: udev reports the device before it is ready. alsa-lib provides no event interface (that I know), so we have to stick with udev for now though. Also, alsa-lib is _not_ used to fetch the card name. In my opinion, the udev vendor string is a lot better. Compare: - "USB Device 0xccd:0x77" (alsa card name) with "TerraTec Electronic GmbH" (udev vendor), or - "Intel ICH6" (alsa card name) with "Intel Corporation" (udev vendor). --- modules/services_discovery/Modules.am | 12 +++++++++- modules/services_discovery/udev.c | 34 ++++++++++++++++++--------- 2 files changed, 34 insertions(+), 12 deletions(-) diff --git a/modules/services_discovery/Modules.am b/modules/services_discovery/Modules.am index bb603292f8..a14c60a62f 100644 --- a/modules/services_discovery/Modules.am +++ b/modules/services_discovery/Modules.am @@ -5,7 +5,15 @@ SOURCES_bonjour = bonjour.c SOURCES_podcast = podcast.c SOURCES_mtp = mtp.c SOURCES_mediadirs = mediadirs.c -SOURCES_udev = udev.c + +libudev_plugin_la_SOURCES = udev.c +libudev_plugin_la_CFLAGS = $(AM_CFLAGS) $(UDEV_CFLAGS) +libudev_plugin_la_LIBADD = $(AM_LIBADD) $(UDEV_LIBS) +libudev_plugin_la_DEPENDENCIES = +if HAVE_ALSA +libudev_plugin_la_CFLAGS += $(ALSA_CFLAGS) -DHAVE_ALSA +libudev_plugin_la_LIBADD += $(ALSA_LIBS) +endif libxcb_apps_plugin_la_SOURCES = xcb_apps.c libxcb_apps_plugin_la_CFLAGS = $(AM_CFLAGS) \ @@ -15,9 +23,11 @@ libxcb_apps_plugin_la_LIBADD = $(AM_LIBADD) \ libxcb_apps_plugin_la_DEPENDENCIES = EXTRA_LTLIBRARIES += \ + libudev_plugin.la \ libxcb_apps_plugin.la libvlc_LTLIBRARIES += \ libmediadirs_plugin.la \ libpodcast_plugin.la \ libsap_plugin.la \ + $(LTLIBudev) \ $(LTLIBxcb_apps) diff --git a/modules/services_discovery/udev.c b/modules/services_discovery/udev.c index ea677d6435..e39f43a7c5 100644 --- a/modules/services_discovery/udev.c +++ b/modules/services_discovery/udev.c @@ -435,7 +435,10 @@ int OpenV4L (vlc_object_t *obj) } +#ifdef HAVE_ALSA /*** Advanced Linux Sound Architecture support ***/ +#include + static int alsa_get_device (struct udev_device *dev, unsigned *restrict pcard, unsigned *restrict pdevice) { @@ -469,22 +472,30 @@ static char *alsa_get_mrl (struct udev_device *dev) static char *alsa_get_name (struct udev_device *dev) { - const char *model = NULL; - char *name; + char *name = NULL; unsigned card, device; if (alsa_get_device (dev, &card, &device)) return NULL; - dev = udev_device_get_parent (dev); - if (dev != NULL) - model = udev_device_get_property_value (dev, - "ID_MODEL_FROM_DATABASE"); - if (model == NULL) - model = _("Device"); - - if (asprintf (&name, "%s (%u)", model, device) == -1) - name = NULL; + char card_name[4 + 3 * sizeof (int)]; + snprintf (card_name, sizeof (card_name), "hw:%u", card); + + snd_ctl_t *ctl; + if (snd_ctl_open (&ctl, card_name, 0)) + return NULL; + + snd_pcm_info_t *pcm_info; + snd_pcm_info_alloca (&pcm_info); + snd_pcm_info_set_device (pcm_info, device); + snd_pcm_info_set_subdevice (pcm_info, 0); + snd_pcm_info_set_stream (pcm_info, SND_PCM_STREAM_CAPTURE); + if (snd_ctl_pcm_info (ctl, pcm_info)) + goto out; + + name = strdup (snd_pcm_info_get_name (pcm_info)); +out: + snd_ctl_close (ctl); return name; } @@ -511,6 +522,7 @@ int OpenALSA (vlc_object_t *obj) return Open (obj, &subsys); } +#endif /* HAVE_ALSA */ /*** Discs support ***/ -- 2.39.2