summaryrefslogtreecommitdiff
path: root/v4l
diff options
context:
space:
mode:
Diffstat (limited to 'v4l')
-rw-r--r--v4l/Makefile3
-rw-r--r--v4l/compat.h23
2 files changed, 25 insertions, 1 deletions
diff --git a/v4l/Makefile b/v4l/Makefile
index 7674abd98..b07b592b1 100644
--- a/v4l/Makefile
+++ b/v4l/Makefile
@@ -102,6 +102,8 @@ EXTRA_CFLAGS += -g
EXTRA_CFLAGS += $(if $(wildcard $(srctree)/.mm), -DMM_KERNEL)
+EXTRA_CFLAGS += -include $(obj)/config-compat.h
+
#################################################
# Kernel 2.4/2.6 specific rules
@@ -241,6 +243,7 @@ config-compat.h:: .myconfig
-e 'while(<>) {' \
-e ' next unless /^(\S+)\s*:= (\S+)$$/;' \
-e ' print "#undef $$1\n";' \
+ -e ' print "#undef $$1_MODULE\n";' \
-e ' if($$2 eq "n") { next; }' \
-e ' elsif($$2 eq "m") { print "#define $$1_MODULE 1\n"; }' \
-e ' elsif($$2 eq "y") { print "#define $$1 1\n"; }' \
diff --git a/v4l/compat.h b/v4l/compat.h
index a4f66eee2..6ba49e825 100644
--- a/v4l/compat.h
+++ b/v4l/compat.h
@@ -10,7 +10,6 @@
#include <linux/version.h>
#include <linux/utsname.h>
#include <linux/sched.h>
-#include "config-compat.h"
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,4,18)
# define minor(x) MINOR(x)
@@ -268,6 +267,10 @@ static inline unsigned long vmalloc_to_pfn(void * vmalloc_addr)
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15)
# define input_allocate_device() kzalloc(sizeof(struct input_dev),GFP_KERNEL);
# define input_free_device(input_dev) kfree(input_dev)
+# ifdef _INPUT_H /* input.h must be included _before_ compat.h for this to work */
+ /* input_register_device() was changed to return an error code in 2.6.15 */
+# define input_register_device(x) (input_register_device(x), 0)
+# endif
#endif
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,15)
@@ -288,6 +291,24 @@ schedule_timeout_interruptible(signed long timeout)
}
#endif
+/* New 4GB DMA zone was added in 2.6.15-rc2 */
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15)
+# define __GFP_DMA32 __GFP_DMA
+#endif
+
+/* setup_timer() helper added 10/31/05, 2.6.15-rc1 */
+/* Need linux/timer.h to be included for struct timer_list */
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,15) && defined(_LINUX_TIMER_H)
+static inline void setup_timer(struct timer_list * timer,
+ void (*function)(unsigned long),
+ unsigned long data)
+{
+ timer->function = function;
+ timer->data = data;
+ init_timer(timer);
+}
+#endif
+
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
#define IRQF_SHARED SA_SHIRQ
#define IRQF_DISABLED SA_INTERRUPT