o Make sure interface is up before continuing with atu_start(). Should fix PR

kern/29326 as reported by Andreas Gustafsson.
o Use IFQ_DEQUEUE instead of IF_DEQUEUE
This commit is contained in:
joff 2005-02-24 06:06:11 +00:00
parent 8c9dd4bba7
commit ba4b28e8e5

View File

@ -1,4 +1,4 @@
/* $NetBSD: if_atu.c,v 1.2 2005/01/24 22:40:00 joff Exp $ */ /* $NetBSD: if_atu.c,v 1.3 2005/02/24 06:06:11 joff Exp $ */
/* $OpenBSD: if_atu.c,v 1.48 2004/12/30 01:53:21 dlg Exp $ */ /* $OpenBSD: if_atu.c,v 1.48 2004/12/30 01:53:21 dlg Exp $ */
/* /*
* Copyright (c) 2003, 2004 * Copyright (c) 2003, 2004
@ -48,7 +48,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: if_atu.c,v 1.2 2005/01/24 22:40:00 joff Exp $"); __KERNEL_RCSID(0, "$NetBSD: if_atu.c,v 1.3 2005/02/24 06:06:11 joff Exp $");
#include "bpfilter.h" #include "bpfilter.h"
@ -1628,9 +1628,6 @@ atu_rxeof(usbd_xfer_handle xfer, usbd_private_handle priv, usbd_status status)
ieee80211_input(ifp, m, ni, h->rssi, UGETDW(h->rx_time)); ieee80211_input(ifp, m, ni, h->rssi, UGETDW(h->rx_time));
if (ni == ic->ic_bss)
ieee80211_unref_node(&ni);
else
ieee80211_release_node(ic, ni); ieee80211_release_node(ic, ni);
done1: done1:
splx(s); splx(s);
@ -1769,6 +1766,10 @@ atu_start(struct ifnet *ifp)
DPRINTFN(25, ("%s: atu_start: enter\n", USBDEVNAME(sc->atu_dev))); DPRINTFN(25, ("%s: atu_start: enter\n", USBDEVNAME(sc->atu_dev)));
s = splnet(); s = splnet();
if ((ifp->if_flags & IFF_RUNNING) == 0) {
splx(s);
return;
}
if (ifp->if_flags & IFF_OACTIVE) { if (ifp->if_flags & IFF_OACTIVE) {
DPRINTFN(30, ("%s: atu_start: IFF_OACTIVE\n", DPRINTFN(30, ("%s: atu_start: IFF_OACTIVE\n",
USBDEVNAME(sc->atu_dev))); USBDEVNAME(sc->atu_dev)));
@ -1814,7 +1815,7 @@ atu_start(struct ifnet *ifp)
break; break;
} }
IF_DEQUEUE(&ifp->if_snd, m); IFQ_DEQUEUE(&ifp->if_snd, m);
if (m == NULL) { if (m == NULL) {
DPRINTFN(25, ("%s: nothing to send\n", DPRINTFN(25, ("%s: nothing to send\n",
USBDEVNAME(sc->atu_dev))); USBDEVNAME(sc->atu_dev)));
@ -1860,8 +1861,7 @@ bad:
cd->atu_tx_inuse--; cd->atu_tx_inuse--;
splx(s); splx(s);
/* ifp_if_oerrors++; */ /* ifp_if_oerrors++; */
if (ni != NULL && ni != ic->ic_bss) if (ni != NULL)
/* reclaim node */
ieee80211_release_node(ic, ni); ieee80211_release_node(ic, ni);
continue; continue;
} }
@ -2114,7 +2114,7 @@ atu_watchdog(struct ifnet *ifp)
ifp->if_timer = 0; ifp->if_timer = 0;
if (sc->sc_state != ATU_S_OK) if (sc->sc_state != ATU_S_OK || (ifp->if_flags & IFF_RUNNING) == 0)
return; return;
sc = ifp->if_softc; sc = ifp->if_softc;