From 2e5551ad87228caa7a774df7bfb17c1e7bbf85a7 Mon Sep 17 00:00:00 2001 From: phk Date: Thu, 1 Jun 2000 21:57:13 +0000 Subject: Don't panic if ifpromisc() returnes ENXIO, it's probably just an pccard which have been pulled. --- sys/net/bpf.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'sys/net/bpf.c') diff --git a/sys/net/bpf.c b/sys/net/bpf.c index 6c08190..5fc8262 100644 --- a/sys/net/bpf.c +++ b/sys/net/bpf.c @@ -295,6 +295,7 @@ static void bpf_detachd(d) struct bpf_d *d; { + int error; struct bpf_d **p; struct bpf_if *bp; @@ -305,13 +306,17 @@ bpf_detachd(d) */ if (d->bd_promisc) { d->bd_promisc = 0; - if (ifpromisc(bp->bif_ifp, 0)) + error = ifpromisc(bp->bif_ifp, 0); + if (error != 0 && error != ENXIO) { /* + * ENXIO can happen if a pccard is unplugged * Something is really wrong if we were able to put * the driver into promiscuous mode, but can't * take it out. */ - panic("bpf: ifpromisc failed"); + printf("%s%d: ifpromisc failed %d\n", + bp->bif_ifp->if_name, bp->bif_ifp->if_unit, error); + } } /* Remove d from the interface's descriptor list. */ p = &bp->bif_dlist; -- cgit v1.1