From a155ac59cca3f7ea994c687509692dea2c600043 Mon Sep 17 00:00:00 2001 From: Mark Kettenis Date: Sun, 21 Feb 2010 12:01:43 +0000 Subject: Start and stop watchdog timer in the appropriate places, and print a message if it fires. --- sys/arch/sparc64/dev/vnet.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'sys/arch/sparc64') diff --git a/sys/arch/sparc64/dev/vnet.c b/sys/arch/sparc64/dev/vnet.c index de702610758..f9f11b66fcd 100644 --- a/sys/arch/sparc64/dev/vnet.c +++ b/sys/arch/sparc64/dev/vnet.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vnet.c,v 1.22 2009/12/26 18:54:56 kettenis Exp $ */ +/* $OpenBSD: vnet.c,v 1.23 2010/02/21 12:01:42 kettenis Exp $ */ /* * Copyright (c) 2009 Mark Kettenis * @@ -866,6 +866,8 @@ vnet_rx_vio_dring_data(struct vnet_softc *sc, struct vio_msg_tag *tag) if (sc->sc_tx_cnt < sc->sc_vd->vd_nentries) ifp->if_flags &= ~IFF_OACTIVE; + if (sc->sc_tx_cnt == 0) + ifp->if_timer = 0; vnet_start(ifp); break; @@ -1120,6 +1122,8 @@ vnet_start(struct ifnet *ifp) dm.start_idx = sc->sc_tx_prod; dm.end_idx = -1; vio_sendmsg(sc, &dm, sizeof(dm)); + + ifp->if_timer = 5; } sc->sc_tx_prod = desc; @@ -1255,6 +1259,9 @@ vnet_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) void vnet_watchdog(struct ifnet *ifp) { + struct vnet_softc *sc = ifp->if_softc; + + printf("%s: watchdog timeout\n", sc->sc_dv.dv_xname); } int @@ -1386,6 +1393,7 @@ vnet_stop(struct ifnet *ifp) struct ldc_conn *lc = &sc->sc_lc; ifp->if_flags &= ~(IFF_RUNNING | IFF_OACTIVE); + ifp->if_timer = 0; cbus_intr_setenabled(sc->sc_tx_sysino, INTR_DISABLED); cbus_intr_setenabled(sc->sc_rx_sysino, INTR_DISABLED); -- cgit v1.2.3