diff options
author | Matthieu Herrb <matthieu@cvs.openbsd.org> | 1999-11-22 07:26:05 +0000 |
---|---|---|
committer | Matthieu Herrb <matthieu@cvs.openbsd.org> | 1999-11-22 07:26:05 +0000 |
commit | 510d7ddbeacd68b09f585510513464fe7045d52e (patch) | |
tree | f996245470164eaf3e6e41745f30f0de12ed4154 /sys/arch/i386/isa/lms.c | |
parent | bd32a8110ac2e138c4d57199c13407f305a2f0b7 (diff) |
add support for asynchronous I/O (through SIGIO)
Diffstat (limited to 'sys/arch/i386/isa/lms.c')
-rw-r--r-- | sys/arch/i386/isa/lms.c | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/sys/arch/i386/isa/lms.c b/sys/arch/i386/isa/lms.c index 0c4c31d51a9..a9420dab1c9 100644 --- a/sys/arch/i386/isa/lms.c +++ b/sys/arch/i386/isa/lms.c @@ -1,4 +1,4 @@ -/* $OpenBSD: lms.c,v 1.12 1999/08/22 08:16:20 downsj Exp $ */ +/* $OpenBSD: lms.c,v 1.13 1999/11/22 07:25:38 matthieu Exp $ */ /* $NetBSD: lms.c,v 1.30 1996/10/21 22:27:41 thorpej Exp $ */ /*- @@ -34,6 +34,7 @@ #include <sys/file.h> #include <sys/select.h> #include <sys/proc.h> +#include <sys/signalvar.h> #include <sys/vnode.h> #include <sys/device.h> @@ -64,6 +65,8 @@ struct lms_softc { /* driver status information */ struct clist sc_q; struct selinfo sc_rsel; + struct proc *sc_io; /* process that opened lms (can get SIGIO) */ + char sc_async; /* send SIGIO on input ready */ u_char sc_state; /* mouse driver state */ #define LMS_OPEN 0x01 /* device is open */ #define LMS_ASLP 0x02 /* waiting for mouse data */ @@ -170,6 +173,8 @@ lmsopen(dev, flag, mode, p) sc->sc_state |= LMS_OPEN; sc->sc_status = 0; sc->sc_x = sc->sc_y = 0; + sc->sc_async = 0; + sc->sc_io = p; /* Enable interrupts. */ bus_space_write_1(sc->sc_iot, sc->sc_ioh, LMS_CNTRL, 0); @@ -190,6 +195,7 @@ lmsclose(dev, flag, mode, p) bus_space_write_1(sc->sc_iot, sc->sc_ioh, LMS_CNTRL, 0x10); sc->sc_state &= ~LMS_OPEN; + sc->sc_io = NULL; clfree(&sc->sc_q); @@ -258,6 +264,18 @@ lmsioctl(dev, cmd, addr, flag, p) int error; switch (cmd) { + case FIONBIO: /* we will remove this someday (soon???) */ + return (0); + + case FIOASYNC: + sc->sc_async = *(int *)addr != 0; + break; + + case TIOCSPGRP: + if (*(int *)addr != sc->sc_io->p_pgid) + return (EPERM); + break; + case MOUSEIOCREAD: s = spltty(); @@ -357,6 +375,10 @@ lmsintr(arg) wakeup((caddr_t)sc); } selwakeup(&sc->sc_rsel); + if (sc->sc_async) { + psignal(sc->sc_io, SIGIO); + } + } return -1; |