summaryrefslogtreecommitdiff
path: root/sys/arch/i386/isa
diff options
context:
space:
mode:
authorMatthieu Herrb <matthieu@cvs.openbsd.org>1998-04-01 20:21:01 +0000
committerMatthieu Herrb <matthieu@cvs.openbsd.org>1998-04-01 20:21:01 +0000
commit6bc3e22bb4487fa3a2e30138ae737e836f24d215 (patch)
tree7ba29a147fb74c271d877190b9b935142023ab94 /sys/arch/i386/isa
parent5d9febdb3830863198c6fb23051d34e5259c4cd7 (diff)
Add a write function and make the raw mode real raw in the PS/2 driver
to support extended PS/2 protocol under XFree86. From NetBSD port-i386/5130 by Lennart Augustsson <augustss@cs.chalmers.se>, adapted to OpenBSD by myself.
Diffstat (limited to 'sys/arch/i386/isa')
-rw-r--r--sys/arch/i386/isa/pms.c78
1 files changed, 32 insertions, 46 deletions
diff --git a/sys/arch/i386/isa/pms.c b/sys/arch/i386/isa/pms.c
index acaaf291f4a..1b7b3fa013e 100644
--- a/sys/arch/i386/isa/pms.c
+++ b/sys/arch/i386/isa/pms.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pms.c,v 1.17 1997/08/29 22:49:06 kstailey Exp $ */
+/* $OpenBSD: pms.c,v 1.18 1998/04/01 20:21:00 matthieu Exp $ */
/* $NetBSD: pms.c,v 1.29 1996/05/12 23:12:42 mycroft Exp $ */
/*-
@@ -364,6 +364,36 @@ pmsread(dev, uio, flag)
}
int
+pmswrite(dev, uio, flag)
+ dev_t dev;
+ struct uio *uio;
+ int flag;
+{
+ struct pms_softc *sc = pms_cd.cd_devs[PMSUNIT(dev)];
+ int i, n;
+ int error;
+ int s;
+ u_char wrbuf[32];
+
+
+ if (!(sc->sc_flags & PMS_RAW))
+ return ENODEV;
+
+ error = 0;
+ /* Only allow a small number of bytes per write. */
+ n = min(sizeof(wrbuf), uio->uio_resid);
+ error = uiomove(wrbuf, n, uio);
+ if (error)
+ return error;
+ s = spltty();
+ for(i = 0; i < n; i++)
+ pms_dev_cmd(wrbuf[i]);
+ splx(s);
+
+ return error;
+}
+
+int
pmsioctl(dev, cmd, addr, flag, p)
dev_t dev;
u_long cmd;
@@ -505,53 +535,9 @@ pmsintr(arg)
#endif
}
} else {
- /* read data port */
buffer[0] = inb(PMS_DATA);
-
- /* emulate old state machine for the ioctl's sake. */
- switch (state) {
- case 0:
- buttons = buffer[0];
- if ((buttons & 0xc0) == 0)
- ++state;
- break;
- case 1:
- dx = buffer[0];
- /* Bounding at -127 avoids a bug in XFree86. */
- dx = (dx == -128) ? -127 : dx;
- ++state;
- break;
- case 2:
- dy = buffer[0];
- dy = (dy == -128) ? -127 : dy;
-#ifdef INTELLIMOUSE
- ++state;
-#else
- state = 0;
-#endif
-
- buttons = ((buttons & PS2LBUTMASK) << 2) |
- ((buttons & (PS2RBUTMASK | PS2MBUTMASK)) >> 1);
- changed = ((buttons ^ sc->sc_status) & BUTSTATMASK) << 3;
- sc->sc_status = buttons |
- (sc->sc_status & ~BUTSTATMASK) | changed;
-
- if (dx || dy || changed) {
- /* Update accumulated movements. */
- sc->sc_x += dx;
- sc->sc_y += dy;
- }
- break;
-#ifdef INTELLIMOUSE /* discard fourth "wheel" byte */
- case 3:
- state = 0;
- return 0; /* XXX 0? -1? */
-#endif
- }
-
- /* add raw data to the queue. */
(void) b_to_q(buffer, 1, &sc->sc_q);
-
+
if (sc->sc_state & PMS_ASLP) {
sc->sc_state &= ~PMS_ASLP;
wakeup((caddr_t)sc);