summaryrefslogtreecommitdiff
path: root/sys/net
diff options
context:
space:
mode:
authormvs <mvs@cvs.openbsd.org>2021-05-02 14:22:06 +0000
committermvs <mvs@cvs.openbsd.org>2021-05-02 14:22:06 +0000
commitb080a695753450a848661a34d7c969d8ce50ee95 (patch)
treed72f167c617904a6d46a186a5edbc10cf84a08c1 /sys/net
parent95a251fcd47b8c5fc1307832db084d23baa71d56 (diff)
Do soreserve() before `kp' allocation. This simplifies error path. The
same was done for route_attach(). Also do soisconnected() after `kp' is fully initialized. This chair movement affects nothing for PF_KEY sockets but makes code more consistent. ok bluhm@ mpi@
Diffstat (limited to 'sys/net')
-rw-r--r--sys/net/pfkeyv2.c18
1 files changed, 7 insertions, 11 deletions
diff --git a/sys/net/pfkeyv2.c b/sys/net/pfkeyv2.c
index a757bf04d8e..e03c899eaa7 100644
--- a/sys/net/pfkeyv2.c
+++ b/sys/net/pfkeyv2.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pfkeyv2.c,v 1.208 2020/12/14 20:20:06 tobhe Exp $ */
+/* $OpenBSD: pfkeyv2.c,v 1.209 2021/05/02 14:22:05 mvs Exp $ */
/*
* @(#)COPYRIGHT 1.1 (NRL) 17 January 1995
@@ -269,24 +269,20 @@ pfkeyv2_attach(struct socket *so, int proto)
if ((so->so_state & SS_PRIV) == 0)
return EACCES;
- kp = pool_get(&pkpcb_pool, PR_WAITOK|PR_ZERO);
- so->so_pcb = kp;
- refcnt_init(&kp->kcb_refcnt);
-
error = soreserve(so, PFKEYSNDQ, PFKEYRCVQ);
- if (error) {
- pool_put(&pkpcb_pool, kp);
+ if (error)
return (error);
- }
+ kp = pool_get(&pkpcb_pool, PR_WAITOK|PR_ZERO);
+ so->so_pcb = kp;
+ refcnt_init(&kp->kcb_refcnt);
kp->kcb_socket = so;
+ kp->kcb_pid = curproc->p_p->ps_pid;
+ kp->kcb_rdomain = rtable_l2(curproc->p_p->ps_rtableid);
so->so_options |= SO_USELOOPBACK;
soisconnected(so);
- kp->kcb_pid = curproc->p_p->ps_pid;
- kp->kcb_rdomain = rtable_l2(curproc->p_p->ps_rtableid);
-
rw_enter(&pkptable.pkp_lk, RW_WRITE);
SRPL_INSERT_HEAD_LOCKED(&pkptable.pkp_rc, &pkptable.pkp_list, kp, kcb_list);
rw_exit(&pkptable.pkp_lk);