diff options
author | Marcus Glocker <mglocker@cvs.openbsd.org> | 2007-11-10 14:20:16 +0000 |
---|---|---|
committer | Marcus Glocker <mglocker@cvs.openbsd.org> | 2007-11-10 14:20:16 +0000 |
commit | 56b12da4739e8992f8f6db598e8695fcb5a2778c (patch) | |
tree | 0c9aa0b8664f6c5617cb673e5ce3d20d18fd051d /sys/dev/ic | |
parent | f4b5c0d5d79172ba1db95fc7baecd219bcce1de8 (diff) |
- Fix command timeouts in certain scenarios (like under X11)
- Properly issue the RTS-Threshold firmware command
ok claudio@
Diffstat (limited to 'sys/dev/ic')
-rw-r--r-- | sys/dev/ic/malo.c | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/sys/dev/ic/malo.c b/sys/dev/ic/malo.c index 72a07f79e1f..a0a30abd071 100644 --- a/sys/dev/ic/malo.c +++ b/sys/dev/ic/malo.c @@ -1,4 +1,4 @@ -/* $OpenBSD: malo.c,v 1.80 2007/10/01 04:03:51 krw Exp $ */ +/* $OpenBSD: malo.c,v 1.81 2007/11/10 14:20:15 mglocker Exp $ */ /* * Copyright (c) 2006 Claudio Jeker <claudio@openbsd.org> @@ -108,6 +108,7 @@ struct malo_tx_desc { #define MALO_RX_RING_COUNT 256 #define MALO_TX_RING_COUNT 256 #define MALO_MAX_SCATTER 8 /* XXX unknown, wild guess */ +#define MALO_CMD_TIMEOUT 50 /* MALO_CMD_TIMEOUT * 100us */ /* * Firmware commands @@ -199,6 +200,11 @@ struct malo_cmd_rate { uint8_t aprates[14]; } __packed; +struct malo_cmd_rts { + uint16_t action; + uint32_t threshold; +} __packed; + struct malo_cmd_slot { uint16_t action; uint8_t slot; @@ -505,14 +511,14 @@ malo_send_cmd_dma(struct malo_softc *sc, bus_addr_t addr) malo_ctl_write4(sc, 0x0c18, 2); /* CPU_TRANSFER_CMD */ malo_ctl_barrier(sc, BUS_SPACE_BARRIER_WRITE); - for (i = 0; i < 10; i++) { + for (i = 0; i < MALO_CMD_TIMEOUT; i++) { delay(100); bus_dmamap_sync(sc->sc_dmat, sc->sc_cmd_dmam, 0, PAGE_SIZE, BUS_DMASYNC_POSTWRITE | BUS_DMASYNC_POSTREAD); if (hdr->cmd & htole16(0x8000)) break; } - if (i == 10) { + if (i == MALO_CMD_TIMEOUT) { printf("%s: timeout while waiting for cmd response!\n", sc->sc_dev.dv_xname); return (ETIMEDOUT); @@ -2234,13 +2240,17 @@ int malo_cmd_set_rts(struct malo_softc *sc, uint32_t threshold) { struct malo_cmdheader *hdr = sc->sc_cmd_mem; + struct malo_cmd_rts *body; hdr->cmd = htole16(MALO_CMD_SET_RTS); - hdr->size = htole16(sizeof(*hdr) + sizeof(threshold)); + hdr->size = htole16(sizeof(*hdr) + sizeof(*body)); hdr->seqnum = 1; hdr->result = 0; + body = (struct malo_cmd_rts *)(hdr + 1); - *(uint32_t *)(hdr + 1) = htole32(threshold); + bzero(body, sizeof(*body)); + body->action = htole16(1); + body->threshold = htole32(threshold); bus_dmamap_sync(sc->sc_dmat, sc->sc_cmd_dmam, 0, PAGE_SIZE, BUS_DMASYNC_PREWRITE | BUS_DMASYNC_PREREAD); |