Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 5 Jul 2021 11:33:47 GMT
From:      Mateusz Guzik <mjg@FreeBSD.org>
To:        src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org
Subject:   git: 3ec1b75a0ddd - stable/13 - pf: add pf_release_staten and use it in pf_unlink_state
Message-ID:  <202107051133.165BXlNf017952@gitrepo.freebsd.org>

next in thread | raw e-mail | index | archive | help
The branch stable/13 has been updated by mjg:

URL: https://cgit.FreeBSD.org/src/commit/?id=3ec1b75a0ddd043abc0bf726127e84318de41699

commit 3ec1b75a0ddd043abc0bf726127e84318de41699
Author:     Mateusz Guzik <mjg@FreeBSD.org>
AuthorDate: 2021-06-28 12:18:43 +0000
Commit:     Mateusz Guzik <mjg@FreeBSD.org>
CommitDate: 2021-07-05 11:32:10 +0000

    pf: add pf_release_staten and use it in pf_unlink_state
    
    Saves one atomic op.
    
    Reviewed by:    kp
    Sponsored by:   Rubicon Communications, LLC ("Netgate")
    
    (cherry picked from commit d09388d013300fc4aa1ee1a6bc24260cd400aff3)
---
 sys/net/pfvar.h     | 11 +++++++++++
 sys/netpfil/pf/pf.c |  7 ++-----
 2 files changed, 13 insertions(+), 5 deletions(-)

diff --git a/sys/net/pfvar.h b/sys/net/pfvar.h
index 0d23607a168a..9e6dad5ca2ac 100644
--- a/sys/net/pfvar.h
+++ b/sys/net/pfvar.h
@@ -1507,6 +1507,17 @@ pf_release_state(struct pf_state *s)
 		return (0);
 }
 
+static __inline int
+pf_release_staten(struct pf_state *s, u_int n)
+{
+
+	if (refcount_releasen(&s->refs, n)) {
+		pf_free_state(s);
+		return (1);
+	} else
+		return (0);
+}
+
 extern struct pf_state		*pf_find_state_byid(uint64_t, uint32_t);
 extern struct pf_state		*pf_find_state_all(struct pf_state_key_cmp *,
 				    u_int, int *);
diff --git a/sys/netpfil/pf/pf.c b/sys/netpfil/pf/pf.c
index 1b8181b7e1cf..8e0c51238f32 100644
--- a/sys/netpfil/pf/pf.c
+++ b/sys/netpfil/pf/pf.c
@@ -1732,11 +1732,8 @@ pf_unlink_state(struct pf_state *s, u_int flags)
 	PF_HASHROW_UNLOCK(ih);
 
 	pf_detach_state(s);
-	/* pf_state_insert() initialises refs to 2, so we can never release the
-	 * last reference here, only in pf_release_state(). */
-	(void)refcount_release(&s->refs);
-
-	return (pf_release_state(s));
+	/* pf_state_insert() initialises refs to 2 */
+	return (pf_release_staten(s, 2));
 }
 
 void



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202107051133.165BXlNf017952>