summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornp <np@FreeBSD.org>2013-08-29 08:07:35 +0000
committernp <np@FreeBSD.org>2013-08-29 08:07:35 +0000
commitaf4b94562133edf0728e28f2a0ae95ebb8f3c2b5 (patch)
tree876661514ea0aef6a1496c8cfc558fb95438f910
parenta52be00b7f7e336eb3883b40cdc6cf73571f0c4e (diff)
downloadFreeBSD-src-af4b94562133edf0728e28f2a0ae95ebb8f3c2b5.zip
FreeBSD-src-af4b94562133edf0728e28f2a0ae95ebb8f3c2b5.tar.gz
Merge r254736 from user/np/cxl_tuning.
Don't leak tags when M_NOFREE | M_PKTHDR mbufs are freed. Reviewed by: andre
-rw-r--r--sys/sys/mbuf.h26
1 files changed, 14 insertions, 12 deletions
diff --git a/sys/sys/mbuf.h b/sys/sys/mbuf.h
index 7e8f427..930a322 100644
--- a/sys/sys/mbuf.h
+++ b/sys/sys/mbuf.h
@@ -646,18 +646,6 @@ m_getcl(int how, short type, int flags)
return (uma_zalloc_arg(zone_pack, &args, how));
}
-static __inline struct mbuf *
-m_free(struct mbuf *m)
-{
- struct mbuf *n = m->m_next;
-
- if (m->m_flags & M_EXT)
- mb_free_ext(m);
- else if ((m->m_flags & M_NOFREE) == 0)
- uma_zfree(zone_mbuf, m);
- return (n);
-}
-
static __inline void
m_clget(struct mbuf *m, int how)
{
@@ -1124,6 +1112,20 @@ m_tag_find(struct mbuf *m, int type, struct m_tag *start)
m_tag_locate(m, MTAG_ABI_COMPAT, type, start));
}
+static __inline struct mbuf *
+m_free(struct mbuf *m)
+{
+ struct mbuf *n = m->m_next;
+
+ if ((m->m_flags & (M_PKTHDR|M_NOFREE)) == (M_PKTHDR|M_NOFREE))
+ m_tag_delete_chain(m, NULL);
+ if (m->m_flags & M_EXT)
+ mb_free_ext(m);
+ else if ((m->m_flags & M_NOFREE) == 0)
+ uma_zfree(zone_mbuf, m);
+ return (n);
+}
+
static int inline
rt_m_getfib(struct mbuf *m)
{
OpenPOWER on IntegriCloud