diff options
author | Alexandr Shadchin <shadchin@cvs.openbsd.org> | 2011-07-17 13:53:01 +0000 |
---|---|---|
committer | Alexandr Shadchin <shadchin@cvs.openbsd.org> | 2011-07-17 13:53:01 +0000 |
commit | 7dfeaf2d218d6d8404ff3e77d21e9c6260eb63ed (patch) | |
tree | 640f33644d3b7096e13280bc6129e0f31228962d | |
parent | 7f5d549c394a406152e3120d9a3724064feacb30 (diff) |
fix bug "lock up" touchpad ( not allowing to move the pointer, or click )
ok matthieu@
-rw-r--r-- | driver/xf86-input-synaptics/src/wsconscomm.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/driver/xf86-input-synaptics/src/wsconscomm.c b/driver/xf86-input-synaptics/src/wsconscomm.c index a439dacc8..e76b2dd1d 100644 --- a/driver/xf86-input-synaptics/src/wsconscomm.c +++ b/driver/xf86-input-synaptics/src/wsconscomm.c @@ -35,6 +35,7 @@ extern int priv_open_device(const char *); #endif #define DEFAULT_WSMOUSE0_DEV "/dev/wsmouse0" +#define NEVENTS 64 static const char *synaptics_devs[] = { DEFAULT_WSMOUSE0_DEV, @@ -90,6 +91,8 @@ WSConsDeviceOffHook(InputInfoPtr pInfo) static Bool WSConsQueryHardware(InputInfoPtr pInfo) { + SynapticsPrivate *priv = (SynapticsPrivate *)pInfo->private; + struct CommData *comm = &priv->comm; int wsmouse_type; if (ioctl(pInfo->fd, WSMOUSEIO_GTYPE, &wsmouse_type) == -1) { @@ -97,10 +100,16 @@ WSConsQueryHardware(InputInfoPtr pInfo) return FALSE; } - if (wsmouse_type == WSMOUSE_TYPE_SYNAPTICS) - return TRUE; + if (wsmouse_type != WSMOUSE_TYPE_SYNAPTICS) + return FALSE; - return FALSE; + if (comm->buffer) + XisbFree(comm->buffer); + comm->buffer = XisbNew(pInfo->fd, sizeof(struct wscons_event) * NEVENTS); + if (comm->buffer == NULL) + return FALSE; + + return TRUE; } static Bool |