packages/Xorg/lib/tslib/patches/tslib-input_raw-grab_events.patch
mirko 986eb4eafc - update to Xorg X11R7.4 and reorganization of the xorg-section
- added tslib
 - added e17 and related efl-libs


git-svn-id: svn://svn.openwrt.org/openwrt/packages@13238 3c298f89-4303-0410-b956-a3cf2f4a3e73
2008-11-16 19:31:42 +00:00

121 lines
2.5 KiB
Diff

This patch adds support for "EVIOCGRAB" on the input device, which
tells the kernel _not_ to deliver events of the touchscreen to
/dev/input/mice.
This is probably what most people want, since unprocessed raw touchscreen
events should not be converted to emulated PS/2 mouse movements.
Signed-off-by: Harald Welte <laforge@openmoko.org>
Index: a/plugins/input-raw.c
===================================================================
--- a/plugins/input-raw.c (revision 49)
+++ b/plugins/input-raw.c (working copy)
@@ -18,6 +18,7 @@
#include <errno.h>
#include <stdio.h>
+#include <limits.h>
#include <stdlib.h>
#ifdef HAVE_UNISTD_H
@@ -33,6 +34,9 @@
#include "tslib-private.h"
+#define GRAB_EVENTS_WANTED 1
+#define GRAB_EVENTS_ACTIVE 2
+
struct tslib_input {
struct tslib_module_info module;
@@ -42,6 +46,7 @@
int sane_fd;
int using_syn;
+ int grab_events;
};
static int check_fd(struct tslib_input *i)
@@ -64,6 +69,14 @@
if (bit & (1 << EV_SYN))
i->using_syn = 1;
+
+ if (i->grab_events == GRAB_EVENTS_WANTED) {
+ if (ioctl(ts->fd, EVIOCGRAB, (void *)1)) {
+ fprintf(stderr, "Unable to grab selected input device\n");
+ return -1;
+ }
+ i->grab_events = GRAB_EVENTS_ACTIVE;
+ }
return 0;
}
@@ -222,6 +235,15 @@
static int ts_input_fini(struct tslib_module_info *inf)
{
+ struct tslib_input *i = (struct tslib_input *)inf;
+ struct tsdev *ts = inf->dev;
+
+ if (i->grab_events == GRAB_EVENTS_ACTIVE) {
+ if (ioctl(ts->fd, EVIOCGRAB, (void *)0)) {
+ fprintf(stderr, "Unable to un-grab selected input device\n");
+ }
+ }
+
free(inf);
return 0;
}
@@ -231,6 +253,36 @@
.fini = ts_input_fini,
};
+static int parse_raw_grab(struct tslib_module_info *inf, char *str, void *data)
+{
+ struct tslib_input *i = (struct tslib_input *)inf;
+ unsigned long v;
+ int err = errno;
+
+ v = strtoul(str, NULL, 0);
+
+ if (v == ULONG_MAX && errno == ERANGE)
+ return -1;
+
+ errno = err;
+ switch ((int)data) {
+ case 1:
+ if (v)
+ i->grab_events = GRAB_EVENTS_WANTED;
+ break;
+ default:
+ return -1;
+ }
+ return 0;
+}
+
+static const struct tslib_vars raw_vars[] =
+{
+ { "grab_events", (void *)1, parse_raw_grab },
+};
+
+#define NR_VARS (sizeof(raw_vars) / sizeof(raw_vars[0]))
+
TSAPI struct tslib_module_info *mod_init(struct tsdev *dev, const char *params)
{
struct tslib_input *i;
@@ -245,5 +297,12 @@
i->current_p = 0;
i->sane_fd = 0;
i->using_syn = 0;
+ i->grab_events = 0;
+
+ if (tslib_parse_vars(&i->module, raw_vars, NR_VARS, params)) {
+ free(i);
+ return NULL;
+ }
+
return &(i->module);
}