diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2009-10-28 22:53:27 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2009-10-28 22:53:27 +0000 |
commit | 440149b70706129506469de15b7d997cc2c02ce3 (patch) | |
tree | 2619e2dc9d7ab08c781032869354772c15a6c266 /sys/arch | |
parent | c53ad1b7394069d5a82fe4a3b58a620a1103554e (diff) |
LOMlite seems to get wedged from time to time; add some code to unwedge it.
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/sparc64/dev/lom.c | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/sys/arch/sparc64/dev/lom.c b/sys/arch/sparc64/dev/lom.c index 759420b8edd..058f4dcea80 100644 --- a/sys/arch/sparc64/dev/lom.c +++ b/sys/arch/sparc64/dev/lom.c @@ -1,4 +1,4 @@ -/* $OpenBSD: lom.c,v 1.15 2009/09/27 18:08:42 kettenis Exp $ */ +/* $OpenBSD: lom.c,v 1.16 2009/10/28 22:53:26 kettenis Exp $ */ /* * Copyright (c) 2009 Mark Kettenis * @@ -403,7 +403,7 @@ lom1_write(struct lom_softc *sc, uint8_t reg, uint8_t val) lc.lc_data = val; lom1_queue_cmd(sc, &lc); - error = tsleep(&lc, PZERO, "lomwr", hz); + error = tsleep(&lc, PZERO, "lomwr", 2 * hz); if (error) lom1_dequeue_cmd(sc, &lc); @@ -520,13 +520,26 @@ lom1_process_queue_locked(struct lom_softc *sc) uint8_t str; lc = TAILQ_FIRST(&sc->sc_queue); - KASSERT(lc != NULL); + if (lc == NULL) { + sc->sc_state = LOM_STATE_IDLE; + return; + } str = bus_space_read_1(sc->sc_iot, sc->sc_ioh, LOM1_STATUS); if (str & LOM1_STATUS_BUSY) { - if (sc->sc_retry++ > 30) + if (sc->sc_retry++ < 30) { + timeout_add_msec(&sc->sc_state_to, 1); return; - timeout_add_msec(&sc->sc_state_to, 1); + } + + /* + * Looks like the microcontroller got wedged. Unwedge + * it by writing this magic value. Give it some time + * to recover. + */ + bus_space_write_1(sc->sc_iot, sc->sc_ioh, LOM1_DATA, 0xac); + timeout_add_msec(&sc->sc_state_to, 1000); + sc->sc_state = LOM_STATE_CMD; return; } |