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)
Mon, Nov 3, 2:13 AM
Unknown Object (File)
Sun, Nov 2, 3:28 AM
Unknown Object (File)
Fri, Oct 31, 6:50 AM
Unknown Object (File)
Fri, Oct 31, 6:50 AM
Unknown Object (File)
Fri, Oct 31, 6:50 AM
Unknown Object (File)
Fri, Oct 31, 1:29 AM
Unknown Object (File)
Thu, Oct 30, 12:49 AM
Unknown Object (File)
Wed, Oct 29, 4:46 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