svn commit: r314222 - in stable/11/sys/dev: iwi ral usb/wlan
Andriy Voskoboinyk
avos at FreeBSD.org
Fri Feb 24 21:19:41 UTC 2017
Author: avos
Date: Fri Feb 24 21:19:40 2017
New Revision: 314222
URL: https://svnweb.freebsd.org/changeset/base/314222
Log:
MFC r313906:
iwi, ral, zyd: fix possible use-after-free.
Modified:
stable/11/sys/dev/iwi/if_iwi.c
stable/11/sys/dev/ral/rt2661.c
stable/11/sys/dev/usb/wlan/if_zyd.c
Directory Properties:
stable/11/ (props changed)
Modified: stable/11/sys/dev/iwi/if_iwi.c
==============================================================================
--- stable/11/sys/dev/iwi/if_iwi.c Fri Feb 24 20:51:39 2017 (r314221)
+++ stable/11/sys/dev/iwi/if_iwi.c Fri Feb 24 21:19:40 2017 (r314222)
@@ -1979,9 +1979,9 @@ iwi_start(struct iwi_softc *sc)
}
ni = (struct ieee80211_node *) m->m_pkthdr.rcvif;
if (iwi_tx_start(sc, m, ni, ac) != 0) {
- ieee80211_free_node(ni);
if_inc_counter(ni->ni_vap->iv_ifp,
IFCOUNTER_OERRORS, 1);
+ ieee80211_free_node(ni);
break;
}
sc->sc_tx_timer = 5;
Modified: stable/11/sys/dev/ral/rt2661.c
==============================================================================
--- stable/11/sys/dev/ral/rt2661.c Fri Feb 24 20:51:39 2017 (r314221)
+++ stable/11/sys/dev/ral/rt2661.c Fri Feb 24 21:19:40 2017 (r314222)
@@ -1619,9 +1619,9 @@ rt2661_start(struct rt2661_softc *sc)
}
ni = (struct ieee80211_node *) m->m_pkthdr.rcvif;
if (rt2661_tx_data(sc, m, ni, ac) != 0) {
- ieee80211_free_node(ni);
if_inc_counter(ni->ni_vap->iv_ifp,
IFCOUNTER_OERRORS, 1);
+ ieee80211_free_node(ni);
break;
}
sc->sc_tx_timer = 5;
Modified: stable/11/sys/dev/usb/wlan/if_zyd.c
==============================================================================
--- stable/11/sys/dev/usb/wlan/if_zyd.c Fri Feb 24 20:51:39 2017 (r314221)
+++ stable/11/sys/dev/usb/wlan/if_zyd.c Fri Feb 24 21:19:40 2017 (r314222)
@@ -2570,10 +2570,10 @@ zyd_start(struct zyd_softc *sc)
while (sc->tx_nfree > 0 && (m = mbufq_dequeue(&sc->sc_snd)) != NULL) {
ni = (struct ieee80211_node *)m->m_pkthdr.rcvif;
if (zyd_tx_start(sc, m, ni) != 0) {
- ieee80211_free_node(ni);
m_freem(m);
if_inc_counter(ni->ni_vap->iv_ifp,
IFCOUNTER_OERRORS, 1);
+ ieee80211_free_node(ni);
break;
}
}
More information about the svn-src-stable
mailing list