summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDale Rahn <drahn@cvs.openbsd.org>2005-01-30 21:55:51 +0000
committerDale Rahn <drahn@cvs.openbsd.org>2005-01-30 21:55:51 +0000
commit971299eb3e37dcc90641f726688aa48ad0e10aaf (patch)
tree3c17d932e5bf92e7987c48a21f2a0044de2aaad7
parentc6e1d4ec4345fac036356b1d20888b041494dd13 (diff)
Hack to allow emulation of mouse buttons for now, incorrectly shares
global between zkbd and zts, until a better solution is found.
-rw-r--r--sys/arch/zaurus/dev/zaurus_kbd.c9
-rw-r--r--sys/arch/zaurus/dev/zts.c36
2 files changed, 40 insertions, 5 deletions
diff --git a/sys/arch/zaurus/dev/zaurus_kbd.c b/sys/arch/zaurus/dev/zaurus_kbd.c
index 9fa68cff985..d7ec1d0c7be 100644
--- a/sys/arch/zaurus/dev/zaurus_kbd.c
+++ b/sys/arch/zaurus/dev/zaurus_kbd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: zaurus_kbd.c,v 1.11 2005/01/28 14:47:31 drahn Exp $ */
+/* $OpenBSD: zaurus_kbd.c,v 1.12 2005/01/30 21:55:50 drahn Exp $ */
/*
* Copyright (c) 2005 Dale Rahn <drahn@openbsd.org>
*
@@ -119,6 +119,8 @@ int zkbd_on(void *v);
int zkbd_sync(void *v);
int zkbd_hinge(void *v);
+int zkbd_modstate;
+
struct cfattach zkbd_ca = {
sizeof(struct zkbd_softc), zkbd_match, zkbd_attach
};
@@ -339,6 +341,11 @@ zkbd_poll(void *v)
/* process after resetting interrupt */
+ zkbd_modstate = (
+ (sc->sc_keystate[84] ? (1 << 0) : 0) | /* shift */
+ (sc->sc_keystate[93] ? (1 << 1) : 0) | /* Fn */
+ (sc->sc_keystate[14] ? (1 << 2) : 0)); /* 'alt' */
+
for (i = 0; i < (sc->sc_nsense * sc->sc_nstrobe); i++) {
stuck = 0;
/* extend xt_keymap to do this faster. */
diff --git a/sys/arch/zaurus/dev/zts.c b/sys/arch/zaurus/dev/zts.c
index ec31a3fb9a4..8d7921578a0 100644
--- a/sys/arch/zaurus/dev/zts.c
+++ b/sys/arch/zaurus/dev/zts.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: zts.c,v 1.2 2005/01/28 23:26:54 drahn Exp $ */
+/* $OpenBSD: zts.c,v 1.3 2005/01/30 21:55:50 drahn Exp $ */
/*
* Copyright (c) 2005 Dale Rahn <drahn@openbsd.org>
*
@@ -99,7 +99,9 @@ zts_attach(struct device *parent, struct device *self, void *aux)
timeout_set(&(sc->sc_ts_poll), zts_poll, sc);
- timeout_add(&sc->sc_ts_poll, POLL_TIMEOUT_RATE);
+
+ sc->sc_enabled = 0;
+ sc->sc_buttons = 0;
/*
pxa2x0_gpio_set_function(IRQ_GPIO_TP_INT_C3K, GPIO_IN);
@@ -181,11 +183,32 @@ zts_irq(void *v)
* relative mode here is really just a hack until abs mode
* really works in X.
*/
- if (t0 != 0 && t1 != 0) {
+ if (t0 > 10 && t1 > 10) {
int dx, dy;
int skip = 0;
if ( sc->sc_oldx == -1) {
+ extern int zkbd_modstate;
+ if (zkbd_modstate != 0) {
+ /*
+ * use motifiers with touchpress to indicate
+ * buttons.
+ */
+
+ if(zkbd_modstate & (1 << 0)) {
+ /* shift */
+ sc->sc_buttons |= (1 << 0);
+ }
+ if(zkbd_modstate & (1 << 1)) {
+ /* Fn */
+ sc->sc_buttons |= (1 << 1);
+ }
+ if(zkbd_modstate & (1 << 2)) {
+ /* 'Alt' */
+ sc->sc_buttons |= (1 << 2);
+ }
+
+ }
skip = 1;
}
@@ -202,9 +225,14 @@ zts_irq(void *v)
sc->sc_oldx = x;
sc->sc_oldy = y;
if (!skip)
- wsmouse_input(sc->sc_wsmousedev, 0/* XXX buttons */,
+ wsmouse_input(sc->sc_wsmousedev, sc->sc_buttons,
dx, dy, 0 /* XXX*/, WSMOUSE_INPUT_DELTA);
} else {
+
+ sc->sc_buttons = 0;
+ wsmouse_input(sc->sc_wsmousedev, sc->sc_buttons,
+ 0, 0, 0 /* XXX*/, WSMOUSE_INPUT_DELTA);
+
sc->sc_oldx = -1;
sc->sc_oldy = -1;
}