Page MenuHomeFreeBSD

MAC/do: Allocate/deallocate rules as a whole
ClosedPublic

Authored by olce on Nov 15 2024, 5:06 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 6, 6:42 AM
Unknown Object (File)
Mon, Jan 6, 6:20 AM
Unknown Object (File)
Sun, Jan 5, 9:39 AM
Unknown Object (File)
Fri, Dec 27, 11:23 AM
Unknown Object (File)
Sat, Dec 14, 9:50 PM
Unknown Object (File)
Nov 24 2024, 11:27 AM
Unknown Object (File)
Nov 23 2024, 9:38 AM
Unknown Object (File)
Nov 21 2024, 3:04 AM

Details

Summary

This revision is part of a series. Click on the Stack tab below to see the context.
This series has also been squeezed into D47633 to provide an overall view.

Commit message:
Stop recycling the top-level 'struct rules' already assigned to jails.
This considerably simplifies the code, as now changing rules on a jail
amounts to just changing the OSD pointer.

Also, this is to increase potential concurrency in preparation for
incoming fixes about enforcing rules. Indeed, keeping these changes
relatively simple requires rules assigned to a jail to slightly outlive
resetting them, which is most easily done by just operating on pointers
to separate rules objects.

The (negligible) price to pay for this change is that setting rules on
a jail now systematically needs to allocate memory (and also that the
OSD slot needs to be accessed twice, once to get the old rules to free
them and another one to set the rules, which was already the case before
when memory had to be allocated).

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

olce requested review of this revision.Nov 15 2024, 5:06 PM

I can see now the comment from D47598 is now useless :D

This revision is now accepted and ready to land.Nov 19 2024, 7:58 AM

I can see now the comment from D47598 is now useless :D

Well, not completely if my answer there can convince you that casting to void is actually useful (to humans).

This revision was automatically updated to reflect the committed changes.