diff options
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/ic/rl2subr.c | 121 |
1 files changed, 65 insertions, 56 deletions
diff --git a/sys/dev/ic/rl2subr.c b/sys/dev/ic/rl2subr.c index 38c5c43f5ee..468c4ff7e66 100644 --- a/sys/dev/ic/rl2subr.c +++ b/sys/dev/ic/rl2subr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rl2subr.c,v 1.2 1999/06/23 04:48:49 d Exp $ */ +/* $OpenBSD: rl2subr.c,v 1.3 1999/07/14 03:53:23 d Exp $ */ /* * David Leonard <d@openbsd.org>, 1999. Public Domain. * @@ -57,9 +57,9 @@ rl2_enable(sc, enable) was_enabled = (sc->sc_intsel & RL2_INTSEL_ENABLE) ? 1 : 0; if (enable != was_enabled) { if (enable) - sc->sc_intsel |= 0x10; + sc->sc_intsel |= RL2_INTSEL_ENABLE; else - sc->sc_intsel &=~0x10; + sc->sc_intsel &=~RL2_INTSEL_ENABLE; _rl2_register_write_1(sc, RL2_REG_INTSEL, sc->sc_intsel); } splx(s); @@ -174,12 +174,13 @@ rl2_wakeup(sc, wnew) int i; /* Save what the last-written values were. */ - wold = (sc->sc_status & 0x80) | (sc->sc_control & 0x10); + wold = (sc->sc_status & RL2_STATUS_WAKEUP) | + (sc->sc_control & RL2_CONTROL_RESET); if (wnew == RL2_WAKEUP_SET) { /* SetWakeupBit() */ dprintf(" Ws["); - rl2_status_set(sc, 0x80); + rl2_status_set(sc, RL2_STATUS_WAKEUP); if (0/*LLDInactivityTimeOut && (sc->sc_cardtype & RL2_CTYPE_OEM)*/) { dprintf (" 167ms"); @@ -189,21 +190,21 @@ rl2_wakeup(sc, wnew) DELAY(100); } s = rl2_status_read(sc); - rl2_control_set(sc, 0x10); - if ((s & 0x80) != 0) + rl2_control_set(sc, RL2_CONTROL_RESET); + if ((s & RL2_STATUS_WAKEUP) != 0) for (i = 0; i < 9; i++) { dprintf(" 2ms"); DELAY(2000); - rl2_status_set(sc, 0x80); + rl2_status_set(sc, RL2_STATUS_WAKEUP); } dprintf("]"); } else { /* ClearWakeupBit() */ dprintf(" Wc["); - if ((wnew & 0x80) == 0) - rl2_status_clear(sc, 0x80); - if ((wnew & 0x10) == 0) - rl2_control_clear(sc, 0x10); + if ((wnew & RL2_STATUS_WAKEUP) == 0) + rl2_status_clear(sc, RL2_STATUS_WAKEUP); + if ((wnew & RL2_CONTROL_RESET) == 0) + rl2_control_clear(sc, RL2_CONTROL_RESET); dprintf("]"); } return (wold); @@ -231,51 +232,53 @@ rl2_tx_request(sc, len) dprintf(" Tr["); if (sc->sc_width == 16) { - rl2_status_tx_write(sc, 0x01); + rl2_status_tx_write(sc, RL2_STATUS_TX_HILEN_AVAIL); rl2_data_write_2(sc, len); rl2_status_tx_int(sc); s = spl0(); for (i = 0; i < 600; i++) { status = rl2_status_tx_read(sc); - if (status == 0x02 || status == 0x05) + if (status == RL2_STATUS_TX_HILEN_ACCEPT || + status == RL2_STATUS_TX_ERROR) break; DELAY(1000); } splx(s); dprintf(" %dms", i); - if (status == 0x02) + if (status == RL2_STATUS_TX_HILEN_ACCEPT) goto success; - if (status == 0x05) + if (status == RL2_STATUS_TX_ERROR) goto error; } else if (sc->sc_width == 8) { - rl2_status_tx_write(sc, 0x06); - rl2_data_write_1(sc, len & 0x00ff); + rl2_status_tx_write(sc, RL2_STATUS_TX_LOLEN_AVAIL); + rl2_data_write_1(sc, len & 0xff); rl2_status_tx_int(sc); s = spl0(); for (i = 0; i < 6800; i++) { status = rl2_status_tx_read(sc); - if (status == 0x07) + if (status == RL2_STATUS_TX_LOLEN_ACCEPT) break; DELAY(1000); } splx(s); dprintf(" %dms", i); - if (status == 0x07) { - rl2_data_write_1(sc, (len & 0xff00) >> 8); - rl2_status_tx_write(sc, 0x01); + if (status == RL2_STATUS_TX_LOLEN_ACCEPT) { + rl2_data_write_1(sc, (len >> 8) & 0xff); + rl2_status_tx_write(sc, RL2_STATUS_TX_HILEN_AVAIL); s = spl0(); for (i = 0; i < 600; i++) { status = rl2_status_tx_read(sc); - if (status == 0x02 || status == 0x05) + if (status == RL2_STATUS_TX_HILEN_ACCEPT || + status == RL2_STATUS_TX_ERROR) break; DELAY(1000); } splx(s); dprintf(" %dms", i); - if (status == 0x02) + if (status == RL2_STATUS_TX_HILEN_ACCEPT) goto success; - if (status == 0x05) + if (status == RL2_STATUS_TX_ERROR) goto error; } } @@ -290,7 +293,7 @@ rl2_tx_request(sc, len) return (1); error: - /* XXX Will need to clear nak within 100 ms. */ + /* Will need to clear nak within 100 ms. */ dprintf("]=2"); #ifdef DIAGNOSTIC printf("%s: tx protocol fault (nak)\n", sc->sc_dev.dv_xname); @@ -322,19 +325,19 @@ rl2_tx_end(sc) s = spl0(); for (i = 0; i < 600; i++) { status = rl2_status_tx_read(sc); - if (status == 0x03) + if (status == RL2_STATUS_TX_XFR_COMPLETE) break; DELAY(1000); } splx(s); - if (status == 0x03) { - rl2_status_tx_write(sc, 0x00); + if (status == RL2_STATUS_TX_XFR_COMPLETE) { + rl2_status_tx_write(sc, RL2_STATUS_TX_IDLE); dprintf("]=0"); return (0); } else { printf("%s: tx cmd failed (%02x)\n", sc->sc_dev.dv_xname, status); - /* XXX Needs reset? */ + rl2_need_reset(sc); dprintf("]=-1"); return (-1); } @@ -364,7 +367,9 @@ rl2_rx_request(sc, timeo) /* Short wait for states 1|5|6. */ s = spl0(); for (i = 0; i < timeo; i++) { - if (status == 0x60 || status == 0x10 || status == 0x50) + if (status == RL2_STATUS_RX_LOLEN_AVAIL || + status == RL2_STATUS_RX_HILEN_AVAIL || + status == RL2_STATUS_RX_ERROR) break; DELAY(1000); status = rl2_status_rx_read(sc); @@ -373,26 +378,26 @@ rl2_rx_request(sc, timeo) dprintf(" (%dms)",i); if (sc->sc_width == 16) { - if (status != 0x10) + if (status != RL2_STATUS_RX_HILEN_AVAIL) goto badstatus_quiet; /* Read 2 octets. */ len = rl2_data_read_2(sc); } else if (sc->sc_width == 8) { - if (status != 0x60) + if (status != RL2_STATUS_RX_LOLEN_AVAIL) goto badstatus_quiet; /* Read low octet. */ lo = rl2_data_read_1(sc); - rl2_status_rx_write(sc, 0x70); + rl2_status_rx_write(sc, RL2_STATUS_RX_LOLEN_ACCEPT); rl2_status_rx_int(sc); s = spl0(); for (i = 0; i < 600; i++) { status = rl2_status_rx_read(sc); - if (status == 0x10) + if (status == RL2_STATUS_RX_HILEN_AVAIL) break; DELAY(1000); } splx(s); - if (status != 0x10) + if (status != RL2_STATUS_RX_HILEN_AVAIL) goto badstatus; /* Read high octet. */ hi = rl2_data_read_1(sc); @@ -410,7 +415,7 @@ badstatus: printf("%s: rx_request timed out, status %02x\n", sc->sc_dev.dv_xname, status); badstatus_quiet: - if (status == 0x50) + if (status == RL2_STATUS_RX_ERROR) printf("%s: rx protocol error (nak)\n", sc->sc_dev.dv_xname); dprintf("]"); return (-1); @@ -487,17 +492,17 @@ rl2_rx_data(sc, buf, len) u_int8_t status; dprintf(" Rd["); - rl2_status_rx_write(sc, 0x20); + rl2_status_rx_write(sc, RL2_STATUS_RX_HILEN_ACCEPT); rl2_status_rx_int(sc); s = spl0(); for (i = 0; i < 600; i++) { status = rl2_status_rx_read(sc); - if (status == 0x40) + if (status == RL2_STATUS_RX_XFR) break; DELAY(1000); } splx(s); - if (status != 0x40) { + if (status != RL2_STATUS_RX_XFR) { dprintf("]=-1"); return (-1); } @@ -520,7 +525,7 @@ rl2_rx_end(sc) /* EndOfRx() */ dprintf(" Re["); - rl2_status_rx_write(sc, 0x30); + rl2_status_rx_write(sc, RL2_STATUS_RX_XFR_COMPLETE); rl2_status_rx_int(sc); /* rl2_wakeup(sc, 0); */ dprintf("]"); @@ -533,7 +538,7 @@ rl2_clear_nak(sc) { /* ClearNAK() */ - rl2_status_tx_write(sc, 0x08); + rl2_status_tx_write(sc, RL2_STATUS_CLRNAK); rl2_status_tx_int(sc); } @@ -564,14 +569,13 @@ rl2_msg_tx_start(sc, buf, pktlen, state) ret = rl2_tx_request(sc, pktlen); if (ret == 2) { rl2_clear_nak(sc); - if (sc->sc_cardtype & RL2_CTYPE_OEM) { - /* XXX Needs reset? */ - } + if (sc->sc_cardtype & RL2_CTYPE_OEM) + rl2_need_reset(sc); ret = 2; } else if (ret == 1) { /* Timeout. */ - rl2_status_tx_write(sc, 0x04); + rl2_status_tx_write(sc, RL2_STATUS_TX_XFR); ret = -1; } return (ret); @@ -644,9 +648,8 @@ rl2_msg_tx_end(sc, state) panic("rl2_msg_tx_end remain %d", state->pd.p_nremain); #endif ret = rl2_tx_end(sc); - if (sc->sc_arpcom.ac_if.if_flags & IFF_OACTIVE) { - state->w |= 0x10 | 0x80; - } + if (sc->sc_arpcom.ac_if.if_flags & IFF_OACTIVE) + state->w = RL2_WAKEUP_NOCHANGE; rl2_wakeup(sc, state->w); rl2_enable(sc, state->ien); return (ret); @@ -662,7 +665,7 @@ rl2_newseq(sc) s = splhigh(); seq = sc->sc_pktseq++; - if (sc->sc_pktseq > 0x7c) + if (sc->sc_pktseq > RL2_MAXSEQ) sc->sc_pktseq = 0; splx(s); return (seq); @@ -759,7 +762,7 @@ rl2_msg_txrx(sc, tx, txlen, rx, rxlen) if (rxc->cmd_error & 0x80) { printf("%s: command error 0x%02x command %c%d\n", sc->sc_dev.dv_xname, - rxc->cmd_error & 0x7f, + rxc->cmd_error & ~0x80, rxc->cmd_letter, rxc->cmd_fn); return (-1); } @@ -772,6 +775,8 @@ rl2_msg_txrx(sc, tx, txlen, rx, rxlen) * service routine that someone is expecting a reply message. * Mailboxes are identified by the message sequence number * and also hold a pointer to storage supplied by the waiter. + * The interrupt service routine signals the mailbox when it + * gets the reply message. */ /* Create a mailbox for filling. */ @@ -834,7 +839,7 @@ rl2_mbox_wait(sc, seq, timeo) s = spl0(); i = 0; while (mb->mb_state == RL2MBOX_EMPTY && i < timeo) { - DELAY(hz); /* 1 tick. */ + DELAY(1000); i++; } if (i) @@ -843,10 +848,14 @@ rl2_mbox_wait(sc, seq, timeo) ; splx(s); } else { - tsleep((void *)mb, PRIBIO, "rl2mbox", timeo); - if (mb->mb_state == RL2MBOX_FILLING) - /* XXX Could race. */ - tsleep((void *)mb, PRIBIO, "rl2mbox", 0); + tsleep((void *)mb, PRIBIO, "rl2mbox", hz * timeo / 1000); + if (mb->mb_state == RL2MBOX_FILLING) { + /* Must wait until filled. */ + s = spl0(); + while (mb->mb_state == RL2MBOX_FILLING) + ; + splx(s); + } } s = splhigh(); |