Page MenuHomeFreeBSD

inpcb: Remove a PCB from its LB group upon a subsequent error
ClosedPublic

Authored by markj on Oct 17 2022, 8:39 PM.
Tags
None
Referenced Files
F106943226: D37027.diff
Tue, Jan 7, 8:14 PM
F106943187: D37027.diff
Tue, Jan 7, 8:13 PM
Unknown Object (File)
Sun, Dec 15, 1:50 AM
Unknown Object (File)
Wed, Dec 11, 9:35 PM
Unknown Object (File)
Nov 30 2024, 8:16 PM
Unknown Object (File)
Nov 19 2024, 9:41 AM
Unknown Object (File)
Nov 8 2024, 12:52 PM
Unknown Object (File)
Nov 8 2024, 12:05 PM

Details

Summary

If a memory allocation failure causes bind to fail, we should take the
inpcb back out of its LB group since it's not prepared to handle
connections.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 47864
Build 44751: arc lint + arc unit

Event Timeline

markj requested review of this revision.Oct 17 2022, 8:39 PM

In the context of bind(2) we definitely can M_WAITOK. At what conditions is M_NOWAIT required?

This revision is now accepted and ready to land.Oct 18 2022, 4:31 AM

In the context of bind(2) we definitely can M_WAITOK. At what conditions is M_NOWAIT required?

The inpcb mutex forces us to use M_NOWAIT here. Maybe those structures should be embedded in the port hash table instead. Though, right now we consume ~3MB per VNET jail for M_PCB mallocs.