Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/kern Put the "free" functions close to one another. No f...
details: https://anonhg.NetBSD.org/src/rev/d778f588c96b
branches: trunk
changeset: 321931:d778f588c96b
user: maxv <maxv%NetBSD.org@localhost>
date: Tue Apr 10 15:29:46 2018 +0000
description:
Put the "free" functions close to one another. No functional change.
diffstat:
sys/kern/uipc_mbuf.c | 142 +++++++++++++++++++++++++-------------------------
1 files changed, 71 insertions(+), 71 deletions(-)
diffs (170 lines):
diff -r 6adad9bec30f -r d778f588c96b sys/kern/uipc_mbuf.c
--- a/sys/kern/uipc_mbuf.c Tue Apr 10 15:27:35 2018 +0000
+++ b/sys/kern/uipc_mbuf.c Tue Apr 10 15:29:46 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: uipc_mbuf.c,v 1.185 2018/04/10 15:27:35 maxv Exp $ */
+/* $NetBSD: uipc_mbuf.c,v 1.186 2018/04/10 15:29:46 maxv Exp $ */
/*
* Copyright (c) 1999, 2001 The NetBSD Foundation, Inc.
@@ -62,7 +62,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uipc_mbuf.c,v 1.185 2018/04/10 15:27:35 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uipc_mbuf.c,v 1.186 2018/04/10 15:29:46 maxv Exp $");
#ifdef _KERNEL_OPT
#include "opt_mbuftrace.h"
@@ -1716,75 +1716,6 @@
return NULL;
}
-/*
- * Release a reference to the mbuf external storage.
- *
- * => free the mbuf m itself as well.
- */
-static void
-m_ext_free(struct mbuf *m)
-{
- const bool embedded = MEXT_ISEMBEDDED(m);
- bool dofree = true;
- u_int refcnt;
-
- KASSERT((m->m_flags & M_EXT) != 0);
- KASSERT(MEXT_ISEMBEDDED(m->m_ext_ref));
- KASSERT((m->m_ext_ref->m_flags & M_EXT) != 0);
- KASSERT((m->m_flags & M_EXT_CLUSTER) ==
- (m->m_ext_ref->m_flags & M_EXT_CLUSTER));
-
- if (__predict_false(m->m_type == MT_FREE)) {
- panic("mbuf %p already freed", m);
- }
-
- if (__predict_true(m->m_ext.ext_refcnt == 1)) {
- refcnt = m->m_ext.ext_refcnt = 0;
- } else {
- refcnt = atomic_dec_uint_nv(&m->m_ext.ext_refcnt);
- }
-
- if (refcnt > 0) {
- if (embedded) {
- /*
- * other mbuf's m_ext_ref still points to us.
- */
- dofree = false;
- } else {
- m->m_ext_ref = m;
- }
- } else {
- /*
- * dropping the last reference
- */
- if (!embedded) {
- m->m_ext.ext_refcnt++; /* XXX */
- m_ext_free(m->m_ext_ref);
- m->m_ext_ref = m;
- } else if ((m->m_flags & M_EXT_CLUSTER) != 0) {
- pool_cache_put_paddr((struct pool_cache *)
- m->m_ext.ext_arg,
- m->m_ext.ext_buf, m->m_ext.ext_paddr);
- } else if (m->m_ext.ext_free) {
- (*m->m_ext.ext_free)(m,
- m->m_ext.ext_buf, m->m_ext.ext_size,
- m->m_ext.ext_arg);
- /*
- * 'm' is already freed by the ext_free callback.
- */
- dofree = false;
- } else {
- free(m->m_ext.ext_buf, m->m_ext.ext_type);
- }
- }
-
- if (dofree) {
- m->m_type = MT_FREE;
- m->m_data = NULL;
- pool_cache_put(mb_cache, m);
- }
-}
-
#if defined(DDB)
void
m_print(const struct mbuf *m, const char *modif, void (*pr)(const char *, ...))
@@ -1970,6 +1901,75 @@
#endif /* defined(MBUFTRACE) */
/*
+ * Release a reference to the mbuf external storage.
+ *
+ * => free the mbuf m itself as well.
+ */
+static void
+m_ext_free(struct mbuf *m)
+{
+ const bool embedded = MEXT_ISEMBEDDED(m);
+ bool dofree = true;
+ u_int refcnt;
+
+ KASSERT((m->m_flags & M_EXT) != 0);
+ KASSERT(MEXT_ISEMBEDDED(m->m_ext_ref));
+ KASSERT((m->m_ext_ref->m_flags & M_EXT) != 0);
+ KASSERT((m->m_flags & M_EXT_CLUSTER) ==
+ (m->m_ext_ref->m_flags & M_EXT_CLUSTER));
+
+ if (__predict_false(m->m_type == MT_FREE)) {
+ panic("mbuf %p already freed", m);
+ }
+
+ if (__predict_true(m->m_ext.ext_refcnt == 1)) {
+ refcnt = m->m_ext.ext_refcnt = 0;
+ } else {
+ refcnt = atomic_dec_uint_nv(&m->m_ext.ext_refcnt);
+ }
+
+ if (refcnt > 0) {
+ if (embedded) {
+ /*
+ * other mbuf's m_ext_ref still points to us.
+ */
+ dofree = false;
+ } else {
+ m->m_ext_ref = m;
+ }
+ } else {
+ /*
+ * dropping the last reference
+ */
+ if (!embedded) {
+ m->m_ext.ext_refcnt++; /* XXX */
+ m_ext_free(m->m_ext_ref);
+ m->m_ext_ref = m;
+ } else if ((m->m_flags & M_EXT_CLUSTER) != 0) {
+ pool_cache_put_paddr((struct pool_cache *)
+ m->m_ext.ext_arg,
+ m->m_ext.ext_buf, m->m_ext.ext_paddr);
+ } else if (m->m_ext.ext_free) {
+ (*m->m_ext.ext_free)(m,
+ m->m_ext.ext_buf, m->m_ext.ext_size,
+ m->m_ext.ext_arg);
+ /*
+ * 'm' is already freed by the ext_free callback.
+ */
+ dofree = false;
+ } else {
+ free(m->m_ext.ext_buf, m->m_ext.ext_type);
+ }
+ }
+
+ if (dofree) {
+ m->m_type = MT_FREE;
+ m->m_data = NULL;
+ pool_cache_put(mb_cache, m);
+ }
+}
+
+/*
* Free a single mbuf and associated external storage. Return the
* successor, if any.
*/
Home |
Main Index |
Thread Index |
Old Index