public inbox for linux-media@vger.kernel.org
 help / color / mirror / Atom feed
From: Jean-Francois Moine <moinejf@free.fr>
To: linux-media@vger.kernel.org,
	Douglas Schilling Landgraf <dougsland@redhat.com>
Cc: Mauro Carvalho Chehab <mchehab@redhat.com>
Subject: Re: [hg:v4l-dvb] gspca - main: Fix a compile error when CONFIG_INPUT is not set
Date: Wed, 3 Mar 2010 09:51:23 +0100	[thread overview]
Message-ID: <20100303095123.047a4d1e@tele> (raw)
In-Reply-To: <E1Nmblu-0007t3-Dm@www.linuxtv.org>

[-- Attachment #1: Type: text/plain, Size: 3206 bytes --]

On Wed, 03 Mar 2010 00:45:02 +0100
Patch from Jean-Fran?ois Moine  <hg-commit@linuxtv.org> wrote:

> The patch number 14343 was added via Douglas Schilling Landgraf
> <dougsland@redhat.com> to http://linuxtv.org/hg/v4l-dvb master
> development tree.
> 
> Kernel patches in this development tree may be modified to be backward
> compatible with older kernels. Compatibility modifications will be
> removed before inclusion into the mainstream Kernel
> 
> If anyone has any objections, please let us know by sending a message
> to: Linux Media Mailing List <linux-media@vger.kernel.org>
> 
> ------
> 
> From: Jean-Fran?ois Moine  <moinejf@free.fr>
> gspca - main: Fix a compile error when CONFIG_INPUT is not set
> 
> 
> Reported-by: Randy Dunlap <randy.dunlap@oracle.com>
> 
> Priority: normal
> 
> [dougsland@redhat.com: patch backported to hg tree]
> Signed-off-by: Jean-Fran?ois Moine <moinejf@free.fr>
> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
> Signed-off-by: Douglas Schilling Landgraf <dougsland@redhat.com>
> 
> 
> ---
> 
>  linux/drivers/media/video/gspca/gspca.c |    6 ++++++
>  1 file changed, 6 insertions(+)
> 
> diff -r c533329e3c41 -r 6519c63ecf6d
> linux/drivers/media/video/gspca/gspca.c ---
> a/linux/drivers/media/video/gspca/gspca.c	Tue Mar 02 20:16:17
> 2010 -0300 +++ b/linux/drivers/media/video/gspca/gspca.c	Tue
> Mar 02 20:38:01 2010 -0300 @@ -44,10 +44,12 @@ 
>  #include "gspca.h"
>  
> +#ifdef CONFIG_INPUT
>  #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
>  #include <linux/input.h>
>  #include <linux/usb/input.h>
>  #endif
> +#endif
>  
>  /* global values */
>  #define DEF_NURBS 3		/* default number of URBs */
> @@ -2371,9 +2373,11 @@
>  void gspca_disconnect(struct usb_interface *intf)
>  {
>  	struct gspca_dev *gspca_dev = usb_get_intfdata(intf);
> +#ifdef CONFIG_INPUT
>  #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
>  	struct input_dev *input_dev;
>  #endif
> +#endif
>  
>  	PDEBUG(D_PROBE, "%s disconnect",
>  		video_device_node_name(&gspca_dev->vdev));
> @@ -2385,6 +2389,7 @@
>  		wake_up_interruptible(&gspca_dev->wq);
>  	}
>  
> +#ifdef CONFIG_INPUT
>  #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
>  	gspca_input_destroy_urb(gspca_dev);
>  	input_dev = gspca_dev->input_dev;
> @@ -2393,6 +2398,7 @@
>  		input_unregister_device(input_dev);
>  	}
>  #endif
> +#endif
>  
>  	/* the device is freed at exit of this function */
>  	gspca_dev->dev = NULL;
> 
> 
> ---
> 
> Patch is available at:
> http://linuxtv.org/hg/v4l-dvb/rev/6519c63ecf6d4e7e2c1c3d46ac2a161da8d6c6f4

Hello Douglas,

I do not understand your patch. Do you mean that the input events
cannot be used with kernel < 2.6.19, while CONFIG_INPUT can be set?

Anyway, this patch seems complex. It would have been easier to simply
unset CONFIG_INPUT when kernel < 2.6.19.

I join the diff of gspca.c between v4l-dvb and my repository. This last
one is closer to the git version and there are still other changes done
in git. How do you think I should merge?

Cheers.

-- 
Ken ar c'hentañ	|	      ** Breizh ha Linux atav! **
Jef		|		http://moinejf.free.fr/

[-- Attachment #2: gspca.dif --]
[-- Type: application/octet-stream, Size: 3596 bytes --]

--- /tmp/gspca.c~other.0wSSrD	2010-03-03 09:17:29.000000000 +0100
+++ linux/drivers/media/video/gspca/gspca.c	2010-03-03 09:17:29.000000000 +0100
@@ -45,11 +45,9 @@
 #include "gspca.h"
 
 #ifdef CONFIG_INPUT
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 #include <linux/input.h>
 #include <linux/usb/input.h>
 #endif
-#endif
 
 /* global values */
 #define DEF_NURBS 3		/* default number of URBs */
@@ -126,8 +124,11 @@
  * Input and interrupt endpoint handling functions
  */
 #ifdef CONFIG_INPUT
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 19)
+static void int_irq(struct urb *urb, struct pt_regs *regs)
+#else
 static void int_irq(struct urb *urb)
+#endif
 {
 	struct gspca_dev *gspca_dev = (struct gspca_dev *) urb->context;
 	int ret;
@@ -306,7 +307,6 @@
 #define gspca_input_create_urb(gspca_dev)	0
 #define gspca_input_destroy_urb(gspca_dev)
 #endif
-#endif
 
 /* get the current input frame buffer */
 struct gspca_frame *gspca_get_i_frame(struct gspca_dev *gspca_dev)
@@ -695,21 +695,13 @@
 			i, ep->desc.bEndpointAddress);
 	gspca_dev->alt = i;		/* memorize the current alt setting */
 	if (gspca_dev->nbalt > 1) {
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 		gspca_input_destroy_urb(gspca_dev);
-#endif
 		ret = usb_set_interface(gspca_dev->dev, gspca_dev->iface, i);
 		if (ret < 0) {
 			err("set alt %d err %d", i, ret);
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 			ep = NULL;
-#else
-			return NULL;
-#endif
 		}
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 		gspca_input_create_urb(gspca_dev);
-#endif
 	}
 	return ep;
 }
@@ -920,13 +912,9 @@
 		if (gspca_dev->sd_desc->stopN)
 			gspca_dev->sd_desc->stopN(gspca_dev);
 		destroy_urbs(gspca_dev);
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 		gspca_input_destroy_urb(gspca_dev);
-#endif
 		gspca_set_alt0(gspca_dev);
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 		gspca_input_create_urb(gspca_dev);
-#endif
 	}
 
 	/* always call stop0 to free the subdriver's resources */
@@ -2350,11 +2338,9 @@
 	usb_set_intfdata(intf, gspca_dev);
 	PDEBUG(D_PROBE, "%s created", video_device_node_name(&gspca_dev->vdev));
 
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 	ret = gspca_input_connect(gspca_dev);
 	if (ret == 0)
 		ret = gspca_input_create_urb(gspca_dev);
-#endif
 
 	return 0;
 out:
@@ -2374,10 +2360,8 @@
 {
 	struct gspca_dev *gspca_dev = usb_get_intfdata(intf);
 #ifdef CONFIG_INPUT
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 	struct input_dev *input_dev;
 #endif
-#endif
 
 	PDEBUG(D_PROBE, "%s disconnect",
 		video_device_node_name(&gspca_dev->vdev));
@@ -2390,7 +2374,6 @@
 	}
 
 #ifdef CONFIG_INPUT
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 	gspca_input_destroy_urb(gspca_dev);
 	input_dev = gspca_dev->input_dev;
 	if (input_dev) {
@@ -2398,7 +2381,6 @@
 		input_unregister_device(input_dev);
 	}
 #endif
-#endif
 
 	/* the device is freed at exit of this function */
 	gspca_dev->dev = NULL;
@@ -2425,9 +2407,7 @@
 	if (gspca_dev->sd_desc->stopN)
 		gspca_dev->sd_desc->stopN(gspca_dev);
 	destroy_urbs(gspca_dev);
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 	gspca_input_destroy_urb(gspca_dev);
-#endif
 	gspca_set_alt0(gspca_dev);
 	if (gspca_dev->sd_desc->stop0)
 		gspca_dev->sd_desc->stop0(gspca_dev);
@@ -2441,9 +2421,7 @@
 
 	gspca_dev->frozen = 0;
 	gspca_dev->sd_desc->init(gspca_dev);
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 19)
 	gspca_input_create_urb(gspca_dev);
-#endif
 	if (gspca_dev->streaming)
 		return gspca_init_transfer(gspca_dev);
 	return 0;

       reply	other threads:[~2010-03-03  8:51 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <E1Nmblu-0007t3-Dm@www.linuxtv.org>
2010-03-03  8:51 ` Jean-Francois Moine [this message]
2010-03-03 16:19   ` [hg:v4l-dvb] gspca - main: Fix a compile error when CONFIG_INPUT is not set Douglas Schilling Landgraf
2010-03-04  8:55     ` Douglas Schilling Landgraf

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20100303095123.047a4d1e@tele \
    --to=moinejf@free.fr \
    --cc=dougsland@redhat.com \
    --cc=linux-media@vger.kernel.org \
    --cc=mchehab@redhat.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox