From 90e373b1248bb464461fde4e785bc3960d46fe23 Mon Sep 17 00:00:00 2001 From: Mark Kettenis Date: Sat, 31 Oct 2009 19:13:38 +0000 Subject: Make sure we don't insert and entry into the list of pending commends twice. --- sys/arch/sparc64/dev/lom.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/sys/arch/sparc64/dev/lom.c b/sys/arch/sparc64/dev/lom.c index 058f4dcea80..6b4e0e98fda 100644 --- a/sys/arch/sparc64/dev/lom.c +++ b/sys/arch/sparc64/dev/lom.c @@ -1,4 +1,4 @@ -/* $OpenBSD: lom.c,v 1.16 2009/10/28 22:53:26 kettenis Exp $ */ +/* $OpenBSD: lom.c,v 1.17 2009/10/31 19:13:37 kettenis Exp $ */ /* * Copyright (c) 2009 Mark Kettenis * @@ -191,6 +191,7 @@ struct cfdriver lom_cd = { int lom_read(struct lom_softc *, uint8_t, uint8_t *); int lom_write(struct lom_softc *, uint8_t, uint8_t); void lom_queue_cmd(struct lom_softc *, struct lom_cmd *); +void lom_dequeue_cmd(struct lom_softc *, struct lom_cmd *); int lom1_read(struct lom_softc *, uint8_t, uint8_t *); int lom1_write(struct lom_softc *, uint8_t, uint8_t); int lom1_read_polled(struct lom_softc *, uint8_t, uint8_t *); @@ -368,6 +369,13 @@ lom_queue_cmd(struct lom_softc *sc, struct lom_cmd *lc) return lom2_queue_cmd(sc, lc); } +void +lom_dequeue_cmd(struct lom_softc *sc, struct lom_cmd *lc) +{ + if (sc->sc_type < LOM_LOMLITE2) + return lom1_dequeue_cmd(sc, lc); +} + int lom1_read(struct lom_softc *sc, uint8_t reg, uint8_t *val) { @@ -901,6 +909,7 @@ lom_wdog_cb(void *arg, int period) timeout_del(&sc->sc_wdog_to); } else { /* Pat the dog. */ + lom_dequeue_cmd(sc, &sc->sc_wdog_pat); sc->sc_wdog_pat.lc_cmd = LOM_IDX_WDOG_CTL | LOM_IDX_WRITE; sc->sc_wdog_pat.lc_data = sc->sc_wdog_ctl; lom_queue_cmd(sc, &sc->sc_wdog_pat); -- cgit v1.2.3