diff options
author | Marcus Glocker <mglocker@cvs.openbsd.org> | 2007-08-07 11:44:45 +0000 |
---|---|---|
committer | Marcus Glocker <mglocker@cvs.openbsd.org> | 2007-08-07 11:44:45 +0000 |
commit | e00cd91c1e2defe9f133c7f6a268244fa59afa5f (patch) | |
tree | 6d3f1ce8293a1bc84d9610cada8ead6c854d1839 /sys/dev/pcmcia/if_malo.c | |
parent | 0cf76e0076af46f7038d442af1c3533eec5eab5f (diff) |
Improve a evil tsleep() loop by using wakeup() in the interrupt handler.
Still not sure if the tsleep() is safe here, but better than the
previous version.
spotted and OK claudio@
Diffstat (limited to 'sys/dev/pcmcia/if_malo.c')
-rw-r--r-- | sys/dev/pcmcia/if_malo.c | 12 |
1 files changed, 3 insertions, 9 deletions
diff --git a/sys/dev/pcmcia/if_malo.c b/sys/dev/pcmcia/if_malo.c index bc810b6ad4f..eb08fe4490f 100644 --- a/sys/dev/pcmcia/if_malo.c +++ b/sys/dev/pcmcia/if_malo.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_malo.c,v 1.42 2007/08/06 22:51:18 mglocker Exp $ */ +/* $OpenBSD: if_malo.c,v 1.43 2007/08/07 11:44:44 mglocker Exp $ */ /* * Copyright (c) 2007 Marcus Glocker <mglocker@openbsd.org> @@ -796,7 +796,7 @@ cmalo_intr(void *arg) cmalo_rx(sc); if (intr & MALO_VAL_HOST_INTR_CMD) /* command response */ - sc->sc_cmd_running = 0; + wakeup(sc); return (1); } @@ -1840,13 +1840,7 @@ cmalo_cmd_request(struct malo_softc *sc, uint16_t psize, int no_response) return (0); /* wait for the command response */ - sc->sc_cmd_running = 1; - for (i = 0; i < 1000; i++) { - if (sc->sc_cmd_running == 0) - break; - tsleep(sc, 0, "malocmd", 1); - } - if (sc->sc_cmd_running) { + if (tsleep(sc, 0, "malocmd", 500)) { printf("%s: timeout while waiting for cmd response!\n", sc->sc_dev.dv_xname); return (EIO); |