summaryrefslogtreecommitdiff
path: root/sys/dev/pcmcia/if_malo.c
diff options
context:
space:
mode:
authorMarcus Glocker <mglocker@cvs.openbsd.org>2007-08-07 11:44:45 +0000
committerMarcus Glocker <mglocker@cvs.openbsd.org>2007-08-07 11:44:45 +0000
commite00cd91c1e2defe9f133c7f6a268244fa59afa5f (patch)
tree6d3f1ce8293a1bc84d9610cada8ead6c854d1839 /sys/dev/pcmcia/if_malo.c
parent0cf76e0076af46f7038d442af1c3533eec5eab5f (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.c12
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);