aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGleb Smirnoff <glebius@FreeBSD.org>2026-04-12 17:26:12 +0000
committerGleb Smirnoff <glebius@FreeBSD.org>2026-04-12 17:26:12 +0000
commit87ef3067acbddbf85f0bdef6d53bdde2b51cbc50 (patch)
tree8a6b49abd8328e60629ac328012c168a8c0e29af
parent9992eb435829a910a2a25c564bf8d2ad7c6557b0 (diff)
tcp lro: use hashalloc(9)
Reviewed by: tuexen, rrs Differential Revision: https://reviews.freebsd.org/D56177
-rw-r--r--sys/netinet/tcp_lro.c26
1 files changed, 20 insertions, 6 deletions
diff --git a/sys/netinet/tcp_lro.c b/sys/netinet/tcp_lro.c
index 59358db6ecf9..06280bce2279 100644
--- a/sys/netinet/tcp_lro.c
+++ b/sys/netinet/tcp_lro.c
@@ -44,6 +44,7 @@
#include <sys/socketvar.h>
#include <sys/sockbuf.h>
#include <sys/sysctl.h>
+#include <sys/hash.h>
#include <net/if.h>
#include <net/if_var.h>
@@ -190,13 +191,19 @@ tcp_lro_init_args(struct lro_ctrl *lc, struct ifnet *ifp,
LIST_INIT(&lc->lro_free);
LIST_INIT(&lc->lro_active);
- /* create hash table to accelerate entry lookup */
- lc->lro_hash = phashinit_flags(lro_entries, M_LRO, &lc->lro_hashsz,
- HASH_NOWAIT);
+ /* Create hash table to accelerate entry lookup. */
+ struct hashalloc_args ha = {
+ .size = lro_entries,
+ .mtype = M_LRO,
+ .mflags = M_NOWAIT,
+ .type = HASH_TYPE_PRIME,
+ };
+ lc->lro_hash = hashalloc(&ha);
if (lc->lro_hash == NULL) {
memset(lc, 0, sizeof(*lc));
return (ENOMEM);
}
+ lc->lro_hashsz = ha.size;
/* compute size to allocate */
size = (lro_mbufs * sizeof(struct lro_mbuf_sort)) +
@@ -206,7 +213,11 @@ tcp_lro_init_args(struct lro_ctrl *lc, struct ifnet *ifp,
/* check for out of memory */
if (lc->lro_mbuf_data == NULL) {
- free(lc->lro_hash, M_LRO);
+ struct hashalloc_args ha = {
+ .size = lc->lro_hashsz,
+ .mtype = M_LRO,
+ };
+ hashfree(lc->lro_hash, &ha);
memset(lc, 0, sizeof(*lc));
return (ENOMEM);
}
@@ -503,8 +514,11 @@ tcp_lro_free(struct lro_ctrl *lc)
lro_free_mbuf_chain(le->m_head);
}
- /* free hash table */
- free(lc->lro_hash, M_LRO);
+ struct hashalloc_args ha = {
+ .size = lc->lro_hashsz,
+ .mtype = M_LRO,
+ };
+ hashfree(lc->lro_hash, &ha);
lc->lro_hash = NULL;
lc->lro_hashsz = 0;