Page MenuHomeFreeBSD

pf: allow scrub rules without fragment reassemble
ClosedPublic

Authored by kp on Nov 22 2022, 3:27 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 17, 7:18 PM
Unknown Object (File)
Mon, Jan 13, 7:41 PM
Unknown Object (File)
Thu, Jan 9, 6:42 PM
Unknown Object (File)
Thu, Jan 9, 6:23 PM
Unknown Object (File)
Thu, Jan 9, 7:16 AM
Unknown Object (File)
Dec 20 2024, 4:46 PM
Unknown Object (File)
Dec 14 2024, 12:32 AM
Unknown Object (File)
Dec 5 2024, 11:31 PM

Details

Summary

scrub rules have defaulted to handling fragments for a long time, but
since we removed "fragment crop" and "fragment drop-ovl" in 64b3b4d611
this has become less obvious and more expensive ("reassemble" being the
more expensive option, even if it's the one the vast majority of users
should be using).

Extent the 'scrub' syntax to allow fragment reassembly to be disabled,
while retaining the other scrub behaviour (e.g. TTL changes, random-id,
..) using 'scrub fragment no reassemble'.

Sponsored by: Rubicon Communications, LLC ("Netgate")

Diff Detail

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

Event Timeline

kp requested review of this revision.Nov 22 2022, 3:27 PM

that seems like a POLA violation which will go unnoticed

how about instead requiring a policy? people will complain about configs which no longer autoload, but that's better than behavior changing without easily visible side effects.

that's assuming the change is worth it to begin with

In D37459#851798, @mjg wrote:

that seems like a POLA violation which will go unnoticed

how about instead requiring a policy? people will complain about configs which no longer autoload, but that's better than behavior changing without easily visible side effects.

that's assuming the change is worth it to begin with

The way it's currently documented is a bit ambiguous, but it could certainly be read as documenting the previous behaviour.
Perhaps the way to go is to support a 'scrub fragment noreassemble' to turn reassembly off, leaving the previous behaviour intact, but allowing users to opt out of reassembly while preserving the other scrub actions.

I'll update this patch to do that instead.

kp retitled this revision from pf: do not default "fragment reassemble" to on to pf: allow scrub rules without fragment reassemble.
kp edited the summary of this revision. (Show Details)
This revision was not accepted when it landed; it landed in state Needs Review.Nov 28 2022, 7:23 PM
This revision was automatically updated to reflect the committed changes.