Page MenuHomeFreeBSD

pf: Simplify rule actions logic
ClosedPublic

Authored by vegeta_tuxpowered.net on Jul 12 2023, 4:54 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Sep 6, 3:18 AM
Unknown Object (File)
Thu, Aug 29, 10:29 PM
Unknown Object (File)
Tue, Aug 20, 9:29 PM
Unknown Object (File)
Mon, Aug 19, 7:22 AM
Unknown Object (File)
Aug 4 2024, 4:02 AM
Unknown Object (File)
Jun 27 2024, 5:20 PM
Unknown Object (File)
Jun 15 2024, 8:43 PM
Unknown Object (File)
Jun 3 2024, 1:17 PM

Details

Summary

Actions applied to a processed packet come in case of stateless firewalling from a rule or in case of statefull firewalling from a state. The state obtains the actions from a rule when it is created by a rule or by pfsync. The logic for deciding if actions come from a rule or a state is spread across many places in pf.

There already is struct pf_rule_actions in struct pf_pdesc and thus it can be used as a central place for storing actions and their parameters. OpenBSD does something similar: they also store the actions in struct pf_pdesc and have no variables in pf_test() but they use separate variables instead of a structure. By using struct pf_rule_actions we can simplify the code even further. Applying of actions is done *only* in pf_rule_to_actions() no matter if for the legacy scrub rules or for the normal match / pass rules. The logic of choosing if rule or state actions are used is applied only once in pf_test() by copying the whole struct.

Sponsored by: InnoGames GmbH

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

"5 files changed, 139 insertions(+), 265 deletions(-)" is pretty nice.

This revision is now accepted and ready to land.Jul 13 2023, 7:36 AM
This revision was automatically updated to reflect the committed changes.