aboutsummaryrefslogtreecommitdiff
path: root/sys/dev/iwn
diff options
context:
space:
mode:
authorAndriy Voskoboinyk <avos@FreeBSD.org>2017-03-26 17:59:51 +0000
committerAndriy Voskoboinyk <avos@FreeBSD.org>2017-03-26 17:59:51 +0000
commit60ff4558eebd1a3693f28e2d4fb46e796b886e8e (patch)
treeb47ee9c7b429ca1fc8a9a2d00b419f740d93a3c0 /sys/dev/iwn
parentabc58cc4d99045343e117874c28a25fb7168f969 (diff)
Notes
Diffstat (limited to 'sys/dev/iwn')
-rw-r--r--sys/dev/iwn/if_iwn.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/sys/dev/iwn/if_iwn.c b/sys/dev/iwn/if_iwn.c
index a9bed7ab380d6..e6bdece8140fc 100644
--- a/sys/dev/iwn/if_iwn.c
+++ b/sys/dev/iwn/if_iwn.c
@@ -4739,9 +4739,19 @@ iwn_tx_cmd(struct iwn_softc *sc, struct mbuf *m, struct ieee80211_node *ni,
error = bus_dmamap_load_mbuf_sg(ring->data_dmat, data->map, m,
segs, &nsegs, BUS_DMA_NOWAIT);
if (error != 0) {
+ /* XXX fix this */
+ /*
+ * NB: Do not return error;
+ * original mbuf does not exist anymore.
+ */
device_printf(sc->sc_dev,
- "%s: can't map mbuf (error %d)\n", __func__, error);
- return error;
+ "%s: can't map mbuf (error %d)\n",
+ __func__, error);
+ if_inc_counter(ni->ni_vap->iv_ifp,
+ IFCOUNTER_OERRORS, 1);
+ ieee80211_free_node(ni);
+ m_freem(m);
+ return 0;
}
}