Module Name: src Committed By: bouyer Date: Sat Dec 8 13:31:32 UTC 2018
Modified Files: src/sys/dev/pci: if_msk.c Log Message: Don't try to handle interrupts for a detached device. Should fix panic on shutdown reported by Stefan Hertenberger on current-users. To generate a diff of this commit: cvs rdiff -u -r1.80 -r1.81 src/sys/dev/pci/if_msk.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/pci/if_msk.c diff -u src/sys/dev/pci/if_msk.c:1.80 src/sys/dev/pci/if_msk.c:1.81 --- src/sys/dev/pci/if_msk.c:1.80 Tue Nov 13 19:39:04 2018 +++ src/sys/dev/pci/if_msk.c Sat Dec 8 13:31:31 2018 @@ -1,4 +1,4 @@ -/* $NetBSD: if_msk.c,v 1.80 2018/11/13 19:39:04 jdolecek Exp $ */ +/* $NetBSD: if_msk.c,v 1.81 2018/12/08 13:31:31 bouyer Exp $ */ /* $OpenBSD: if_msk.c,v 1.79 2009/10/15 17:54:56 deraadt Exp $ */ /* @@ -52,7 +52,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_msk.c,v 1.80 2018/11/13 19:39:04 jdolecek Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_msk.c,v 1.81 2018/12/08 13:31:31 bouyer Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -1299,7 +1299,7 @@ msk_detach(device_t self, int flags) if (sc->sk_if[sc_if->sk_port] == NULL) return (0); - msk_stop(ifp, 0); + msk_stop(ifp, 1); if (--sc->rnd_attached == 0) rnd_detach_source(&sc->rnd_source); @@ -2244,10 +2244,12 @@ msk_intr(void *xsc) switch (cur_st->sk_opcode) { case SK_Y2_STOPC_RXSTAT: sc_if = sc->sk_if[cur_st->sk_link & 0x01]; - msk_rxeof(sc_if, letoh16(cur_st->sk_len), - letoh32(cur_st->sk_status)); - if (sc_if->sk_cdata.sk_rx_cnt < (MSK_RX_RING_CNT/3)) - msk_fill_rx_tick(sc_if); + if (sc_if) { + msk_rxeof(sc_if, letoh16(cur_st->sk_len), + letoh32(cur_st->sk_status)); + if (sc_if->sk_cdata.sk_rx_cnt < (MSK_RX_RING_CNT/3)) + msk_fill_rx_tick(sc_if); + } break; case SK_Y2_STOPC_TXSTAT: if (sc_if0)