Page MenuHomeFreeBSD

Fix an infinite loop in tcp_tw_2msl_scan() when an INP_TIMEWAIT inp has been destroyed before its tcptw with INVARIANTS undefined.
ClosedPublic

Authored by jch on Sep 7 2017, 3:12 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Dec 3, 1:01 AM
Unknown Object (File)
Sun, Nov 30, 5:31 PM
Unknown Object (File)
Thu, Nov 27, 4:17 AM
Unknown Object (File)
Fri, Nov 21, 3:14 AM
Unknown Object (File)
Fri, Nov 21, 3:09 AM
Unknown Object (File)
Fri, Nov 21, 3:08 AM
Unknown Object (File)
Fri, Nov 21, 3:07 AM
Unknown Object (File)
Nov 3 2025, 2:13 AM

Details

Summary

Fix an infinite loop in tcp_tw_2msl_scan() when an INP_TIMEWAIT inp has been destroyed before its tcptw wint INVARIANTS undefined.

This is a symmetric change of r307551:

A INP_TIMEWAIT inp should not be destroyed before its tcptw, and INVARIANTS
will catch this case. If INVARIANTS is undefined it will emit a log(LOG_ERR)
and avoid a hard to debug infinite loop in tcp_tw_2msl_scan().

Reported by: Ben Rubson, hselasky
Submitted by: hselasky
Tested by: Ben Rubson, jch
MFC after: 1 week
Sponsored by: Verisign, inc

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 11413
Build 11773: arc lint + arc unit