aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Johnston <markj@FreeBSD.org>2026-04-21 14:31:18 +0000
committerMark Johnston <markj@FreeBSD.org>2026-04-21 16:13:19 +0000
commit69e8d8b49d4bd889a42ba354f290f05d88bcd4b1 (patch)
treedea90aac66819fa7fd60432f4e1a01e02ace14e4
parent30b7621d46cc06053c0cb40bb691fbcecbfdab7f (diff)
tests/sys/netinet/tcp_hpts: Make a socket available in mock inpcbs
After commit 9b76228006d8, tcp_hptsi() dereferences inp_socket in order to get the inpcb's VNET. This means that mock inpcbs created by the HPTS test fixture must set inp_socket. Also set the current VNET there; previously, it was NULL, and this was not noticed since VNET_DEBUG is disabled even in debug kernels. Fixes: 9b76228006d8 ("inpcb: retire inp_vnet")
-rw-r--r--sys/netinet/tcp_hpts_test.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/sys/netinet/tcp_hpts_test.c b/sys/netinet/tcp_hpts_test.c
index ea088f5c71cf..a664e9fafcc3 100644
--- a/sys/netinet/tcp_hpts_test.c
+++ b/sys/netinet/tcp_hpts_test.c
@@ -35,6 +35,7 @@
#include <sys/mutex.h>
#include <sys/refcount.h>
#include <sys/socket.h>
+#include <sys/socketvar.h>
#include <sys/sysctl.h>
#include <sys/systm.h>
@@ -369,9 +370,15 @@ static struct tcpcb *
test_hpts_create_tcpcb(struct ktest_test_context *ctx, struct tcp_hptsi *pace)
{
struct tcpcb *tp;
+ struct socket *so;
tp = malloc(sizeof(struct tcpcb), M_TCPHPTS, M_WAITOK | M_ZERO);
if (tp) {
+ so = malloc(sizeof(struct socket), M_TCPHPTS,
+ M_WAITOK | M_ZERO);
+ so->so_vnet = curvnet;
+ tp->t_inpcb.inp_socket = so;
+
rw_init_flags(&tp->t_inpcb.inp_lock, "test-inp",
RW_RECURSE | RW_DUPOK);
refcount_init(&tp->t_inpcb.inp_refcount, 1);
@@ -399,6 +406,7 @@ test_hpts_free_tcpcb(struct tcpcb *tp)
return;
INP_LOCK_DESTROY(&tp->t_inpcb);
+ free(tp->t_inpcb.inp_socket, M_TCPHPTS);
free(tp, M_TCPHPTS);
}