Page MenuHomeFreeBSD

libjail: extend struct handlers to included MAC labels
ClosedPublic

Authored by kevans on Nov 27 2025, 6:38 PM.
Tags
None
Referenced Files
F159894181: D53960.diff
Fri, Jun 19, 5:19 AM
Unknown Object (File)
Sun, May 31, 9:40 PM
Unknown Object (File)
Sun, May 31, 9:32 PM
Unknown Object (File)
Sun, May 31, 5:41 PM
Unknown Object (File)
Sat, May 30, 10:45 AM
Unknown Object (File)
May 16 2026, 4:00 AM
Unknown Object (File)
May 16 2026, 4:00 AM
Unknown Object (File)
May 16 2026, 3:58 AM
Subscribers

Details

Summary

MAC label handling is a little special; to avoid being too disruptive,
we allocate a mac_t * here for the value so that we can mac_prepare()
or mac_from_text() into. As a result, we need:

  • A custom free() handler to avoid leaking the *jp_value
  • A custom jailparam_get() handler to mac_prepare() the mac_t and populate the iove properly, so that the kernel doesn't have to do something funky like copyin, dereference, copyin again.
  • A custom jailparam_set() handler to similarly populate the iovec properly.

Diff Detail

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