public inbox for linux-media@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] ivtv-alsa: Add index to specify device number
@ 2015-08-13 19:37 Nicolas Sugino
  2015-08-14 11:31 ` Hans Verkuil
  0 siblings, 1 reply; 2+ messages in thread
From: Nicolas Sugino @ 2015-08-13 19:37 UTC (permalink / raw)
  To: mchehab, awalls, linux-media

When using multiple capture cards, it migth be necessary to identify a specific device with an ALSA one. If not, the order of the ALSA devices might have no relation to the id of the radio or video device.

Signed-off-by: Nicolas Sugino <nsugino@3way.com.ar>
---
 drivers/media/pci/ivtv/ivtv-alsa-main.c | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/drivers/media/pci/ivtv/ivtv-alsa-main.c b/drivers/media/pci/ivtv/ivtv-alsa-main.c
index 41fa215..034908c 100644
--- a/drivers/media/pci/ivtv/ivtv-alsa-main.c
+++ b/drivers/media/pci/ivtv/ivtv-alsa-main.c
@@ -41,6 +41,7 @@
 #include "ivtv-alsa-pcm.h"
 
 int ivtv_alsa_debug;
+static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
 
 #define IVTV_DEBUG_ALSA_INFO(fmt, arg...) \
 	do { \
@@ -54,6 +55,10 @@ MODULE_PARM_DESC(debug,
 		 "\t\t\t  1/0x0001: warning\n"
 		 "\t\t\t  2/0x0002: info\n");
 
+module_param_array(index, int, NULL, 0444);
+MODULE_PARM_DESC(index,
+		 "Index value for IVTV ALSA capture interface(s).\n");
+
 MODULE_AUTHOR("Andy Walls");
 MODULE_DESCRIPTION("CX23415/CX23416 ALSA Interface");
 MODULE_SUPPORTED_DEVICE("CX23415/CX23416 MPEG2 encoder");
@@ -146,7 +151,7 @@ static int snd_ivtv_init(struct v4l2_device *v4l2_dev)
 
 	/* (2) Create a card instance */
 	ret = snd_card_new(&itv->pdev->dev,
-			   SNDRV_DEFAULT_IDX1, /* use first available id */
+			   index[itv->instance] == -1 ? SNDRV_DEFAULT_IDX1 : index[itv->instance], /* use first available id if not specified otherwise*/
 			   SNDRV_DEFAULT_STR1, /* xid from end of shortname*/
 			   THIS_MODULE, 0, &sc);
 	if (ret) {
@@ -196,6 +201,9 @@ static int snd_ivtv_init(struct v4l2_device *v4l2_dev)
 		goto err_exit_free;
 	}
 
+	IVTV_ALSA_INFO("%s:: Instance %d registered ALSA card %d\n",
+			 __func__, itv->instance, index[itv->instance]);
+
 	return 0;
 
 err_exit_free:
-- 
2.1.4


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] ivtv-alsa: Add index to specify device number
  2015-08-13 19:37 [PATCH] ivtv-alsa: Add index to specify device number Nicolas Sugino
@ 2015-08-14 11:31 ` Hans Verkuil
  0 siblings, 0 replies; 2+ messages in thread
From: Hans Verkuil @ 2015-08-14 11:31 UTC (permalink / raw)
  To: Nicolas Sugino, mchehab, awalls, linux-media

On 08/13/2015 09:37 PM, Nicolas Sugino wrote:
> When using multiple capture cards, it migth be necessary to identify a specific device with an ALSA one. If not, the order of the ALSA devices might have no relation to the id of the radio or video device.
> 
> Signed-off-by: Nicolas Sugino <nsugino@3way.com.ar>
> ---
>  drivers/media/pci/ivtv/ivtv-alsa-main.c | 10 +++++++++-
>  1 file changed, 9 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/media/pci/ivtv/ivtv-alsa-main.c b/drivers/media/pci/ivtv/ivtv-alsa-main.c
> index 41fa215..034908c 100644
> --- a/drivers/media/pci/ivtv/ivtv-alsa-main.c
> +++ b/drivers/media/pci/ivtv/ivtv-alsa-main.c
> @@ -41,6 +41,7 @@
>  #include "ivtv-alsa-pcm.h"
>  
>  int ivtv_alsa_debug;
> +static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
>  
>  #define IVTV_DEBUG_ALSA_INFO(fmt, arg...) \
>  	do { \
> @@ -54,6 +55,10 @@ MODULE_PARM_DESC(debug,
>  		 "\t\t\t  1/0x0001: warning\n"
>  		 "\t\t\t  2/0x0002: info\n");
>  
> +module_param_array(index, int, NULL, 0444);
> +MODULE_PARM_DESC(index,
> +		 "Index value for IVTV ALSA capture interface(s).\n");
> +
>  MODULE_AUTHOR("Andy Walls");
>  MODULE_DESCRIPTION("CX23415/CX23416 ALSA Interface");
>  MODULE_SUPPORTED_DEVICE("CX23415/CX23416 MPEG2 encoder");
> @@ -146,7 +151,7 @@ static int snd_ivtv_init(struct v4l2_device *v4l2_dev)
>  
>  	/* (2) Create a card instance */
>  	ret = snd_card_new(&itv->pdev->dev,
> -			   SNDRV_DEFAULT_IDX1, /* use first available id */
> +			   index[itv->instance] == -1 ? SNDRV_DEFAULT_IDX1 : index[itv->instance], /* use first available id if not specified otherwise*/

This line is way too long.

It's more readable if you make an 'idx' local variable that you assign first, then use
in snd_card_new. The comment can go in front of the idx assignment.

>  			   SNDRV_DEFAULT_STR1, /* xid from end of shortname*/
>  			   THIS_MODULE, 0, &sc);
>  	if (ret) {
> @@ -196,6 +201,9 @@ static int snd_ivtv_init(struct v4l2_device *v4l2_dev)
>  		goto err_exit_free;
>  	}
>  
> +	IVTV_ALSA_INFO("%s:: Instance %d registered ALSA card %d\n",
> +			 __func__, itv->instance, index[itv->instance]);

You can't use index[] here since it could give back -1. You can probably
get the actual index from sc.

> +
>  	return 0;
>  
>  err_exit_free:
> 

Regards,

	Hans

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2015-08-14 11:32 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-08-13 19:37 [PATCH] ivtv-alsa: Add index to specify device number Nicolas Sugino
2015-08-14 11:31 ` Hans Verkuil

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox