mirror of
https://github.com/opnsense/src.git
synced 2026-05-28 04:12:45 -04:00
toe: Read-lock the inp in toe_4tuple_check().
tcp_twcheck now expects a read lock on the inp for the SYN case
instead of a write lock.
Reviewed by: np
Fixes: 1db08fbe3f tcp_input: always request read-locking of PCB for any pure SYN segment.
Sponsored by: Chelsio Communications
Differential Revision: https://reviews.freebsd.org/D30782
This commit is contained in:
parent
abc273a290
commit
a7f6c6fd94
1 changed files with 4 additions and 4 deletions
|
|
@ -390,19 +390,19 @@ toe_4tuple_check(struct in_conninfo *inc, struct tcphdr *th, struct ifnet *ifp)
|
|||
if (inc->inc_flags & INC_ISIPV6) {
|
||||
inp = in6_pcblookup(&V_tcbinfo, &inc->inc6_faddr,
|
||||
inc->inc_fport, &inc->inc6_laddr, inc->inc_lport,
|
||||
INPLOOKUP_WLOCKPCB, ifp);
|
||||
INPLOOKUP_RLOCKPCB, ifp);
|
||||
} else {
|
||||
inp = in_pcblookup(&V_tcbinfo, inc->inc_faddr, inc->inc_fport,
|
||||
inc->inc_laddr, inc->inc_lport, INPLOOKUP_WLOCKPCB, ifp);
|
||||
inc->inc_laddr, inc->inc_lport, INPLOOKUP_RLOCKPCB, ifp);
|
||||
}
|
||||
if (inp != NULL) {
|
||||
INP_WLOCK_ASSERT(inp);
|
||||
INP_RLOCK_ASSERT(inp);
|
||||
|
||||
if ((inp->inp_flags & INP_TIMEWAIT) && th != NULL) {
|
||||
if (!tcp_twcheck(inp, NULL, th, NULL, 0))
|
||||
return (EADDRINUSE);
|
||||
} else {
|
||||
INP_WUNLOCK(inp);
|
||||
INP_RUNLOCK(inp);
|
||||
return (EADDRINUSE);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in a new issue