diff options
Diffstat (limited to 'sys/arch/vax/qbus/dz.c')
-rw-r--r-- | sys/arch/vax/qbus/dz.c | 65 |
1 files changed, 28 insertions, 37 deletions
diff --git a/sys/arch/vax/qbus/dz.c b/sys/arch/vax/qbus/dz.c index 33c45d8e287..355e2cfe96b 100644 --- a/sys/arch/vax/qbus/dz.c +++ b/sys/arch/vax/qbus/dz.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dz.c,v 1.14 2006/08/05 16:58:47 miod Exp $ */ +/* $OpenBSD: dz.c,v 1.15 2008/08/15 22:50:25 miod Exp $ */ /* $NetBSD: dz.c,v 1.23 2000/06/04 02:14:12 matt Exp $ */ /* * Copyright (c) 1996 Ken C. Wellsch. All rights reserved. @@ -59,16 +59,6 @@ #include <arch/vax/qbus/dzreg.h> #include <arch/vax/qbus/dzvar.h> -#define DZ_READ_BYTE(adr) \ - bus_space_read_1(sc->sc_iot, sc->sc_ioh, sc->sc_dr.adr) -#define DZ_READ_WORD(adr) \ - bus_space_read_2(sc->sc_iot, sc->sc_ioh, sc->sc_dr.adr) -#define DZ_WRITE_BYTE(adr, val) \ - bus_space_write_1(sc->sc_iot, sc->sc_ioh, sc->sc_dr.adr, val) -#define DZ_WRITE_WORD(adr, val) \ - bus_space_write_2(sc->sc_iot, sc->sc_ioh, sc->sc_dr.adr, val) - - /* Flags used to monitor modem bits, make them understood outside driver */ #define DML_DTR TIOCM_DTR @@ -126,10 +116,10 @@ dzattach(struct dz_softc *sc) sc->sc_rxint = sc->sc_brk = 0; sc->sc_dr.dr_tcrw = sc->sc_dr.dr_tcr; - DZ_WRITE_WORD(dr_csr, DZ_CSR_MSE | DZ_CSR_RXIE | DZ_CSR_TXIE); + DZ_WRITE_WORD(sc, dr_csr, DZ_CSR_MSE | DZ_CSR_RXIE | DZ_CSR_TXIE); dzdrain(sc); - DZ_WRITE_BYTE(dr_dtr, 0); - DZ_WRITE_BYTE(dr_break, 0); + DZ_WRITE_BYTE(sc, dr_dtr, 0); + DZ_WRITE_BYTE(sc, dr_break, 0); /* Initialize our softc structure. Should be done in open? */ @@ -162,7 +152,7 @@ dzrint(void *arg) sc->sc_rxint++; - while ((c = DZ_READ_WORD(dr_rbuf)) & DZ_RBUF_DATA_VALID) { + while ((c = DZ_READ_WORD(sc, dr_rbuf)) & DZ_RBUF_DATA_VALID) { cc = c & 0xFF; line = DZ_PORT(c>>8); tp = sc->sc_dz[line].dz_tty; @@ -189,7 +179,7 @@ dzrint(void *arg) if (c & DZ_RBUF_PARITY_ERR) cc |= TTY_PE; -#if defined(DDB) && (defined(VAX410) || defined(VAX43) || defined(VAX46) || defined(VAX48) || defined(VAX49) || defined(VAX53)) +#if defined(DDB) && (defined(VAX410) || defined(VAX43) || defined(VAX46) || defined(VAX48) || defined(VAX49) || defined(VAX53) || defined(VAX60)) if (tp->t_dev == cn_tab->cn_dev) { int j = kdbrint(cc); @@ -200,6 +190,7 @@ dzrint(void *arg) (*linesw[tp->t_line].l_rint)(27, tp); } #endif + (*linesw[tp->t_line].l_rint)(cc, tp); } } @@ -233,7 +224,7 @@ dzxint(void *arg) * Remove the pdma stuff; no great need of it right now. */ - while (((csr = DZ_READ_WORD(dr_csr)) & DZ_CSR_TX_READY) != 0) { + while (((csr = DZ_READ_WORD(sc, dr_csr)) & DZ_CSR_TX_READY) != 0) { line = DZ_PORT(csr>>8); @@ -246,15 +237,15 @@ dzxint(void *arg) if (cl->c_cc) { tp->t_state |= TS_BUSY; ch = getc(cl); - DZ_WRITE_BYTE(dr_tbuf, ch); + DZ_WRITE_BYTE(sc, dr_tbuf, ch); continue; } /* Nothing to send; clear the scan bit */ /* Clear xmit scanner bit; dzstart may set it again */ - tcr = DZ_READ_WORD(dr_tcrw); + tcr = DZ_READ_WORD(sc, dr_tcrw); tcr &= 255; tcr &= ~(1 << line); - DZ_WRITE_BYTE(dr_tcr, tcr); + DZ_WRITE_BYTE(sc, dr_tcr, tcr); if (sc->sc_dz[line].dz_catch) continue; @@ -496,9 +487,9 @@ dzstart(struct tty *tp) tp->t_state |= TS_BUSY; - state = DZ_READ_WORD(dr_tcrw) & 255; + state = DZ_READ_WORD(sc, dr_tcrw) & 255; if ((state & (1 << line)) == 0) { - DZ_WRITE_BYTE(dr_tcr, state | (1 << line)); + DZ_WRITE_BYTE(sc, dr_tcr, state | (1 << line)); } dzxint(sc); splx(s); @@ -558,7 +549,7 @@ dzparam(struct tty *tp, struct termios *t) if (cflag & CSTOPB) lpr |= DZ_LPR_2_STOP; - DZ_WRITE_WORD(dr_lpr, lpr); + DZ_WRITE_WORD(sc, dr_lpr, lpr); splx(s); return (0); @@ -580,19 +571,19 @@ dzmctl(struct dz_softc *sc, int line, int bits, int how) /* external signals as seen from the port */ - status = DZ_READ_BYTE(dr_dcd) | sc->sc_dsr; + status = DZ_READ_BYTE(sc, dr_dcd) | sc->sc_dsr; if (status & bit) mbits |= DML_DCD; - status = DZ_READ_BYTE(dr_ring); + status = DZ_READ_BYTE(sc, dr_ring); if (status & bit) mbits |= DML_RI; /* internal signals/state delivered to port */ - status = DZ_READ_BYTE(dr_dtr); + status = DZ_READ_BYTE(sc, dr_dtr); if (status & bit) mbits |= DML_DTR; @@ -620,17 +611,17 @@ dzmctl(struct dz_softc *sc, int line, int bits, int how) } if (mbits & DML_DTR) { - DZ_WRITE_BYTE(dr_dtr, DZ_READ_BYTE(dr_dtr) | bit); + DZ_WRITE_BYTE(sc, dr_dtr, DZ_READ_BYTE(sc, dr_dtr) | bit); } else { - DZ_WRITE_BYTE(dr_dtr, DZ_READ_BYTE(dr_dtr) & ~bit); + DZ_WRITE_BYTE(sc, dr_dtr, DZ_READ_BYTE(sc, dr_dtr) & ~bit); } if (mbits & DML_BRK) { sc->sc_brk |= bit; - DZ_WRITE_BYTE(dr_break, sc->sc_brk); + DZ_WRITE_BYTE(sc, dr_break, sc->sc_brk); } else { sc->sc_brk &= ~bit; - DZ_WRITE_BYTE(dr_break, sc->sc_brk); + DZ_WRITE_BYTE(sc, dr_break, sc->sc_brk); } splx(s); @@ -664,13 +655,13 @@ dzscan(void *arg) tp = sc->sc_dz[port].dz_tty; bit = (1 << port); - if ((DZ_READ_BYTE(dr_dcd) | sc->sc_dsr) & bit) { + if ((DZ_READ_BYTE(sc, dr_dcd) | sc->sc_dsr) & bit) { if (!(tp->t_state & TS_CARR_ON)) (*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) { - DZ_WRITE_BYTE(dr_tcr, - (DZ_READ_WORD(dr_tcrw) & 255) & ~bit); + DZ_WRITE_BYTE(sc, dr_tcr, + (DZ_READ_WORD(sc, dr_tcrw) & 255) & ~bit); } } @@ -683,14 +674,14 @@ dzscan(void *arg) * if off unless the rate is appropriately low. */ - csr = DZ_READ_WORD(dr_csr); + csr = DZ_READ_WORD(sc, dr_csr); if (sc->sc_rxint > (16*10)) { if ((csr & DZ_CSR_SAE) == 0) - DZ_WRITE_WORD(dr_csr, csr | DZ_CSR_SAE); + DZ_WRITE_WORD(sc, dr_csr, csr | DZ_CSR_SAE); } else if ((csr & DZ_CSR_SAE) != 0) if (sc->sc_rxint < 10) - DZ_WRITE_WORD(dr_csr, csr & ~(DZ_CSR_SAE)); + DZ_WRITE_WORD(sc, dr_csr, csr & ~(DZ_CSR_SAE)); sc->sc_rxint = 0; } @@ -729,6 +720,6 @@ dzreset(struct device *dev) static void dzdrain(struct dz_softc *sc) { - while (DZ_READ_WORD(dr_rbuf) & DZ_RBUF_DATA_VALID) + while (DZ_READ_WORD(sc, dr_rbuf) & DZ_RBUF_DATA_VALID) /*EMPTY*/; } |