summaryrefslogtreecommitdiff
path: root/sys/arch/vax/qbus/dz.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/vax/qbus/dz.c')
-rw-r--r--sys/arch/vax/qbus/dz.c65
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*/;
}