svn commit: r343627 - in head/sys: kern sys
Gleb Smirnoff
glebius at FreeBSD.org
Thu Jan 31 22:37:29 UTC 2019
Author: glebius
Date: Thu Jan 31 22:37:28 2019
New Revision: 343627
URL: https://svnweb.freebsd.org/changeset/base/343627
Log:
Add new m_ext type for data for M_NOFREE mbufs, which doesn't actually do
anything except several assertions. This type is going to be used for
temporary on stack mbufs, that point into data in receive ring of a NIC,
that shall not be freed. Such mbuf can not be stored or reallocated, its
life time is current context.
Modified:
head/sys/kern/kern_mbuf.c
head/sys/sys/mbuf.h
Modified: head/sys/kern/kern_mbuf.c
==============================================================================
--- head/sys/kern/kern_mbuf.c Thu Jan 31 22:27:39 2019 (r343626)
+++ head/sys/kern/kern_mbuf.c Thu Jan 31 22:37:28 2019 (r343627)
@@ -847,7 +847,8 @@ mb_free_ext(struct mbuf *m)
*/
if (m->m_flags & M_NOFREE) {
freembuf = 0;
- KASSERT(m->m_ext.ext_type == EXT_EXTREF,
+ KASSERT(m->m_ext.ext_type == EXT_EXTREF ||
+ m->m_ext.ext_type == EXT_RXRING,
("%s: no-free mbuf %p has wrong type", __func__, m));
} else
freembuf = 1;
@@ -890,6 +891,10 @@ mb_free_ext(struct mbuf *m)
KASSERT(m->m_ext.ext_free != NULL,
("%s: ext_free not set", __func__));
m->m_ext.ext_free(m);
+ break;
+ case EXT_RXRING:
+ KASSERT(m->m_ext.ext_free == NULL,
+ ("%s: ext_free is set", __func__));
break;
default:
KASSERT(m->m_ext.ext_type == 0,
Modified: head/sys/sys/mbuf.h
==============================================================================
--- head/sys/sys/mbuf.h Thu Jan 31 22:27:39 2019 (r343626)
+++ head/sys/sys/mbuf.h Thu Jan 31 22:37:28 2019 (r343627)
@@ -443,6 +443,7 @@ struct mbuf {
#define EXT_JUMBO16 5 /* jumbo cluster 16184 bytes */
#define EXT_PACKET 6 /* mbuf+cluster from packet zone */
#define EXT_MBUF 7 /* external mbuf reference */
+#define EXT_RXRING 8 /* data in NIC receive ring */
#define EXT_VENDOR1 224 /* for vendor-internal use */
#define EXT_VENDOR2 225 /* for vendor-internal use */
More information about the svn-src-all
mailing list