diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arch/pmax/dev/dc.c | 1261 | ||||
-rw-r--r-- | sys/arch/pmax/dev/dc_cons.h | 17 | ||||
-rw-r--r-- | sys/arch/pmax/dev/dc_ds.c | 106 | ||||
-rw-r--r-- | sys/arch/pmax/dev/dc_ds_cons.h | 14 | ||||
-rw-r--r-- | sys/arch/pmax/dev/dc_ioasic.c | 109 | ||||
-rw-r--r-- | sys/arch/pmax/dev/dc_ioasic_cons.h | 14 | ||||
-rw-r--r-- | sys/arch/pmax/dev/dcvar.h | 50 |
7 files changed, 0 insertions, 1571 deletions
diff --git a/sys/arch/pmax/dev/dc.c b/sys/arch/pmax/dev/dc.c deleted file mode 100644 index 05ceec4f811..00000000000 --- a/sys/arch/pmax/dev/dc.c +++ /dev/null @@ -1,1261 +0,0 @@ -/* $NetBSD: dc.c,v 1.30 1996/10/16 02:10:33 jonathan Exp $ */ - -/*- - * Copyright (c) 1992, 1993 - * The Regents of the University of California. All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * Ralph Campbell and Rick Macklem. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Berkeley and its contributors. - * 4. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - * - * @(#)dc.c 8.5 (Berkeley) 6/2/95 - */ - -/* - * devDC7085.c -- - * - * This file contains machine-dependent routines that handle the - * output queue for the serial lines. - * - * Copyright (C) 1989 Digital Equipment Corporation. - * Permission to use, copy, modify, and distribute this software and - * its documentation for any purpose and without fee is hereby granted, - * provided that the above copyright notice appears in all copies. - * Digital Equipment Corporation makes no representations about the - * suitability of this software for any purpose. It is provided "as is" - * without express or implied warranty. - * - * from: Header: /sprite/src/kernel/dev/ds3100.md/RCS/devDC7085.c, - * v 1.4 89/08/29 11:55:30 nelson Exp SPRITE (DECWRL)"; - */ - -/* - * DC7085 (DZ-11 look alike) Driver - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/ioctl.h> -#include <sys/tty.h> -#include <sys/proc.h> -#include <sys/map.h> -#include <sys/buf.h> -#include <sys/conf.h> -#include <sys/file.h> -#include <sys/uio.h> -#include <sys/kernel.h> -#include <sys/syslog.h> - -#include <machine/conf.h> -#include <sys/device.h> -#include <machine/autoconf.h> -#include <dev/tc/tcvar.h> -#include <dev/tc/ioasicvar.h> - -#include <machine/dc7085cons.h> -#include <machine/pmioctl.h> - -#include <pmax/pmax/pmaxtype.h> -#include <pmax/pmax/cons.h> - -#include <pmax/dev/lk201.h> - -/* - * XXX in dcvar.h or not? - * #include <pmax/dev/pdma.h> - */ -#include "dcvar.h" - -#include "tc.h" - -#include <pmax/dev/lk201var.h> /* XXX KbdReset band friends */ - -#include <pmax/dev/dcvar.h> -#include <pmax/dev/dc_cons.h> - -extern struct cfdriver mainbus_cd; - -#define DCUNIT(dev) (minor(dev) >> 2) -#define DCLINE(dev) (minor(dev) & 3) - -/* - * Autoconfiguration data for config. - * - * Use the statically-allocated softc until old autoconfig code and - * config.old are completely gone. - */ -int old_dcmatch __P((struct device * parent, void *cfdata, void *aux)); -void old_dcattach __P((struct device *parent, struct device *self, void *aux)); - - -extern struct cfdriver dz_cd; -struct cfdriver dz_cd = { - NULL, "dz", DV_TTY -}; - - - -/* - * Forward declarations - */ -struct tty *dctty __P((dev_t dev)); -void dcstart __P((struct tty *)); -void dcrint __P((struct dc_softc *sc)); -void dcxint __P((struct tty *)); -int dcmctl __P((dev_t dev, int bits, int how)); -void dcscan __P((void *)); -int dcparam __P((struct tty *tp, struct termios *t)); -static int cold_dcparam __P((struct tty *tp, struct termios *t, - dcregs *dcaddr, int allow_19200)); - -void dc_reset __P ((dcregs *dcaddr)); - -/* console I/O */ -int dcGetc __P((dev_t)); -void dcPutc __P((dev_t, int)); -void dcPollc __P((dev_t, int)); -void dc_consinit __P((dev_t dev, dcregs *dcaddr)); - - -/* QVSS-compatible in-kernel X input event parser, pointer tracker */ -void (*dcDivertXInput) __P((int cc)); /* X windows keyboard input routine */ -void (*dcMouseEvent) __P((int)); /* X windows mouse motion event routine */ -void (*dcMouseButtons) __P((int)); /* X windows mouse buttons event routine */ -#ifdef DEBUG -int debugChar; -#endif - - -/* - * The DC7085 doesn't interrupt on carrier transitions, so - * we have to use a timer to watch it. - */ -int dc_timer; /* true if timer started */ - -/* - * Pdma structures for fast output code - */ - -struct speedtab dcspeedtab[] = { - { 0, 0, }, - { 50, LPR_B50 }, - { 75, LPR_B75 }, - { 110, LPR_B110 }, - { 134, LPR_B134 }, - { 150, LPR_B150 }, - { 300, LPR_B300 }, - { 600, LPR_B600 }, - { 1200, LPR_B1200 }, - { 1800, LPR_B1800 }, - { 2400, LPR_B2400 }, - { 4800, LPR_B4800 }, - { 9600, LPR_B9600 }, - { 19200,LPR_B19200 }, -#ifdef notyet - { 19200,LPR_B38400 }, /* Overloaded with 19200, per chip. */ -#endif - { -1, -1 } -}; - -#ifndef PORTSELECTOR -#define ISPEED TTYDEF_SPEED -#define LFLAG TTYDEF_LFLAG -#else -#define ISPEED B4800 -#define LFLAG (TTYDEF_LFLAG & ~ECHO) -#endif - -/* - * Console line variables, for use when cold - */ -extern int cold; -dcregs *dc_cons_addr = 0; - -/* - * Is there a framebuffer console device using this serial driver? - * XXX used for ugly special-cased console input that should be redone - * more cleanly. - */ -static inline int raster_console __P((void)); - -static inline int -raster_console() -{ - return (cn_tab->cn_pri == CN_INTERNAL || - cn_tab->cn_pri == CN_NORMAL); -} - - -/* XXX move back into dc_consinit when debugged */ -static struct consdev dccons = { - NULL, NULL, dcGetc, dcPutc, dcPollc, NODEV, CN_REMOTE -}; - -/* - * Special-case code to attach a console. - * We were using PROM callbacks for console I/O, - * and we just reset the chip under the console. - * wire up this driver as console ASAP. - * - * Must be called at spltty() or higher. - */ -void -dc_consinit(dev, dcaddr) - dev_t dev; - register dcregs *dcaddr; -{ - struct termios cterm; - struct tty ctty; - - /* save address in case we're cold */ - if (cold && dc_cons_addr == 0) - dc_cons_addr = dcaddr; - - /* reset chip */ - dc_reset(dcaddr); - - dcaddr->dc_lpr = LPR_RXENAB | LPR_8_BIT_CHAR | - LPR_B9600 | DCLINE(dev); - wbflush(); - DELAY(10); - - bzero(&cterm, sizeof(cterm)); - bzero(&ctty, sizeof(ctty)); - ctty.t_dev = dev; - dccons.cn_dev = dev; - cterm.c_cflag |= CLOCAL; - cterm.c_cflag = CS8; - cterm.c_ospeed = 9600; - *cn_tab = dccons; - cold_dcparam(&ctty, &cterm, dcaddr, 0); /* XXX untested */ -} - - -/* - * Attach DC7085 (dz-11) device. - */ -int -dcattach(sc, addr, dtr_mask, rtscts_mask, speed, - console_line) - register struct dc_softc *sc; - void *addr; - int dtr_mask, rtscts_mask, speed, console_line; -{ - register dcregs *dcaddr; - register struct pdma *pdp; - register struct tty *tp; - register int line; - int s; - - dcaddr = (dcregs *)addr; - - /* - * For a remote console, wait a while for previous output to - * complete. - * XXX both cn_dev == 0 and cn_pri == CN_DEAD are bug workarounds. - * The interface between ttys and cpu_cons.c should be reworked. - */ - if (sc->sc_dv.dv_unit == 0 && /* XXX why only unit 0? */ - (major(cn_tab->cn_dev) == DCDEV || major(cn_tab->cn_dev) == 0) && - (cn_tab->cn_pri == CN_REMOTE || (cn_tab->cn_pri == CN_DEAD))) { - DELAY(10000); - } - /* reset chip and enable interrupts */ - dc_reset(dcaddr); - dcaddr->dc_csr |= (CSR_MSE | CSR_TIE | CSR_RIE); - - /* init pseudo DMA structures */ - pdp = &sc->dc_pdma[0]; - for (line = 0; line < 4; line++) { - pdp->p_addr = (void *)dcaddr; - tp = sc->dc_tty[line] = ttymalloc(); - if (line != DCKBD_PORT && line != DCMOUSE_PORT) - tty_attach(tp); - tp->t_dev = makedev(DCDEV, 4 * sc->sc_dv.dv_unit + line); - pdp->p_arg = (int) tp; - pdp->p_fcn = dcxint; - pdp++; - } - sc->dcsoftCAR = sc->sc_dv.dv_cfdata->cf_flags | 0xB; - - if (dc_timer == 0) { - dc_timer = 1; - timeout(dcscan, (void *)0, hz); - } - - sc->dc_19200 = speed; - sc->dc_modem = dtr_mask; - sc->dc_rtscts = rtscts_mask; - - - /* - * Special handling for consoles. - */ - if (sc->sc_dv.dv_unit == 0) { - if (raster_console()) { - s = spltty(); - dcaddr->dc_lpr = LPR_RXENAB | LPR_8_BIT_CHAR | - LPR_B4800 | DCKBD_PORT; - wbflush(); - dcaddr->dc_lpr = LPR_RXENAB | LPR_B4800 | LPR_OPAR | - LPR_PARENB | LPR_8_BIT_CHAR | DCMOUSE_PORT; - wbflush(); - DELAY(1000); - KBDReset(makedev(DCDEV, DCKBD_PORT), dcPutc); - MouseInit(makedev(DCDEV, DCMOUSE_PORT), dcPutc, dcGetc); - splx(s); - } - else if (major(cn_tab->cn_dev) == DCDEV) { - s = spltty(); - dc_consinit(cn_tab->cn_dev, dcaddr); - dcaddr->dc_csr |= (CSR_MSE | CSR_TIE | CSR_RIE); - splx(s); - } - } - return (1); -} - - -/* - * Reset chip. Does not change modem control output bits - * or modem state register. - * Does not enable interrupts; caller must explicitly or - * TIE and RIE on if desired (XXX not true yet) - */ -void -dc_reset(dcaddr) - register dcregs *dcaddr; -{ - /* Reset CSR and wait until cleared. */ - dcaddr->dc_csr = CSR_CLR; - wbflush(); - DELAY(10); - while (dcaddr->dc_csr & CSR_CLR) - ; - - /* Enable scanner. */ - dcaddr->dc_csr = CSR_MSE; - wbflush(); - DELAY(10); -} - - -int -dcopen(dev, flag, mode, p) - dev_t dev; - int flag, mode; - struct proc *p; -{ - register struct tty *tp; - register struct dc_softc *sc; - register int unit, line; - int s, error = 0; - - unit = DCUNIT(dev); - line = DCLINE(dev); - if (unit >= dz_cd.cd_ndevs || line > 4) - return (ENXIO); - - sc = dz_cd.cd_devs[unit]; - if (sc->dc_pdma[line].p_addr == (void *)0) - return (ENXIO); - - tp = sc->dc_tty[line]; - if (tp == NULL) { - tp = sc->dc_tty[line] = ttymalloc(); - tty_attach(tp); - } - tp->t_oproc = dcstart; - tp->t_param = dcparam; - tp->t_dev = dev; - if ((tp->t_state & TS_ISOPEN) == 0) { - tp->t_state |= TS_WOPEN; - ttychars(tp); -#ifndef PORTSELECTOR - if (tp->t_ispeed == 0) { -#endif - tp->t_iflag = TTYDEF_IFLAG; - tp->t_oflag = TTYDEF_OFLAG; - tp->t_cflag = TTYDEF_CFLAG; - tp->t_lflag = LFLAG; - tp->t_ispeed = tp->t_ospeed = ISPEED; -#ifdef PORTSELECTOR - tp->t_cflag |= HUPCL; -#else - } -#endif - (void) dcparam(tp, &tp->t_termios); - ttsetwater(tp); - } else if ((tp->t_state & TS_XCLUDE) && curproc->p_ucred->cr_uid != 0) - return (EBUSY); -#ifdef HW_FLOW_CONTROL - (void) dcmctl(dev, DML_DTR | DML_RTS, DMSET); -#else - (void) dcmctl(dev, DML_DTR, DMSET); -#endif - if ((sc->dcsoftCAR & (1 << line)) || - (dcmctl(dev, 0, DMGET) & DML_CAR)) - tp->t_state |= TS_CARR_ON; - s = spltty(); - while (!(flag & O_NONBLOCK) && !(tp->t_cflag & CLOCAL) && - !(tp->t_state & TS_CARR_ON)) { - tp->t_state |= TS_WOPEN; - if ((error = ttysleep(tp, (caddr_t)&tp->t_rawq, - TTIPRI | PCATCH, ttopen, 0)) != 0) - break; - } - splx(s); - if (error) - return (error); - return ((*linesw[tp->t_line].l_open)(dev, tp)); -} - -/*ARGSUSED*/ -int -dcclose(dev, flag, mode, p) - dev_t dev; - int flag, mode; - struct proc *p; -{ - register struct dc_softc *sc; - register struct tty *tp; - register int line, bit; - int s; - - sc = dz_cd.cd_devs[DCUNIT(dev)]; - line = DCLINE(dev); - tp = sc->dc_tty[line]; - bit = 1 << (line + 8); - s = spltty(); - /* turn off the break bit if it is set */ - if (sc->dc_brk & bit) { - sc->dc_brk &= ~bit; - ttyoutput(0, tp); - } - splx(s); - (*linesw[tp->t_line].l_close)(tp, flag); - if ((tp->t_cflag & HUPCL) || (tp->t_state & TS_WOPEN) || - !(tp->t_state & TS_ISOPEN)) - (void) dcmctl(dev, 0, DMSET); - return (ttyclose(tp)); -} - -int -dcread(dev, uio, flag) - dev_t dev; - struct uio *uio; -{ - register struct dc_softc *sc; - register struct tty *tp; - - sc = dz_cd.cd_devs[DCUNIT(dev)]; - tp = sc->dc_tty[DCLINE(dev)]; - -#ifdef HW_FLOW_CONTROL - if ((tp->t_cflag & CRTS_IFLOW) && (tp->t_state & TS_TBLOCK) && - tp->t_rawq.c_cc < TTYHOG/5) { - tp->t_state &= ~TS_TBLOCK; - (void) dcmctl(dev, DML_RTS, DMBIS); - } -#endif /* HW_FLOW_CONTROL */ - - return ((*linesw[tp->t_line].l_read)(tp, uio, flag)); -} - -int -dcwrite(dev, uio, flag) - dev_t dev; - struct uio *uio; -{ - register struct dc_softc *sc; - register struct tty *tp; - - sc = dz_cd.cd_devs[DCUNIT(dev)]; - tp = sc->dc_tty[DCLINE(dev)]; - return ((*linesw[tp->t_line].l_write)(tp, uio, flag)); -} - -struct tty * -dctty(dev) - dev_t dev; -{ - register struct dc_softc *sc; - register struct tty *tp; - - sc = dz_cd.cd_devs[DCUNIT(dev)]; - tp = sc->dc_tty[DCLINE(dev)]; - return (tp); -} - -/*ARGSUSED*/ -int -dcioctl(dev, cmd, data, flag, p) - dev_t dev; - u_long cmd; - caddr_t data; - int flag; - struct proc *p; -{ - register struct dc_softc *sc; - register struct tty *tp; - register int unit; - register int line; - int error; - - - unit = DCUNIT(dev); - line = DCLINE(dev); - sc = dz_cd.cd_devs[unit]; - tp = sc->dc_tty[line]; - - error = (*linesw[tp->t_line].l_ioctl)(tp, cmd, data, flag, p); - if (error >= 0) - return (error); - error = ttioctl(tp, cmd, data, flag, p); - if (error >= 0) - return (error); - - switch (cmd) { - - case TIOCSBRK: - sc->dc_brk |= 1 << (line + 8); - ttyoutput(0, tp); - break; - - case TIOCCBRK: - sc->dc_brk &= ~(1 << (line + 8)); - ttyoutput(0, tp); - break; - - case TIOCSDTR: - (void) dcmctl(dev, DML_DTR|DML_RTS, DMBIS); - break; - - case TIOCCDTR: - (void) dcmctl(dev, DML_DTR|DML_RTS, DMBIC); - break; - - case TIOCMSET: - (void) dcmctl(dev, *(int *)data, DMSET); - break; - - case TIOCMBIS: - (void) dcmctl(dev, *(int *)data, DMBIS); - break; - - case TIOCMBIC: - (void) dcmctl(dev, *(int *)data, DMBIC); - break; - - case TIOCMGET: - *(int *)data = dcmctl(dev, 0, DMGET); - break; - - default: - return (ENOTTY); - } - return (0); -} - -/* - * Set line parameters - */ - -int -dcparam(tp, t) - register struct tty *tp; - register struct termios *t; -{ - register struct dc_softc *sc; - register dcregs *dcaddr; - - - /* - * Extract softc data, and pass entire request onto - * cold_dcparam() for argument checking and execution. - */ - sc = dz_cd.cd_devs[DCUNIT(tp->t_dev)]; - dcaddr = (dcregs *)sc->dc_pdma[0].p_addr; - return (cold_dcparam(tp, t, dcaddr, sc->dc_19200)); - -} - -int -cold_dcparam(tp, t, dcaddr, allow_19200) - register struct tty *tp; - register struct termios *t; - register dcregs *dcaddr; - int allow_19200; -{ - register int lpr; - register int cflag = t->c_cflag; - int unit = minor(tp->t_dev); - int ospeed = ttspeedtab(t->c_ospeed, dcspeedtab); - int s; - int line; - - line = DCLINE(tp->t_dev); - - /* check requested parameters */ - if (ospeed < 0 || (t->c_ispeed && t->c_ispeed != t->c_ospeed) || - (cflag & CSIZE) == CS5 || (cflag & CSIZE) == CS6 || - (t->c_ospeed >= 19200 && allow_19200 != 1)) - return (EINVAL); - /* and copy to tty */ - tp->t_ispeed = t->c_ispeed; - tp->t_ospeed = t->c_ospeed; - tp->t_cflag = cflag; - - /* - * Handle console cases specially. - */ - if (raster_console()) { - if (unit == DCKBD_PORT) { - lpr = LPR_RXENAB | LPR_8_BIT_CHAR | - LPR_B4800 | DCKBD_PORT; - goto out; - } else if (unit == DCMOUSE_PORT) { - lpr = LPR_RXENAB | LPR_B4800 | LPR_OPAR | - LPR_PARENB | LPR_8_BIT_CHAR | DCMOUSE_PORT; - goto out; - } - } else if (tp->t_dev == cn_tab->cn_dev) { - lpr = LPR_RXENAB | LPR_8_BIT_CHAR | LPR_B9600 | line; - goto out; - } - if (ospeed == 0) { - (void) dcmctl(unit, 0, DMSET); /* hang up line */ - return (0); - } - lpr = LPR_RXENAB | ospeed | line; - if ((cflag & CSIZE) == CS7) - lpr |= LPR_7_BIT_CHAR; - else - lpr |= LPR_8_BIT_CHAR; - if (cflag & PARENB) - lpr |= LPR_PARENB; - if (cflag & PARODD) - lpr |= LPR_OPAR; - if (cflag & CSTOPB) - lpr |= LPR_2_STOP; -out: - s = spltty(); - dcaddr->dc_lpr = lpr; - wbflush(); - splx(s); - DELAY(10); - return (0); -} - - -/* - * Check for interrupts from all devices. - */ -int -dcintr(xxxunit) - void *xxxunit; -{ - register struct dc_softc *sc = xxxunit; - register dcregs *dcaddr; - register unsigned csr; - - dcaddr = (dcregs *)sc->dc_pdma[0].p_addr; - while ((csr = dcaddr->dc_csr) & (CSR_RDONE | CSR_TRDY)) { - if (csr & CSR_RDONE) - dcrint(sc); - if (csr & CSR_TRDY) - dcxint(sc->dc_tty[((csr >> 8) & 03)]); - } - /* XXX check for spurious interrupts */ - return 0; -} - -void -dcrint(sc) - register struct dc_softc * sc; -{ - register dcregs *dcaddr; - register struct tty *tp; - register int c, cc; - int overrun = 0; - register struct tty **dc_tty; - - dc_tty = ((struct dc_softc*)dz_cd.cd_devs[0])->dc_tty; /* XXX */ - - dcaddr = (dcregs *)sc->dc_pdma[0].p_addr; /*XXX*/ - while ((c = dcaddr->dc_rbuf) < 0) { /* char present */ - cc = c & 0xff; - tp = sc->dc_tty[((c >> 8) & 03)]; - - if ((c & RBUF_OERR) && overrun == 0) { - log(LOG_WARNING, "%s,%d: silo overflow\n", - sc->sc_dv.dv_xname, - (c >> 8) & 03); - overrun = 1; - } - /* the keyboard requires special translation */ - if (raster_console() && tp == dc_tty[DCKBD_PORT]) { -#ifdef KADB - if (cc == LK_DO) { - spl0(); - kdbpanic(); - return; - } -#endif -#ifdef DEBUG - debugChar = cc; -#endif - if (dcDivertXInput) { - (*dcDivertXInput)(cc); - return; - } - if ((cc = kbdMapChar(cc)) < 0) - return; - } else if (tp == dc_tty[DCMOUSE_PORT] && dcMouseButtons) { - mouseInput(cc); - return; - } - if (!(tp->t_state & TS_ISOPEN)) { - wakeup((caddr_t)&tp->t_rawq); -#ifdef PORTSELECTOR - if (!(tp->t_state & TS_WOPEN)) -#endif - return; - } - if (c & RBUF_FERR) - cc |= TTY_FE; - if (c & RBUF_PERR) - cc |= TTY_PE; -#ifdef HW_FLOW_CONTROL - if ((tp->t_cflag & CRTS_IFLOW) && !(tp->t_state & TS_TBLOCK) && - tp->t_rawq.c_cc + tp->t_canq.c_cc >= TTYHOG) { - tp->t_state &= ~TS_TBLOCK; - (void) dcmctl(tp->t_dev, DML_RTS, DMBIC); - } -#endif /* HWW_FLOW_CONTROL */ - (*linesw[tp->t_line].l_rint)(cc, tp); - } - DELAY(10); -} - -void -dcxint(tp) - register struct tty *tp; -{ - register struct dc_softc *sc; - register struct pdma *dp; - register dcregs *dcaddr; - int line, linemask; - - sc = dz_cd.cd_devs[DCUNIT(tp->t_dev)]; /* XXX */ - - line = DCLINE(tp->t_dev); - linemask = 1 << line; - - dp = &sc->dc_pdma[line]; - if (dp->p_mem < dp->p_end) { - dcaddr = (dcregs *)dp->p_addr; - -#ifdef HW_FLOW_CONTROL - /* check for hardware flow control of output */ - if ((tp->t_cflag & CCTS_OFLOW) && (sc->dc_rtscts & linemask)) { - switch (line) { - case 2: - if (dcaddr->dc_msr & MSR_CTS2) - break; - goto stop; - - case 3: - if (dcaddr->dc_msr & MSR_CTS3) - break; - stop: - tp->t_state &= ~TS_BUSY; - tp->t_state |= TS_TTSTOP; - ndflush(&tp->t_outq, dp->p_mem - - (caddr_t)tp->t_outq.c_cf); - dp->p_end = dp->p_mem = tp->t_outq.c_cf; - dcaddr->dc_tcr &= ~(1 << line); - wbflush(); - DELAY(10); - return; - } - } -#endif /* HW_FLOW_CONTROL */ - dcaddr->dc_tdr = sc->dc_brk | *(u_char *)dp->p_mem; - dp->p_mem++; - - wbflush(); - DELAY(10); - return; - } - tp->t_state &= ~TS_BUSY; - if (tp->t_state & TS_FLUSH) - tp->t_state &= ~TS_FLUSH; - else { - ndflush(&tp->t_outq, dp->p_mem - (caddr_t) tp->t_outq.c_cf); - dp->p_end = dp->p_mem = tp->t_outq.c_cf; - } - if (tp->t_line) - (*linesw[tp->t_line].l_start)(tp); - else - dcstart(tp); - if (tp->t_outq.c_cc == 0 || !(tp->t_state & TS_BUSY)) { - dcaddr = (dcregs *)dp->p_addr; - dcaddr->dc_tcr &= ~(1 << line); - wbflush(); - DELAY(10); - } -} - -void -dcstart(tp) - register struct tty *tp; -{ - register struct dc_softc *sc; - register struct pdma *dp; - register dcregs *dcaddr; - register int cc; - int line, s; - - sc = dz_cd.cd_devs[DCUNIT(tp->t_dev)]; - line = DCLINE(tp->t_dev); - dp = &sc->dc_pdma[line]; - dcaddr = (dcregs *)dp->p_addr; - s = spltty(); - if (tp->t_state & (TS_TIMEOUT|TS_BUSY|TS_TTSTOP)) - goto out; - if (tp->t_outq.c_cc <= tp->t_lowat) { - if (tp->t_state & TS_ASLEEP) { - tp->t_state &= ~TS_ASLEEP; - wakeup((caddr_t)&tp->t_outq); - } - selwakeup(&tp->t_wsel); - } - if (tp->t_outq.c_cc == 0) - goto out; - /* handle console specially */ - if (raster_console() && tp == sc->dc_tty[DCKBD_PORT]) { - while (tp->t_outq.c_cc > 0) { - cc = getc(&tp->t_outq) & 0x7f; - cnputc(cc); - } - /* - * After we flush the output queue we may need to wake - * up the process that made the output. - */ - if (tp->t_outq.c_cc <= tp->t_lowat) { - if (tp->t_state & TS_ASLEEP) { - tp->t_state &= ~TS_ASLEEP; - wakeup((caddr_t)&tp->t_outq); - } - selwakeup(&tp->t_wsel); - } - goto out; - } - cc = ndqb(&tp->t_outq, 0); - if (cc == 0) - goto out; - tp->t_state |= TS_BUSY; - dp->p_end = dp->p_mem = tp->t_outq.c_cf; - dp->p_end += cc; - dcaddr->dc_tcr |= 1 << line; - wbflush(); -out: - splx(s); -} - -/* - * Stop output on a line. - */ -/*ARGSUSED*/ -int /* was void TTTTT */ -dcstop(tp, flag) - register struct tty *tp; -{ - register struct dc_softc *sc; - register struct pdma *dp; - register int s; - - sc = dz_cd.cd_devs[DCUNIT(tp->t_dev)]; - dp = &sc->dc_pdma[DCLINE(tp->t_dev)]; - s = spltty(); - if (tp->t_state & TS_BUSY) { - dp->p_end = dp->p_mem; - if (!(tp->t_state & TS_TTSTOP)) - tp->t_state |= TS_FLUSH; - } - splx(s); -} - -int -dcmctl(dev, bits, how) - dev_t dev; - int bits, how; -{ - register struct dc_softc *sc; - register dcregs *dcaddr; - register int line, mbits; - int b, s; - register int tcr, msr; - - line = DCLINE(dev); - sc = dz_cd.cd_devs[DCUNIT(dev)]; - b = 1 << line; - dcaddr = (dcregs *)sc->dc_pdma[line].p_addr; - s = spltty(); - /* only channel 2 has modem control on a DECstation 2100/3100 */ - mbits = DML_DTR | DML_DSR | DML_CAR; -#ifdef HW_FLOW_CONTROL - mbits != DML_RTS; -#endif /* HW_FLOW_CONTROL */ - switch (line) { - case 2: /* pmax partial-modem comms port, full-modem port on 3max */ - mbits = 0; - tcr = dcaddr->dc_tcr; - if (tcr & TCR_DTR2) - mbits |= DML_DTR; - if ((sc->dc_rtscts & (1<<line)) && (tcr & TCR_RTS2)) - mbits |= DML_RTS; - msr = dcaddr->dc_msr; - if (msr & MSR_CD2) - mbits |= DML_CAR; - if (msr & MSR_DSR2) { - /* - * XXX really tests for DS_PMAX instead of DS_3MAX - * but close enough for now. Vaxes? - */ - if ((sc->dc_rtscts & (1 << line )) == 0 && - (sc->dc_modem & (1 << line ))) - mbits |= DML_CAR | DML_DSR; - else - mbits |= DML_DSR; - } - break; - - case 3: /* no modem control on pmax, console port on 3max */ - /* - * XXX really tests for DS_3MAX instead of DS_PMAX - * but close enough for now. Vaxes? - */ - if ( sc->dc_modem & (1 << line )) { - mbits = 0; - tcr = dcaddr->dc_tcr; - if (tcr & TCR_DTR3) - mbits |= DML_DTR; -#ifdef HW_FLOW_CONTROL - /* XXX OK for get, but not for set? */ - /*if ( sc->dc_rtscts & (1 << line ))*/ - if (tcr & TCR_RTS3) - mbits |= DML_RTS; -#endif /*HW_FLOW_CONTROL*/ - msr = dcaddr->dc_msr; - if (msr & MSR_CD3) - mbits |= DML_CAR; - if (msr & MSR_DSR3) - mbits |= DML_DSR; - } - } - switch (how) { - case DMSET: - mbits = bits; - break; - - case DMBIS: - mbits |= bits; - break; - - case DMBIC: - mbits &= ~bits; - break; - - case DMGET: - (void) splx(s); - return (mbits); - } - switch (line) { - case 2: /* 2 */ - tcr = dcaddr->dc_tcr; - if (mbits & DML_DTR) - tcr |= TCR_DTR2; - else - tcr &= ~TCR_DTR2; - /*if (pmax_boardtype != DS_PMAX)*/ - if (sc->dc_rtscts & (1 << line)) { - if (mbits & DML_RTS) - tcr |= TCR_RTS2; - else - tcr &= ~TCR_RTS2; - } - dcaddr->dc_tcr = tcr; - break; - - case 3: - /* XXX DTR not supported on this line on 2100/3100 */ - /*if (pmax_boardtype != DS_PMAX)*/ - if (sc->dc_modem & (1 << line)) { - tcr = dcaddr->dc_tcr; - if (mbits & DML_DTR) - tcr |= TCR_DTR3; - else - tcr &= ~TCR_DTR3; -#ifdef HW_FLOW_CONTROL - /*if (sc->dc_rtscts & (1 << line))*/ - if (mbits & DML_RTS) - tcr |= TCR_RTS3; - else - tcr &= ~TCR_RTS3; -#endif /* HW_FLOW_CONTROL */ - dcaddr->dc_tcr = tcr; - } - } - (void) splx(s); - return (mbits); -} - -/* - * This is called by timeout() periodically. - * Check to see if modem status bits have changed. - */ -void -dcscan(arg) - void *arg; -{ - register struct dc_softc *sc = dz_cd.cd_devs[0]; /* XXX */ - register dcregs *dcaddr; - register struct tty *tp; - register int unit, limit, dtr, dsr; - int s; - - /* only channel 2 has modem control on a DECstation 2100/3100 */ - dtr = TCR_DTR2; - dsr = MSR_DSR2; -#ifdef HW_FLOW_CONTROL - /*limit = (pmax_boardtype == DS_PMAX) ? 2 : 3;*/ - limit = (sc->dc_rtscts & (1 << 3)) ? 3 : 2; /*XXX*/ -#else - limit = 2; -#endif - s = spltty(); - for (unit = 2; unit <= limit; unit++, dtr >>= 2, dsr >>= 8) { - tp = sc->dc_tty[unit]; - dcaddr = (dcregs *)sc->dc_pdma[unit].p_addr; - if ((dcaddr->dc_msr & dsr) || (sc->dcsoftCAR & (1 << unit))) { - /* carrier present */ - if (!(tp->t_state & TS_CARR_ON)) - (void)(*linesw[tp->t_line].l_modem)(tp, 1); - } else if ((tp->t_state & TS_CARR_ON) && - (*linesw[tp->t_line].l_modem)(tp, 0) == 0) - dcaddr->dc_tcr &= ~dtr; -#ifdef HW_FLOW_CONTROL - /* - * If we are using hardware flow control and output is stopped, - * then resume transmit. - */ - if ((tp->t_cflag & CCTS_OFLOW) && (tp->t_state & TS_TTSTOP) && - /*pmax_boardtype != DS_PMAX*/ - (sc->dc_rtscts & (1 << unit)) ) { - switch (unit) { - case 2: - if (dcaddr->dc_msr & MSR_CTS2) - break; - continue; - - case 3: - if (dcaddr->dc_msr & MSR_CTS3) - break; - continue; - } - tp->t_state &= ~TS_TTSTOP; - dcstart(tp); - } -#endif /* HW_FLOW_CONTROL */ - } - splx(s); - timeout(dcscan, (void *)0, hz); -} - -/* - * ---------------------------------------------------------------------------- - * - * dcGetc -- - * - * Read a character from a serial line. - * - * Results: - * A character read from the serial port. - * - * Side effects: - * None. - * - * ---------------------------------------------------------------------------- - */ -int -dcGetc(dev) - dev_t dev; -{ - register dcregs *dcaddr; - register int c; - register int line; - int s; - - line = DCLINE(dev); - if (cold && dc_cons_addr) { - dcaddr = dc_cons_addr; - } else { - struct dc_softc *sc; - sc = dz_cd.cd_devs[DCUNIT(dev)]; - dcaddr = (dcregs *)sc->dc_pdma[line].p_addr; - } - if (!dcaddr) - return (0); - s = spltty(); - for (;;) { - if (!(dcaddr->dc_csr & CSR_RDONE)) - continue; - c = dcaddr->dc_rbuf; - DELAY(10); - if (((c >> 8) & 03) == line) - break; - } - splx(s); - return (c & 0xff); -} - -/* - * Send a char on a port, non interrupt driven. - */ -void -dcPutc(dev, c) - dev_t dev; - int c; -{ - register dcregs *dcaddr; - register u_short tcr; - register int timeout; - int s, out_line, activeline; - int brk; - - s = spltty(); - out_line = DCLINE(dev); - if (cold && dc_cons_addr) { - brk = 0; - dcaddr = dc_cons_addr; - } else { - struct dc_softc *sc; - - sc = dz_cd.cd_devs[DCUNIT(dev)]; - dcaddr = (dcregs *)sc->dc_pdma[out_line].p_addr; - brk = sc->dc_brk; - } - tcr = dcaddr->dc_tcr; - dcaddr->dc_tcr = tcr | (1 << out_line); - wbflush(); - DELAY(10); - while (1) { - /* - * Wait for transmitter to be not busy. - */ - timeout = 1000000; - while (!(dcaddr->dc_csr & CSR_TRDY) && timeout > 0) - timeout--; - if (timeout == 0) { - printf("dcPutc: timeout waiting for CSR_TRDY\n"); - break; - } - activeline = (dcaddr->dc_csr >> 8) & 3; - /* - * Check to be sure its the right port. - */ - if (activeline != out_line) { - tcr |= 1 << activeline; - dcaddr->dc_tcr &= ~(1 << out_line); - wbflush(); - DELAY(10); - continue; - } - /* - * Start sending the character. - */ - dcaddr->dc_tdr = brk | (c & 0xff); - wbflush(); - DELAY(10); - /* - * Wait for character to be sent. - */ - while (1) { - /* - * cc -O bug: this code produces and infinite loop! - * while (!(dcaddr->dc_csr & CSR_TRDY)) - * ; - */ - timeout = 1000000; - while (!(dcaddr->dc_csr & CSR_TRDY) && timeout > 0) - timeout--; - activeline = (dcaddr->dc_csr >> 8) & 3; - if (activeline != out_line) { - tcr |= 1 << activeline; - dcaddr->dc_tcr &= ~(1 << activeline); - wbflush(); - DELAY(10); - continue; - } - dcaddr->dc_tcr &= ~(1 << out_line); - wbflush(); - DELAY(10); - break; - } - break; - } - /* - * Enable interrupts for other lines which became ready. - */ - if (tcr & 0xF) { - dcaddr->dc_tcr = tcr; - wbflush(); - DELAY(10); - } - - splx(s); -} - - -/* - * Enable/disable polling mode - */ -void -dcPollc(dev, on) - dev_t dev; - int on; -{ -#if defined(DIAGNOSTIC) || defined(DEBUG) - printf("dc_Pollc(%d, %d): not implemented\n", minor(dev), on); -#endif -} - diff --git a/sys/arch/pmax/dev/dc_cons.h b/sys/arch/pmax/dev/dc_cons.h deleted file mode 100644 index 8110a2a2629..00000000000 --- a/sys/arch/pmax/dev/dc_cons.h +++ /dev/null @@ -1,17 +0,0 @@ -/* $NetBSD: dc_cons.h,v 1.1 1996/10/13 03:42:17 jonathan Exp $ */ - -#ifdef _KERNEL -#ifndef _DC_CONS_H -#define _DC_CONS_H - -/* - * Following declaratios for console code. - * XXX should be redesigned to expose less driver internals. - */ -void dc_consinit __P((dev_t dev, dcregs *dcaddr)); -extern int dcGetc __P ((dev_t dev)); -extern int dcparam __P((register struct tty *tp, register struct termios *t)); -extern void dcPutc __P((dev_t dev, int c)); - -#endif /* _DCVAR_H */ -#endif /* _KERNEL */ diff --git a/sys/arch/pmax/dev/dc_ds.c b/sys/arch/pmax/dev/dc_ds.c deleted file mode 100644 index c99d9c8a8a8..00000000000 --- a/sys/arch/pmax/dev/dc_ds.c +++ /dev/null @@ -1,106 +0,0 @@ -/* $NetBSD: dc_ds.c,v 1.4 1996/10/14 17:28:46 jonathan Exp $ */ - -/* - * Copyright 1996 The Board of Trustees of The Leland Stanford - * Junior University. All Rights Reserved. - * - * Permission to use, copy, modify, and distribute this - * software and its documentation for any purpose and without - * fee is hereby granted, provided that the above copyright - * notice appear in all copies. Stanford University - * makes no representations about the suitability of this - * software for any purpose. It is provided "as is" without - * express or implied warranty. - * - * this driver contributed by Jonathan Stone - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/types.h> -#include <sys/device.h> -#include <sys/tty.h> -#include <machine/autoconf.h> -#include <machine/dc7085cons.h> /* XXX */ -#include <pmax/dev/dcvar.h> -#include <pmax/dev/dc_ds_cons.h> -#include <pmax/pmax/kn01.h> - -extern struct cfdriver mainbus_cd; /* XXX */ - -/* - * Autoconfig definition of driver front-end - */ -int dc_ds_match __P((struct device * parent, void *cfdata, void *aux)); -void dc_ds_attach __P((struct device *parent, struct device *self, void *aux)); - -struct cfattach dz_ds_ca = { - sizeof(struct dc_softc), dc_ds_match, dc_ds_attach -}; - - -/* - * Initialize a line for (polled) console I/O - */ -int -dc_ds_consinit(dev) - dev_t dev; -{ -#if defined(DEBUG) && 1 /* XXX untested */ - printf("dc_ds(%d,%d): serial console at 0x%x\n", - minor(dev) >> 2, minor(dev) & 03, - MIPS_PHYS_TO_KSEG1(KN01_SYS_DZ)); -#endif - /* let any pending PROM output from boot drain */ - DELAY(100000); - dc_consinit(dev, (void *)MIPS_PHYS_TO_KSEG1(KN01_SYS_DZ)); - return (1); -} - - -/* - * Match driver on decstation (2100,3100,5100) based on name - */ -int -dc_ds_match(parent, match, aux) - struct device *parent; - void *match; - void *aux; -{ - struct confargs *ca = aux; - - if (strcmp(ca->ca_name, "dc") != 0 && - strcmp(ca->ca_name, "mdc") != 0 && - strcmp(ca->ca_name, "dc7085") != 0) - return (0); - - if (badaddr((caddr_t)ca->ca_addr, 2)) - return (0); - - return (1); -} - - -void -dc_ds_attach(parent, self, aux) - struct device *parent; - struct device *self; - void *aux; -{ - register struct confargs *ca = aux; - caddr_t dcaddr; - struct dc_softc *sc = (void*) self; - - - dcaddr = (caddr_t)ca->ca_addr; - (void) dcattach(sc, (void*)MIPS_PHYS_TO_KSEG1(dcaddr), - /* dtr/dsr mask: comm port only */ - 1 << DCCOMM_PORT, - /* rts/cts mask: none */ - 0x0, - 0, DCCOMM_PORT); - - /* tie pseudo-slot to device */ - BUS_INTR_ESTABLISH(ca, dcintr, self); - printf("\n"); -} diff --git a/sys/arch/pmax/dev/dc_ds_cons.h b/sys/arch/pmax/dev/dc_ds_cons.h deleted file mode 100644 index 6b19ba04b89..00000000000 --- a/sys/arch/pmax/dev/dc_ds_cons.h +++ /dev/null @@ -1,14 +0,0 @@ -/* $NetBSD: dc_ds_cons.h,v 1.1 1996/09/25 20:48:55 jonathan Exp $ */ - -#ifdef _KERNEL -#ifndef _DC_DS_CONS_H -#define _DC_DS_CONS_H - -/* - * Following declaratios for console code. - * XXX should be redesigned to expose less driver internals. - */ -int dc_ds_consinit __P((dev_t dev)); - -#endif /* _DC_DS_CONS_H */ -#endif /* _KERNEL */ diff --git a/sys/arch/pmax/dev/dc_ioasic.c b/sys/arch/pmax/dev/dc_ioasic.c deleted file mode 100644 index 55d1f14acc8..00000000000 --- a/sys/arch/pmax/dev/dc_ioasic.c +++ /dev/null @@ -1,109 +0,0 @@ -/* $NetBSD: dc_ioasic.c,v 1.4 1996/10/14 17:15:42 jonathan Exp $ */ - -/* - * Copyright 1996 The Board of Trustees of The Leland Stanford - * Junior University. All Rights Reserved. - * - * Permission to use, copy, modify, and distribute this - * software and its documentation for any purpose and without - * fee is hereby granted, provided that the above copyright - * notice appear in all copies. Stanford University - * makes no representations about the suitability of this - * software for any purpose. It is provided "as is" without - * express or implied warranty. - * - * this driver contributed by Jonathan Stone - */ - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/types.h> -#include <sys/device.h> -#include <sys/tty.h> -#include <machine/autoconf.h> -#include <dev/tc/tcvar.h> -#include <dev/tc/ioasicvar.h> -#include <machine/dc7085cons.h> -#include <pmax/dev/dcvar.h> -#include <pmax/dev/dc_ioasic_cons.h> -#include <pmax/pmax/kn02.h> -/* - * Autoconfig definition of driver front-end - */ -int dc_ioasic_match __P((struct device * parent, void *cfdata, void *aux)); -void dc_ioasic_attach __P((struct device *parent, struct device *self, void *aux)); - -struct cfattach dz_ioasic_ca = { - sizeof(struct dc_softc), dc_ioasic_match, dc_ioasic_attach -}; - - -/* - * Initialize a line for (polled) console I/O - */ -int -dc_ioasic_consinit(dev) - dev_t dev; -{ - -#if defined(DEBUG) && 0 - printf("dc_ioasic(%d,%d): serial console at 0x%x\n", - minor(dev) >> 2, minor(dev) & 03, - MIPS_PHYS_TO_KSEG1(KN02_SYS_DZ)); - DELAY(100000); -#endif - dc_consinit(dev, (void *)MIPS_PHYS_TO_KSEG1(KN02_SYS_DZ)); - return(1); -} - - -/* - * Match driver on 5000/200 - * (not a real ioasic, but we configure it as one) - */ -int -dc_ioasic_match(parent, match, aux) - struct device *parent; - void *match; - void *aux; -{ - struct ioasicdev_attach_args *d = aux; - - if (strcmp(d->iada_modname, "dc") != 0 && - strcmp(d->iada_modname, "dc7085") != 0) - return (0); - - if (badaddr((caddr_t)(d->iada_addr), 2)) - return (0); - - return (1); -} - - -void -dc_ioasic_attach(parent, self, aux) - struct device *parent; - struct device *self; - void *aux; -{ - struct dc_softc *sc = (void*) self; - struct ioasicdev_attach_args *d = aux; - caddr_t dcaddr; - - dcaddr = (caddr_t)d->iada_addr; - printf(" address %p", dcaddr); - (void) dcattach(sc, (void*)MIPS_PHYS_TO_KSEG1(dcaddr), - /* dtr/dsr mask */ (1<< DCPRINTER_PORT) + (1 << DCCOMM_PORT), -#ifdef HW_FLOW_CONTROL - /* rts/cts mask */ (1<< DCPRINTER_PORT) + (1 << DCCOMM_PORT), -#else - 0, -#endif - 1, 3); - /* tie pseudo-slot to device */ - ioasic_intr_establish(parent, d->iada_cookie, TC_IPL_TTY, - dcintr, self); - - printf("\n"); -} - diff --git a/sys/arch/pmax/dev/dc_ioasic_cons.h b/sys/arch/pmax/dev/dc_ioasic_cons.h deleted file mode 100644 index d3ebda1de28..00000000000 --- a/sys/arch/pmax/dev/dc_ioasic_cons.h +++ /dev/null @@ -1,14 +0,0 @@ -/* $NetBSD: dc_ioasic_cons.h,v 1.1 1996/09/25 20:48:56 jonathan Exp $ */ - -#ifdef _KERNEL -#ifndef _DC_IOASIC_CONS_H -#define _DC_IOASIC_CONS_H - -/* - * Following declaratios for console code. - * XXX should be redesigned to expose less driver internals. - */ -int dc_ioasic_consinit __P((dev_t dev)); - -#endif /* _DCVAR_H */ -#endif /* _KERNEL */ diff --git a/sys/arch/pmax/dev/dcvar.h b/sys/arch/pmax/dev/dcvar.h deleted file mode 100644 index 954b4c9ef7e..00000000000 --- a/sys/arch/pmax/dev/dcvar.h +++ /dev/null @@ -1,50 +0,0 @@ -/* $NetBSD: dcvar.h,v 1.4 1997/05/28 14:21:39 jonathan Exp $ */ - -/* - * External declarations from DECstation dc serial driver. - */ - -#ifdef _KERNEL -#ifndef _DCVAR_H -#define _DCVAR_H - -#include <pmax/dev/pdma.h> - -struct dc_softc { - struct device sc_dv; - struct pdma dc_pdma[4]; - struct tty *dc_tty[4]; - /* - * Software copy of brk register since it isn't readable - */ - int dc_brk; - - char dc_19200; /* this unit supports 19200 */ - char dcsoftCAR; /* mask, lines with carrier on (DSR) */ - char dc_rtscts; /* mask, lines with hw flow control */ - char dc_modem; /* mask, lines with DTR wired */ -}; - -int dcattach __P((struct dc_softc *sc, void *addr, - int dtrmask, int rts_ctsmask, - int speed, int consline)); -int dcintr __P((void * xxxunit)); - -/* - * Following declaratios for console code. - * XXX shuould be separated, or redesigned. - */ -extern int dcGetc __P ((dev_t dev)); -extern int dcparam __P((register struct tty *tp, register struct termios *t)); -extern void dcPutc __P((dev_t dev, int c)); - -struct dc7085regs; -void dc_consinit __P((dev_t dev, volatile struct dc7085regs *dcaddr)); - -/* QVSS-compatible in-kernel X input event parser, pointer tracker */ -void (*dcDivertXInput) __P((int cc)); /* X windows keyboard input routine */ -void (*dcMouseEvent) __P((int)); /* X windows mouse motion event routine */ -void (*dcMouseButtons) __P((int)); /* X windows mouse buttons event routine */ - -#endif /* _DCVAR_H */ -#endif /* _KERNEL */ |