summaryrefslogtreecommitdiff
path: root/sys/dev/isa/if_ex.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/isa/if_ex.c')
-rw-r--r--sys/dev/isa/if_ex.c203
1 files changed, 103 insertions, 100 deletions
diff --git a/sys/dev/isa/if_ex.c b/sys/dev/isa/if_ex.c
index 104ba211d6c..3b91b23fc5c 100644
--- a/sys/dev/isa/if_ex.c
+++ b/sys/dev/isa/if_ex.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ex.c,v 1.27 2007/09/20 05:48:46 brad Exp $ */
+/* $OpenBSD: if_ex.c,v 1.28 2007/10/06 06:35:57 brad Exp $ */
/*
* Copyright (c) 1997, Donald A. Schmidt
* Copyright (c) 1996, Javier Martín Rueda (jmrueda@diatel.upm.es)
@@ -129,17 +129,19 @@ struct cfdriver ex_cd = {
NULL, "ex", DV_IFNET
};
-#define ISA_GET(offset) bus_space_read_1(sc->sc_iot, sc->sc_ioh, (offset))
-#define ISA_PUT(offset, value) bus_space_write_1(sc->sc_iot, sc->sc_ioh, \
- (offset), (value))
-#define ISA_GET_2(offset) bus_space_read_2(sc->sc_iot, sc->sc_ioh, \
- (offset))
-#define ISA_PUT_2(offset, value) bus_space_write_2(sc->sc_iot, sc->sc_ioh, \
- (offset), (value))
-#define ISA_GET_2_MULTI(offset, addr, count) bus_space_read_multi_2( \
- sc->sc_iot, sc->sc_ioh, (offset), (addr), (count))
-#define ISA_PUT_2_MULTI(offset, addr, count) bus_space_write_multi_2( \
- sc->sc_iot, sc->sc_ioh, (offset), (addr), (count))
+#define CSR_READ_1(sc, off) \
+ bus_space_read_1((sc)->sc_iot, (sc)->sc_ioh, (off))
+#define CSR_READ_2(sc, off) \
+ bus_space_read_2((sc)->sc_iot, (sc)->sc_ioh, (off))
+#define CSR_READ_MULTI_2(sc, off, addr, count) \
+ bus_space_read_multi_2((sc)->sc_iot, (sc)->sc_ioh, (off), (addr), (count))
+
+#define CSR_WRITE_1(sc, off, value) \
+ bus_space_write_1((sc)->sc_iot, (sc)->sc_ioh, (off), (value))
+#define CSR_WRITE_2(sc, off, value) \
+ bus_space_write_2((sc)->sc_iot, (sc)->sc_ioh, (off), (value))
+#define CSR_WRITE_MULTI_2(sc, off, addr, count) \
+ bus_space_write_multi_2((sc)->sc_iot, (sc)->sc_ioh, (off), (addr), (count))
int
ex_look_for_card(struct isa_attach_args *ia, struct ex_softc *sc)
@@ -150,11 +152,11 @@ ex_look_for_card(struct isa_attach_args *ia, struct ex_softc *sc)
* Check for the i82595 signature, and check that the round robin
* counter actually advances.
*/
- if (((count1 = ISA_GET(ID_REG)) & Id_Mask) != Id_Sig)
+ if (((count1 = CSR_READ_1(sc, ID_REG)) & Id_Mask) != Id_Sig)
return(0);
- count2 = ISA_GET(ID_REG);
- count2 = ISA_GET(ID_REG);
- count2 = ISA_GET(ID_REG);
+ count2 = CSR_READ_1(sc, ID_REG);
+ count2 = CSR_READ_1(sc, ID_REG);
+ count2 = CSR_READ_1(sc, ID_REG);
if ((count2 & Counter_bits) == ((count1 + 0xc0) & Counter_bits))
return(1);
else
@@ -189,7 +191,7 @@ ex_probe(struct device *parent, void *match, void *aux)
/*
* Reset the card.
*/
- ISA_PUT(CMD_REG, Reset_CMD);
+ CSR_WRITE_1(sc, CMD_REG, Reset_CMD);
delay(200);
/*
@@ -224,8 +226,8 @@ ex_probe(struct device *parent, void *match, void *aux)
printf("ex: invalid IRQ.\n");
return(0);
}
- ISA_PUT(CMD_REG, Bank2_Sel);
- tmp = ISA_GET(REG3);
+ CSR_WRITE_1(sc, CMD_REG, Bank2_Sel);
+ tmp = CSR_READ_1(sc, REG3);
if (tmp & TPE_bit)
sc->connector = Conn_TPE;
else if (tmp & BNC_bit)
@@ -235,7 +237,7 @@ ex_probe(struct device *parent, void *match, void *aux)
sc->mem_size = CARD_RAM_SIZE; /* XXX This should be read from the card
itself. */
- ISA_PUT(CMD_REG, Bank0_Sel);
+ CSR_WRITE_1(sc, CMD_REG, Bank0_Sel);
DODEBUG(Start_End, printf("ex_probe: finish\n"););
return(1);
@@ -294,12 +296,12 @@ ex_init(struct ex_softc *sc)
/*
* Load the ethernet address into the card.
*/
- ISA_PUT(CMD_REG, Bank2_Sel);
- temp_reg = ISA_GET(EEPROM_REG);
+ CSR_WRITE_1(sc, CMD_REG, Bank2_Sel);
+ temp_reg = CSR_READ_1(sc, EEPROM_REG);
if (temp_reg & Trnoff_Enable)
- ISA_PUT(EEPROM_REG, temp_reg & ~Trnoff_Enable);
+ CSR_WRITE_1(sc, EEPROM_REG, temp_reg & ~Trnoff_Enable);
for (i = 0; i < ETHER_ADDR_LEN; i++)
- ISA_PUT(I_ADDR_REG0 + i, sc->arpcom.ac_enaddr[i]);
+ CSR_WRITE_1(sc, I_ADDR_REG0 + i, sc->arpcom.ac_enaddr[i]);
/*
* - Setup transmit chaining and discard bad received frames.
* - Match broadcast.
@@ -307,12 +309,13 @@ ex_init(struct ex_softc *sc)
* - Set receiving mode.
* - Set IRQ number.
*/
- ISA_PUT(REG1, ISA_GET(REG1) | Tx_Chn_Int_Md | Tx_Chn_ErStp |
- Disc_Bad_Fr);
- ISA_PUT(REG2, ISA_GET(REG2) | No_SA_Ins | RX_CRC_InMem);
- ISA_PUT(REG3, (ISA_GET(REG3) & 0x3f));
- ISA_PUT(CMD_REG, Bank1_Sel);
- ISA_PUT(INT_NO_REG, (ISA_GET(INT_NO_REG) & 0xf8) |
+ CSR_WRITE_1(sc, REG1, CSR_READ_1(sc, REG1) | Tx_Chn_Int_Md |
+ Tx_Chn_ErStp | Disc_Bad_Fr);
+ CSR_WRITE_1(sc, REG2, CSR_READ_1(sc, REG2) | No_SA_Ins |
+ RX_CRC_InMem);
+ CSR_WRITE_1(sc, REG3, (CSR_READ_1(sc, REG3) & 0x3f));
+ CSR_WRITE_1(sc, CMD_REG, Bank1_Sel);
+ CSR_WRITE_1(sc, INT_NO_REG, (CSR_READ_1(sc, INT_NO_REG) & 0xf8) |
irq2eemap[sc->irq_no]);
/*
@@ -326,26 +329,26 @@ ex_init(struct ex_softc *sc)
sc->rx_upper_limit = sc->rx_mem_size - 2;
sc->tx_lower_limit = sc->rx_mem_size;
sc->tx_upper_limit = sc->mem_size - 2;
- ISA_PUT(RCV_LOWER_LIMIT_REG, sc->rx_lower_limit >> 8);
- ISA_PUT(RCV_UPPER_LIMIT_REG, sc->rx_upper_limit >> 8);
- ISA_PUT(XMT_LOWER_LIMIT_REG, sc->tx_lower_limit >> 8);
- ISA_PUT(XMT_UPPER_LIMIT_REG, sc->tx_upper_limit >> 8);
-
+ CSR_WRITE_1(sc, RCV_LOWER_LIMIT_REG, sc->rx_lower_limit >> 8);
+ CSR_WRITE_1(sc, RCV_UPPER_LIMIT_REG, sc->rx_upper_limit >> 8);
+ CSR_WRITE_1(sc, XMT_LOWER_LIMIT_REG, sc->tx_lower_limit >> 8);
+ CSR_WRITE_1(sc, XMT_UPPER_LIMIT_REG, sc->tx_upper_limit >> 8);
+
/*
* Enable receive and transmit interrupts, and clear any pending int.
*/
- ISA_PUT(REG1, ISA_GET(REG1) | TriST_INT);
- ISA_PUT(CMD_REG, Bank0_Sel);
- ISA_PUT(MASK_REG, All_Int & ~(Rx_Int | Tx_Int));
- ISA_PUT(STATUS_REG, All_Int);
+ CSR_WRITE_1(sc, REG1, CSR_READ_1(sc, REG1) | TriST_INT);
+ CSR_WRITE_1(sc, CMD_REG, Bank0_Sel);
+ CSR_WRITE_1(sc, MASK_REG, All_Int & ~(Rx_Int | Tx_Int));
+ CSR_WRITE_1(sc, STATUS_REG, All_Int);
/*
* Initialize receive and transmit ring buffers.
*/
- ISA_PUT_2(RCV_BAR, sc->rx_lower_limit);
+ CSR_WRITE_2(sc, RCV_BAR, sc->rx_lower_limit);
sc->rx_head = sc->rx_lower_limit;
- ISA_PUT_2(RCV_STOP_REG, sc->rx_upper_limit | 0xfe);
- ISA_PUT_2(XMT_BAR, sc->tx_lower_limit);
+ CSR_WRITE_2(sc, RCV_STOP_REG, sc->rx_upper_limit | 0xfe);
+ CSR_WRITE_2(sc, XMT_BAR, sc->tx_lower_limit);
sc->tx_head = sc->tx_tail = sc->tx_lower_limit;
ifp->if_flags |= IFF_RUNNING;
@@ -355,9 +358,9 @@ ex_init(struct ex_softc *sc)
/*
* Final reset of the board, and enable operation.
*/
- ISA_PUT(CMD_REG, Sel_Reset_CMD);
+ CSR_WRITE_1(sc, CMD_REG, Sel_Reset_CMD);
delay(2);
- ISA_PUT(CMD_REG, Rcv_Enable_CMD);
+ CSR_WRITE_1(sc, CMD_REG, Rcv_Enable_CMD);
ex_start(ifp);
splx(s);
@@ -415,7 +418,7 @@ ex_start(struct ifnet *ifp)
* routines. XXX Is this necessary with splnet()
* enabled?
*/
- ISA_WRITE(MASK_REG, All_Int);
+ CSR_WRITE_2(sc, MASK_REG, All_Int);
#endif
/*
@@ -436,11 +439,11 @@ ex_start(struct ifnet *ifp)
/* Build the packet frame in the card's ring buffer. */
DODEBUG(Sent_Pkts, printf("2. dest=%d, next=%d. ", dest, next););
- ISA_PUT_2(HOST_ADDR_REG, dest);
- ISA_PUT_2(IO_PORT_REG, Transmit_CMD);
- ISA_PUT_2(IO_PORT_REG, 0);
- ISA_PUT_2(IO_PORT_REG, next);
- ISA_PUT_2(IO_PORT_REG, data_len);
+ CSR_WRITE_2(sc, HOST_ADDR_REG, dest);
+ CSR_WRITE_2(sc, IO_PORT_REG, Transmit_CMD);
+ CSR_WRITE_2(sc, IO_PORT_REG, 0);
+ CSR_WRITE_2(sc, IO_PORT_REG, next);
+ CSR_WRITE_2(sc, IO_PORT_REG, data_len);
/*
* Output the packet data to the card. Ensure all
@@ -452,16 +455,16 @@ ex_start(struct ifnet *ifp)
DODEBUG(Sent_Pkts, printf("[%d]", m->m_len););
if (i) {
tmp16[1] = *(mtod(m, caddr_t));
- ISA_PUT_2_MULTI(IO_PORT_REG, tmp16, 1);
+ CSR_WRITE_MULTI_2(sc, IO_PORT_REG, tmp16, 1);
}
- ISA_PUT_2_MULTI(IO_PORT_REG, mtod(m, caddr_t)
+ CSR_WRITE_MULTI_2(sc, IO_PORT_REG, mtod(m, caddr_t)
+ i, (m->m_len - i) / 2);
if ((i = (m->m_len - i) & 1))
tmp16[0] = *(mtod(m, caddr_t) +
m->m_len - 1);
}
if (i)
- ISA_PUT_2_MULTI(IO_PORT_REG, tmp16, 1);
+ CSR_WRITE_MULTI_2(sc, IO_PORT_REG, tmp16, 1);
/*
* If there were other frames chained, update the
@@ -469,16 +472,16 @@ ex_start(struct ifnet *ifp)
*/
if (sc->tx_head != sc->tx_tail) {
if (sc->tx_tail != dest) {
- ISA_PUT_2(HOST_ADDR_REG,
+ CSR_WRITE_2(sc, HOST_ADDR_REG,
sc->tx_last + XMT_Chain_Point);
- ISA_PUT_2(IO_PORT_REG, dest);
+ CSR_WRITE_2(sc, IO_PORT_REG, dest);
}
- ISA_PUT_2(HOST_ADDR_REG, sc->tx_last +
+ CSR_WRITE_2(sc, HOST_ADDR_REG, sc->tx_last +
XMT_Byte_Count);
- i = ISA_GET_2(IO_PORT_REG);
- ISA_PUT_2(HOST_ADDR_REG, sc->tx_last +
+ i = CSR_READ_2(sc, IO_PORT_REG);
+ CSR_WRITE_2(sc, HOST_ADDR_REG, sc->tx_last +
XMT_Byte_Count);
- ISA_PUT_2(IO_PORT_REG, i | Ch_bit);
+ CSR_WRITE_2(sc, IO_PORT_REG, i | Ch_bit);
}
/*
@@ -487,17 +490,17 @@ ex_start(struct ifnet *ifp)
* -Enable receive and transmit interrupts.
* -Send Transmit or Resume_XMT command, as appropriate.
*/
- ISA_GET_2(IO_PORT_REG);
+ CSR_READ_2(sc, IO_PORT_REG);
#ifdef EX_PSA_INTR
- ISA_PUT_2(MASK_REG, All_Int & ~(Rx_Int | Tx_Int));
+ CSR_WRITE_2(sc, MASK_REG, All_Int & ~(Rx_Int | Tx_Int));
#endif
if (sc->tx_head == sc->tx_tail) {
- ISA_PUT_2(XMT_BAR, dest);
- ISA_PUT(CMD_REG, Transmit_CMD);
+ CSR_WRITE_2(sc, XMT_BAR, dest);
+ CSR_WRITE_1(sc, CMD_REG, Transmit_CMD);
sc->tx_head = dest;
DODEBUG(Sent_Pkts, printf("Transmit\n"););
} else {
- ISA_PUT(CMD_REG, Resume_XMT_List_CMD);
+ CSR_WRITE_1(sc, CMD_REG, Resume_XMT_List_CMD);
DODEBUG(Sent_Pkts, printf("Resume\n"););
}
sc->tx_last = dest;
@@ -531,17 +534,17 @@ ex_stop(struct ex_softc *sc)
* - Mask and clear all interrupts.
* - Reset the 82595.
*/
- ISA_PUT(CMD_REG, Bank1_Sel);
- ISA_PUT(REG1, ISA_GET(REG1) & ~TriST_INT);
- ISA_PUT(CMD_REG, Bank0_Sel);
- ISA_PUT(CMD_REG, Rcv_Stop);
+ CSR_WRITE_1(sc, CMD_REG, Bank1_Sel);
+ CSR_WRITE_1(sc, REG1, CSR_READ_1(sc, REG1) & ~TriST_INT);
+ CSR_WRITE_1(sc, CMD_REG, Bank0_Sel);
+ CSR_WRITE_1(sc, CMD_REG, Rcv_Stop);
sc->tx_head = sc->tx_tail = sc->tx_lower_limit;
sc->tx_last = 0; /* XXX I think these two lines are not necessary,
because ex_init will always be called again
to reinit the interface. */
- ISA_PUT(MASK_REG, All_Int);
- ISA_PUT(STATUS_REG, All_Int);
- ISA_PUT(CMD_REG, Reset_CMD);
+ CSR_WRITE_1(sc, MASK_REG, All_Int);
+ CSR_WRITE_1(sc, STATUS_REG, All_Int);
+ CSR_WRITE_1(sc, CMD_REG, Reset_CMD);
delay(200);
DODEBUG(Start_End, printf("ex_stop: finish\n"););
@@ -565,13 +568,13 @@ ex_intr(void *arg)
#endif
send_pkts = 0;
- while ((int_status = ISA_GET(STATUS_REG)) & (Tx_Int | Rx_Int)) {
+ while ((int_status = CSR_READ_1(sc, STATUS_REG)) & (Tx_Int | Rx_Int)) {
if (int_status & Rx_Int) {
- ISA_PUT(STATUS_REG, Rx_Int);
+ CSR_WRITE_1(sc, STATUS_REG, Rx_Int);
handled = 1;
ex_rx_intr(sc);
} else if (int_status & Tx_Int) {
- ISA_PUT(STATUS_REG, Tx_Int);
+ CSR_WRITE_1(sc, STATUS_REG, Tx_Int);
handled = 1;
ex_tx_intr(sc);
send_pkts = 1;
@@ -609,11 +612,11 @@ ex_tx_intr(struct ex_softc *sc)
*/
ifp->if_timer = 0;
while (sc->tx_head != sc->tx_tail) {
- ISA_PUT_2(HOST_ADDR_REG, sc->tx_head);
- if (! ISA_GET_2(IO_PORT_REG) & Done_bit)
+ CSR_WRITE_2(sc, HOST_ADDR_REG, sc->tx_head);
+ if (!CSR_READ_2(sc, IO_PORT_REG) & Done_bit)
break;
- tx_status = ISA_GET_2(IO_PORT_REG);
- sc->tx_head = ISA_GET_2(IO_PORT_REG);
+ tx_status = CSR_READ_2(sc, IO_PORT_REG);
+ sc->tx_head = CSR_READ_2(sc, IO_PORT_REG);
if (tx_status & TX_OK_bit)
ifp->if_opackets++;
else
@@ -643,11 +646,11 @@ ex_rx_intr(struct ex_softc *sc)
* - If packet bad, just discard it, and update statistics.
* Finally, advance receive stop limit in card's memory to new location.
*/
- ISA_PUT_2(HOST_ADDR_REG, sc->rx_head);
- while (ISA_GET_2(IO_PORT_REG) == RCV_Done) {
- rx_status = ISA_GET_2(IO_PORT_REG);
- sc->rx_head = ISA_GET_2(IO_PORT_REG);
- QQQ = pkt_len = ISA_GET_2(IO_PORT_REG);
+ CSR_WRITE_2(sc, HOST_ADDR_REG, sc->rx_head);
+ while (CSR_READ_2(sc, IO_PORT_REG) == RCV_Done) {
+ rx_status = CSR_READ_2(sc, IO_PORT_REG);
+ sc->rx_head = CSR_READ_2(sc, IO_PORT_REG);
+ QQQ = pkt_len = CSR_READ_2(sc, IO_PORT_REG);
if (rx_status & RCV_OK_bit) {
MGETHDR(m, M_DONTWAIT, MT_DATA);
ipkt = m;
@@ -675,12 +678,12 @@ ex_rx_intr(struct ex_softc *sc)
* for the last one in an odd-length
* packet.
*/
- ISA_GET_2_MULTI(IO_PORT_REG,
+ CSR_READ_MULTI_2(sc, IO_PORT_REG,
mtod(m, caddr_t), m->m_len / 2);
if (m->m_len & 1)
*(mtod(m, caddr_t) +
m->m_len - 1) =
- ISA_GET(IO_PORT_REG);
+ CSR_READ_1(sc, IO_PORT_REG);
pkt_len -= m->m_len;
if (pkt_len > 0) {
MGET(m->m_next, M_DONTWAIT,
@@ -713,13 +716,13 @@ ex_rx_intr(struct ex_softc *sc)
}
} else
ifp->if_ierrors++;
- ISA_PUT_2(HOST_ADDR_REG, sc->rx_head);
+ CSR_WRITE_2(sc, HOST_ADDR_REG, sc->rx_head);
rx_another: ;
}
if (sc->rx_head < sc->rx_lower_limit + 2)
- ISA_PUT_2(RCV_STOP_REG, sc->rx_upper_limit);
+ CSR_WRITE_2(sc, RCV_STOP_REG, sc->rx_upper_limit);
else
- ISA_PUT_2(RCV_STOP_REG, sc->rx_head - 2);
+ CSR_WRITE_2(sc, RCV_STOP_REG, sc->rx_head - 2);
DODEBUG(Start_End, printf("ex_rx_intr: finish\n"););
}
@@ -831,30 +834,30 @@ ex_eeprom_read(struct ex_softc *sc, int location)
int read_cmd = location | EE_READ_CMD;
short ctrl_val = EECS;
- ISA_PUT(CMD_REG, Bank2_Sel);
- ISA_PUT(EEPROM_REG, EECS);
+ CSR_WRITE_1(sc, CMD_REG, Bank2_Sel);
+ CSR_WRITE_1(sc, EEPROM_REG, EECS);
for (i = 8; i >= 0; i--) {
short outval = (read_cmd & (1 << i)) ? ctrl_val | EEDI :
ctrl_val;
- ISA_PUT(EEPROM_REG, outval);
- ISA_PUT(EEPROM_REG, outval | EESK);
+ CSR_WRITE_1(sc, EEPROM_REG, outval);
+ CSR_WRITE_1(sc, EEPROM_REG, outval | EESK);
delay(3);
- ISA_PUT(EEPROM_REG, outval);
+ CSR_WRITE_1(sc, EEPROM_REG, outval);
delay(2);
}
- ISA_PUT(EEPROM_REG, ctrl_val);
+ CSR_WRITE_1(sc, EEPROM_REG, ctrl_val);
for (i = 16; i > 0; i--) {
- ISA_PUT(EEPROM_REG, ctrl_val | EESK);
+ CSR_WRITE_1(sc, EEPROM_REG, ctrl_val | EESK);
delay(3);
- data = (data << 1) | ((ISA_GET(EEPROM_REG) & EEDO) ? 1 : 0);
- ISA_PUT(EEPROM_REG, ctrl_val);
+ data = (data << 1) | ((CSR_READ_1(sc, EEPROM_REG) & EEDO) ? 1 : 0);
+ CSR_WRITE_1(sc, EEPROM_REG, ctrl_val);
delay(2);
}
ctrl_val &= ~EECS;
- ISA_PUT(EEPROM_REG, ctrl_val | EESK);
+ CSR_WRITE_1(sc, EEPROM_REG, ctrl_val | EESK);
delay(3);
- ISA_PUT(EEPROM_REG, ctrl_val);
+ CSR_WRITE_1(sc, EEPROM_REG, ctrl_val);
delay(2);
- ISA_PUT(CMD_REG, Bank0_Sel);
+ CSR_WRITE_1(sc, CMD_REG, Bank0_Sel);
return(data);
}