History log of /freebsd/sys/security/mac_do/ (Results 1 – 25 of 82)
Revision Date Author Comments
(<<< Hide modified files)
(Show modified files >>>)
0c2d64ce04-Jun-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Clarify comments about flags attached per-ID or per-ID-type

No functional change.

MFC after: 3 days
Sponsored by: The FreeBSD Foundation


/freebsd/ObsoleteFiles.inc
/freebsd/bin/pwd/tests/pwd_test.sh
/freebsd/contrib/file/ChangeLog
/freebsd/contrib/file/config.sub
/freebsd/contrib/file/configure
/freebsd/contrib/file/configure.ac
/freebsd/contrib/file/doc/file.man
/freebsd/contrib/file/doc/magic.man
/freebsd/contrib/file/magic/Magdir/amigaos
/freebsd/contrib/file/magic/Magdir/animation
/freebsd/contrib/file/magic/Magdir/apache
/freebsd/contrib/file/magic/Magdir/archive
/freebsd/contrib/file/magic/Magdir/audio
/freebsd/contrib/file/magic/Magdir/bgcode
/freebsd/contrib/file/magic/Magdir/blender
/freebsd/contrib/file/magic/Magdir/bytecode
/freebsd/contrib/file/magic/Magdir/c-lang
/freebsd/contrib/file/magic/Magdir/cisco
/freebsd/contrib/file/magic/Magdir/commands
/freebsd/contrib/file/magic/Magdir/console
/freebsd/contrib/file/magic/Magdir/creativeassembly
/freebsd/contrib/file/magic/Magdir/database
/freebsd/contrib/file/magic/Magdir/filesystems
/freebsd/contrib/file/magic/Magdir/firmware
/freebsd/contrib/file/magic/Magdir/fonts
/freebsd/contrib/file/magic/Magdir/games
/freebsd/contrib/file/magic/Magdir/gguf
/freebsd/contrib/file/magic/Magdir/ibm370
/freebsd/contrib/file/magic/Magdir/images
/freebsd/contrib/file/magic/Magdir/intel
/freebsd/contrib/file/magic/Magdir/linux
/freebsd/contrib/file/magic/Magdir/lua
/freebsd/contrib/file/magic/Magdir/mail.news
/freebsd/contrib/file/magic/Magdir/measure
/freebsd/contrib/file/magic/Magdir/msdos
/freebsd/contrib/file/magic/Magdir/msooxml
/freebsd/contrib/file/magic/Magdir/music
/freebsd/contrib/file/magic/Magdir/os2
/freebsd/contrib/file/magic/Magdir/pdf
/freebsd/contrib/file/magic/Magdir/pgp
/freebsd/contrib/file/magic/Magdir/python
/freebsd/contrib/file/magic/Magdir/r
/freebsd/contrib/file/magic/Magdir/riff
/freebsd/contrib/file/magic/Magdir/rtf
/freebsd/contrib/file/magic/Magdir/sf3
/freebsd/contrib/file/magic/Magdir/sgml
/freebsd/contrib/file/magic/Magdir/sniffer
/freebsd/contrib/file/magic/Magdir/sql
/freebsd/contrib/file/magic/Magdir/syd
/freebsd/contrib/file/magic/Magdir/tapebackup
/freebsd/contrib/file/magic/Magdir/tex
/freebsd/contrib/file/magic/Magdir/ti-8x
/freebsd/contrib/file/magic/Magdir/varied.script
/freebsd/contrib/file/magic/Magdir/virtual
/freebsd/contrib/file/magic/Magdir/webassembly
/freebsd/contrib/file/magic/Magdir/windows
/freebsd/contrib/file/magic/Magdir/xilinx
/freebsd/contrib/file/magic/Magdir/xwindows
/freebsd/contrib/file/magic/Magdir/zip
/freebsd/contrib/file/magic/Makefile.am
/freebsd/contrib/file/magic/Makefile.in
/freebsd/contrib/file/python/magic.py
/freebsd/contrib/file/src/apprentice.c
/freebsd/contrib/file/src/apptype.c
/freebsd/contrib/file/src/buffer.c
/freebsd/contrib/file/src/cdf.c
/freebsd/contrib/file/src/cdf.h
/freebsd/contrib/file/src/encoding.c
/freebsd/contrib/file/src/file.h
/freebsd/contrib/file/src/funcs.c
/freebsd/contrib/file/src/is_simh.c
/freebsd/contrib/file/src/magic.c
/freebsd/contrib/file/src/print.c
/freebsd/contrib/file/src/readcdf.c
/freebsd/contrib/file/src/readelf.c
/freebsd/contrib/file/src/seccomp.c
/freebsd/contrib/file/src/softmagic.c
/freebsd/contrib/file/tests/Makefile.am
/freebsd/contrib/file/tests/Makefile.in
/freebsd/contrib/file/tests/arj.result
/freebsd/contrib/file/tests/bgcode.result
/freebsd/contrib/file/tests/bgcode.testfile
/freebsd/contrib/file/tests/efi-signature-list-sha256.result
/freebsd/contrib/file/tests/efi-signature-list-sha256.testfile
/freebsd/contrib/llvm-project/clang/lib/Serialization/ASTReaderDecl.cpp
/freebsd/lib/libc/tests/gen/Makefile
/freebsd/lib/libc/tests/gen/fts_set_test.c
/freebsd/lib/libmagic/config.h
/freebsd/lib/libsys/open.2
/freebsd/lib/libsysdecode/flags.c
/freebsd/lib/libsysdecode/mktables
/freebsd/lib/libsysdecode/sysdecode.h
/freebsd/lib/libufs/inode.c
/freebsd/libexec/rc/rc.d/defaultroute
/freebsd/sbin/fsck_ffs/inode.c
/freebsd/sys/amd64/amd64/machdep.c
/freebsd/sys/amd64/conf/GENERIC
/freebsd/sys/amd64/conf/NOTES
/freebsd/sys/amd64/linux/linux.h
/freebsd/sys/amd64/linux/linux_machdep.c
/freebsd/sys/arm/broadcom/bcm2835/bcm2838_pci.c
/freebsd/sys/compat/linux/linux_file.c
/freebsd/sys/compat/linux/linux_ptrace.c
/freebsd/sys/compat/linux/linux_signal.c
/freebsd/sys/compat/linuxkpi/common/include/linux/pm_qos.h
/freebsd/sys/conf/files.amd64
/freebsd/sys/conf/kern.post.mk
/freebsd/sys/conf/options.amd64
/freebsd/sys/dev/asmc/asmc.c
/freebsd/sys/dev/asmc/asmcmmio.c
/freebsd/sys/dev/asmc/asmcmmio.h
/freebsd/sys/dev/asmc/asmcvar.h
/freebsd/sys/dev/cxgbe/common/t4_hw.c
/freebsd/sys/dev/cxgbe/crypto/t7_kern_tls.c
/freebsd/sys/dev/cxgbe/t4_main.c
/freebsd/sys/dev/ofw/ofw_bus_subr.c
/freebsd/sys/dev/ofw/ofw_bus_subr.h
/freebsd/sys/dev/pci/pci_host_generic.c
/freebsd/sys/dev/pci/pci_host_generic.h
/freebsd/sys/dev/pci/pci_host_generic_fdt.c
/freebsd/sys/dev/pci/pci_host_generic_fdt.h
/freebsd/sys/dev/thunderbolt/nhi.c
/freebsd/sys/dev/thunderbolt/router.c
/freebsd/sys/dev/thunderbolt/tb_acpi_pcib.c
/freebsd/sys/dev/thunderbolt/tb_pcib.c
/freebsd/sys/fs/nfs/nfs.h
/freebsd/sys/fs/nfs/nfs_var.h
/freebsd/sys/fs/nfs/nfsproto.h
/freebsd/sys/fs/nfs/nfsrvstate.h
/freebsd/sys/fs/nfsclient/nfs_clrpcops.c
/freebsd/sys/fs/nfsserver/nfs_nfsdport.c
/freebsd/sys/fs/nfsserver/nfs_nfsdserv.c
/freebsd/sys/fs/nfsserver/nfs_nfsdstate.c
/freebsd/sys/i386/i386/genassym.c
/freebsd/sys/kern/kern_prot.c
/freebsd/sys/kern/kern_resource.c
/freebsd/sys/kern/uipc_usrreq.c
/freebsd/sys/modules/asmc/Makefile
/freebsd/sys/net/ieee8023ad_lacp.c
/freebsd/sys/net/if.c
/freebsd/sys/net/if_lagg.c
/freebsd/sys/net/if_private.h
/freebsd/sys/netpfil/ipfw/nat64/nat64lsn.c
/freebsd/sys/netpfil/pf/pf_nl.h
mac_do.c
/freebsd/sys/ufs/ffs/ffs_vfsops.c
/freebsd/sys/x86/cpufreq/hwpstate_intel.c
/freebsd/sys/x86/x86/ucode.c
/freebsd/usr.bin/asa/tests/asa_test.sh
/freebsd/usr.bin/cmp/tests/cmp_test2.sh
/freebsd/usr.bin/diff/pr.c
/freebsd/usr.bin/du/tests/du_test.sh
/freebsd/usr.bin/env/tests/env_test.sh
/freebsd/usr.bin/ident/tests/ident_test.sh
/freebsd/usr.bin/printenv/tests/printenv_test.sh
/freebsd/usr.bin/uniq/tests/uniq_test.sh
/freebsd/usr.bin/xinstall/install.1
/freebsd/usr.bin/xinstall/tests/install_test.sh
/freebsd/usr.bin/xinstall/xinstall.c
/freebsd/usr.bin/yes/tests/yes_test.sh
/freebsd/usr.sbin/bsdinstall/scripts/services
/freebsd/usr.sbin/periodic/etc/security/520.pfdenied
/freebsd/usr.sbin/virtual_oss/virtual_oss_cmd/command.c
79d0dbc901-Jun-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Fix double-free on parse error after "executable paths" feature

parse_rules() has been calling toast_rules() in case of a parse error in
order to deallocate the 'struct rule' objects it has

MAC/do: Fix double-free on parse error after "executable paths" feature

parse_rules() has been calling toast_rules() in case of a parse error in
order to deallocate the 'struct rule' objects it has constructed up to
that point.

toast_rules() would take a pointer to a full 'struct rules' object, and
besides freeing all 'struct rule' referenced by it, would also free the
holding 'struct rules' itself.

With the introduction of the "executable paths" feature, and the
embedding of 'struct rules' into 'struct conf', meaning that the
lifecycle for 'struct rules' was no longer independent, toast_rules()
was changed not to free the passed 'struct rules' (as it was a field of
a 'struct conf' object). Unfortunately, this change was not completed
with a reinitialization of the rules list head, so the 'struct conf'
object would continue to reference just-freed rules, which then would be
freed a second time on destruction of that container.

So, make toast_rules() re-initialize the rules list in 'struct rules',
which it logically has been having to do since not freeing the enclosing
'struct rules'. This alone is enough to fix the bug, but let's use the
occasion to change the contract of parse_rules() and bring its herald
comment up-to-date: On error, parse_rules() now simply leaves already
constructed 'struct rule' objects in 'conf'. The latter is eventually
destroyed and the rule objects reclaimed at that point.

Add a test trying to set an invalid rules configuration with the first
rule being valid and the second being invalid, which triggers the bug
(and an immediate panic() on an INVARIANTS kernel).

Reported by: impost0r(ret2plt) <impostor@ret2p.lt>
Reviewed by: markj
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
Sponsored by: The FreeBSD Foundation

show more ...


/freebsd/bin/sh/miscbltin.c
/freebsd/contrib/dma/conf.c
/freebsd/contrib/dma/dma.conf
/freebsd/contrib/dma/dma.h
/freebsd/contrib/dma/net.c
/freebsd/etc/mtree/BSD.include.dist
/freebsd/include/Makefile
/freebsd/include/assert.h
/freebsd/include/rpcsvc/yp_prot.h
/freebsd/lib/libc/gen/fts.3
/freebsd/lib/libc/gen/fts.c
/freebsd/lib/libc/stdlib/rand.3
/freebsd/lib/libc/tests/gen/fts_options_test.c
/freebsd/lib/libutil/login_class.c
/freebsd/sbin/mdmfs/mdmfs.c
/freebsd/sbin/route/route_netlink.c
/freebsd/share/man/man3/assert.3
/freebsd/share/man/man4/mac_do.4
/freebsd/share/man/man9/style.9
/freebsd/stand/defs.mk
/freebsd/stand/efi/Makefile
/freebsd/stand/efi/Makefile.inc
/freebsd/stand/efi/ficl32efi/Makefile
/freebsd/stand/efi/liblua32efi/Makefile
/freebsd/stand/efi/libsa32efi/Makefile
/freebsd/stand/efi/loader/main.c
/freebsd/stand/loader.mk
/freebsd/stand/man/loader.efi.8
/freebsd/sys/amd64/amd64/machdep.c
/freebsd/sys/compat/linux/linux_misc.c
/freebsd/sys/compat/linux/linux_misc.h
/freebsd/sys/compat/linuxkpi/common/src/linux_idr.c
/freebsd/sys/compat/linuxkpi/common/src/linuxkpi_80211_pm.c
/freebsd/sys/dev/hwpmc/hwpmc_intel.c
/freebsd/sys/dev/ichiic/ig4_pci.c
/freebsd/sys/dev/ichsmb/ichsmb_pci.c
/freebsd/sys/dev/ntsync/linux_ntsync.c
/freebsd/sys/dev/ntsync/linux_ntsync.h
/freebsd/sys/dev/ntsync/ntsync.c
/freebsd/sys/dev/ntsync/ntsync.h
/freebsd/sys/dev/ntsync/ntsyncvar.h
/freebsd/sys/dev/rtwn/usb/rtwn_usb_attach.h
/freebsd/sys/dev/usb/input/ukbd.c
/freebsd/sys/dev/usb/usbdevs
/freebsd/sys/fs/msdosfs/direntry.h
/freebsd/sys/fs/msdosfs/msdosfs_conv.c
/freebsd/sys/fs/msdosfs/msdosfs_lookup.c
/freebsd/sys/kern/imgact_elf.c
/freebsd/sys/kern/syscalls.master
/freebsd/sys/modules/Makefile
/freebsd/sys/modules/linux_ntsync/Makefile
/freebsd/sys/modules/ntsync/Makefile
/freebsd/sys/netlink/route/iface_drivers.c
/freebsd/sys/netlink/route/rt.c
mac_do.c
/freebsd/sys/sys/file.h
/freebsd/sys/sys/pmc.h
/freebsd/sys/sys/signal.h
/freebsd/sys/sys/user.h
/freebsd/tests/sys/mac/do/Makefile
/freebsd/tests/sys/mac/do/common.sh
/freebsd/tests/sys/mac/do/consistency.sh
/freebsd/tests/sys/mac/do/invalid_configs.sh
/freebsd/tests/sys/mac/do/valid_configs.sh
/freebsd/tests/sys/netipsec/tunnel/Makefile
/freebsd/tools/test/stress2/misc/all.exclude
/freebsd/tools/test/stress2/misc/msdos22.sh
/freebsd/tools/test/stress2/misc/msdos23.sh
/freebsd/tools/test/stress2/misc/msdos24.sh
/freebsd/usr.sbin/spi/spi.c
fcb0018620-May-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Update copyright

Update years for the Foundation.

While here, remove the initial '/*-' which has been useless for a long
time.

While here, add a missing space on bapt@'s copyright line (ap

MAC/do: Update copyright

Update years for the Foundation.

While here, remove the initial '/*-' which has been useless for a long
time.

While here, add a missing space on bapt@'s copyright line (approved by
him).

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

1fa1e3f307-May-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Do not skip blanks when parsing executable paths

The kind of tolerance we apply to parsing rules, whose format we have
defined, cannot be applied to paths since blank characters are allowed

MAC/do: Do not skip blanks when parsing executable paths

The kind of tolerance we apply to parsing rules, whose format we have
defined, cannot be applied to paths since blank characters are allowed
there.

There is still the limitation that no escape character is currently
supported, and so it is not possible to configure a path having a ':'
character.

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

4c98f7a029-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Serialize installing/modifying some jail's configuration

See the immediately preceding commit for explanations on what this is
fixing.

When setting 'mac.do' to 'inherit' on a jail with 'mac

MAC/do: Serialize installing/modifying some jail's configuration

See the immediately preceding commit for explanations on what this is
fixing.

When setting 'mac.do' to 'inherit' on a jail with 'mac.do.rules' and
'mac.do.exec_paths' also specified in the same call, ensure that the
check that these passed parameters are the same as those to be inherited
is atomic with respect to enabling the inheritance (i.e., removing the
jail's 'struct conf' object). (See previous commit "MAC/do: Fix the
recent logic to set jail parameters, make it more tolerant" as for why
this check exists.)

Because we currently only modify a single configuration object per
transaction, we introduce the parse_and_commit_conf() wrapper around
parse_and_set_conf() to remove duplicated code that would ensue from
calling the latter directly, namely, releasing the 'mac_do_rwl' lock and
freeing the old configuration object (if any).

Taking the 'mac_do_rwl' lock for writing as a way to freeze all accesses
to mac_do(4) configurations was deemed too thin an operation to be worth
wrapping.

Reviewed by: bapt (older version)
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

0db7f11029-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Support for atomically modifying configurations

As mentioned in previous commits "MAC/do: parse_and_set_conf(): Require
the model configuration" and "MAC/do: Sequential consistency for
confi

MAC/do: Support for atomically modifying configurations

As mentioned in previous commits "MAC/do: parse_and_set_conf(): Require
the model configuration" and "MAC/do: Sequential consistency for
configuration retrieval", the introduction of the "executable path"
feature, more fundamentally, the fact that there is now more than one
per-jail parameter and that parameters can be independently modified or
copied, causes an atomicity problem in case of concurrent accesses to of
a jail's applicable configuration.

Partially modifying a configuration is indeed akin to
a read-modify-write operation, where the read is either to the current
or an inherited configuration. More precisely, once pointed to by
a jail, a configuration object is immutable, and changing the jail's
configuration means making the jail point to another configuration
object. To change a jail's configuration, a new configuration object is
thus built, and if only some parameters have been explicitly specified,
those that have not been are set by copying the corresponding values
from an existing configuration object (in case of partial modification
of the existing configuration, from the original configuration object
that is going to be replaced; in case of breakage of inheritance or at
jail creation, from the applicable configuration object, which is on an
ancestor jail). This process is not immune to concurrent modifications
because nothing prevents changes of configurations between reading
existing values and setting the new configuration. Thus, some other
thread could change the value of a parameter after a copy of it has been
made into the new object but before that copy is actually installed,
which effectively will erase the other thread's modification.

To avoid this, we introduce support for serializing configuration
changes on a given jail. To this end, we move the jail climbing process
from find_conf() into find_conf_locked(), and make the former call the
latter in a read-locked section. Similarly, we isolate setting
a configuration in the new set_conf_locked() function, and make
set_conf() call it inside a write-locked section. The new *_unlocked()
variants make it possible to prevent any configuration access between
determining and reading an applicable configuration, computing from it
a new configuration object and finally setting it, by holding a write
lock over the whole process (there is a trade-off here, as read-mostly
locks cannot be upgraded), effectively making it atomic and realizing
full sequential consistency of configuration changes. Also, the
'mac_do_rm' global read-mostly lock is made sleepable so that it can be
write-locked over sysctl_handle*() functions or memory allocations
(eases implementation, at the expense of a potential loss of concurrency
which is most probably irrelevant).

No functional change (intended) at this point.

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

5b194a4a29-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Sequential consistency for configuration retrieval

Since the inception of mac_do(4), find_conf(), used to retrieve the
applicable configuration, has been weakly consistent with respect to
co

MAC/do: Sequential consistency for configuration retrieval

Since the inception of mac_do(4), find_conf(), used to retrieve the
applicable configuration, has been weakly consistent with respect to
concurrent modifications to configuration inheritance that influence its
result (and it has been sequentially consistent with respect to other
configuration modifications, which the initial executable paths feature
and introduction of implicit parameters broke and which will be fixed in
a subsequent commit).

Indeed, find_conf() climbs the jail tree to find an applicable
configuration, which is not an atomic operation. It examines the
current jail's configuration pointer for each browsed jail, which does
not prevent concurrent modifications of the configuration pointer for
jails below or above it. Modifications above the current jail are not
a problem, since if climbing needs to continue (i.e., the current jail
inherits), these modifications will be seen if performed before that
check (and may or may not be seen if performed after that check).
However, modifications below the current jail impair sequential
consistency, because they could be done before other modifications at
the current jail or higher up, and the latter could still be picked up
by the rest of the climb, effectively ignoring that the former should
have blocked the climb earlier, making them look as if they had happened
after for the climbing thread.

As a concrete example of this situation, let's examine a scenario where
some jail A is the parent of some jail B, and B inherits its
configuration from A. An administrator may want to relax the rules only
for jail A but not B. To this end, he first copies the current rules on
B over to A and then relaxes the rules on A. He can intuitively and
reasonably expect that changing B's rules first will prevent A's relaxed
rules to leak to threads in B. Unfortunately, that is not the case: As
explained in the previous paragraph, there can be a time window where
threads from B can still pick up A's new configuration just after it has
been installed. This arguably makes changing inheritance in mac_do(4)
in a fully secure fashion almost impossible.

If preserving fine-grained locking of prisons, we could prevent this
problem by having find_conf(), once it has climbed to a non-NULL pointer
(actual, non-inherited configuration), do another climb to check that it
can reach the same configuration on the same jail again. If the new
climb gives another pointer or jail, it could make it the new candidate
and do a climb check again until the situation stabilizes. A climb
check detects whether changes in jails below that of the candidate
configuration object happened, catching in particular such changes that
happened before changes to the candidate object. However, that process
alone would still be subject to ABA problems, and we would additionally
need to tag each prison with some modification timestamp (global, or
local but necessitating allocating memory during the check) to fix them.

In the end, we considered this direction to be unnecessarily complex,
given that configuration changes are to be rare events and most uses
will just be configuration determination.

Consequently, switch protecting jail configurations with a single
read-mostly lock.

While here, adapt set_conf() to accept NULL as the new configuration
object, and have remove_conf() call it, which removes duplicated code.

While here, add a comment explaining why we do not need to take any more
locks when climbing the jail tree.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

5bedb5e429-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Comment to explain the main invariant for configurations

Once visible, configuration structures must *never* change.

Spell that out in a comment to help future readers/contributors
understa

MAC/do: Comment to explain the main invariant for configurations

Once visible, configuration structures must *never* change.

Spell that out in a comment to help future readers/contributors
understand the design.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

31ef4ee229-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Allocate only one default configuration

When mac_do(4) is loaded, all jails get the same default configuration
(disabled, with only one allowed executable path: '/usr/bin/mdo').
Share it bet

MAC/do: Allocate only one default configuration

When mac_do(4) is loaded, all jails get the same default configuration
(disabled, with only one allowed executable path: '/usr/bin/mdo').
Share it between all jails instead of creating a separate copy for each.

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

01e2b0ce28-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Visually separate some file sections

With additional empty lines.

No functional change (intended).

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull

MAC/do: Visually separate some file sections

With additional empty lines.

No functional change (intended).

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

888a84ce28-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Fix reporting of "mac.do" post-"executable paths"

In mac_do_jail_get(), computation of 'jsys' had not been updated to take
into account executable paths.

Reviewed by: bapt
Fixes:

MAC/do: Fix reporting of "mac.do" post-"executable paths"

In mac_do_jail_get(), computation of 'jsys' had not been updated to take
into account executable paths.

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

51cc584028-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Configuration: Fix default values: Remove jail creation method

mac_do_jail_create() would create a default configuration on the
just-created jail, erroneously causing mac_do_jail_set() to th

MAC/do: Configuration: Fix default values: Remove jail creation method

mac_do_jail_create() would create a default configuration on the
just-created jail, erroneously causing mac_do_jail_set() to then
retrieve it and use it as a model when determining the default values
for not-specified parameters, instead of using the configuration
applicable to the parent jail.

Setting a default configuration in mac_do_jail_create() had been done as
a kind of defensive measure to prevent a created jail not to have
a configuration (effectively making it inherit from an ancestor jail,
which is a security hazard except if explicitly requested). However,
this measure was never really effective (osd_jail_call(PR_METHOD_CREATE)
in kern_jail_set() calls the PR_PETHOD_CREATE methods in an unspecified
order, and stops at the first error), so we are forced to rely in any
case on the fact that an error in a PR_METHOD_CREATE or PR_METHOD_SET
method leads to stopping the jail creation process (which is the case
today; see kern_jail_set()).

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

7929f36428-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Fix the recent logic to set jail parameters, make it more tolerant

The logic introduced in the initial commit for the "executable paths"
feature did not match the specification we discussed

MAC/do: Fix the recent logic to set jail parameters, make it more tolerant

The logic introduced in the initial commit for the "executable paths"
feature did not match the specification we discussed in that specifying
an empty value (for rules or executable paths) on "mac.do" being "new"
would be treated as an absence of value and trigger a copy from the
currently applicable configuration, instead of being an override that
deactivates mac_do(4) in the jail. Fix that by distinguishing both
cases.

More generally, a non-explicitly specified parameter is set to the same
value it has in the currently applicable configuration (that of the
closest ancestor jail that has one; 'prison0' (the host) always has
one), with an exception in the disable case.

On disable (explicit: "mac.do" to "disable", implicit: no parameters
passed, or at least one is empty), now accept parameters with
a non-empty value as long as at least one of them is empty (which alone
is enough to disable mac_do(4)). If no parameters are passed, both are
copied from the currently applicable configuration; if none of them is
empty, then the rules are emptied to effectively disable mac_do(4) (see
the inline comment as to why this was chosen).

On explicit enable ("mac.do" to "enable"), allow not specifying any of
the rules and executable paths, in which case both are copied from the
currently applicable configuration (consistently with what is done when
only one is missing). Note that, as mentioned above, not specifying any
of them by default still resolves to disabling mac_do(4) (i.e., on no
explicit "mac.do" parameter).

On (explicit) inheritance, allow specifying non-empty parameters,
provided they match the values we are going to inherit. This enables
re-applying jail parameters' reported values verbatim to the current
jail (idempotence) or, e.g., to some sibling jail.

(While here, make some existing code easier to read by leveraging
is_null_or_empty().)

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

37bc08d520-May-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Constify is_null_or_empty()

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

dbf8f08928-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Fix obsolete wording in a comment ("ascendant" => "ancestor")

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/

MAC/do: Fix obsolete wording in a comment ("ascendant" => "ancestor")

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

73215eba28-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: parse_and_set_conf(): Require the model configuration

This change is a prerequisite for the next change in caller
mac_do_jail_set(), which for semantic correctness needs to rely on
a stable

MAC/do: parse_and_set_conf(): Require the model configuration

This change is a prerequisite for the next change in caller
mac_do_jail_set(), which for semantic correctness needs to rely on
a stable model configuration.

The two other callers already call find_conf() to retrieve the
applicable configuration, so for these a second call to find_conf() can
be saved.

However, this does not fix (actually, makes slightly worse) an atomicity
problem when multiple threads concurrently change some jail's
configuration (or the configuration inherited by a jail), which has
existed since the introduction of executable paths due to being able to
change only rules or executable paths independently (and the possibility
of not specifying them and having them copied from the currently
applicable configuration). Before tackling it in later commits, we
first focus on fixing the semantics of configuration changes in the very
next patches.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

d254322f27-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: parse_and_set_conf(): Obey empty parameters; Add doc

parse_and_set_conf() is meant to be used in all situations when there is
a need to set or modify some jail's MAC/do configuration. This

MAC/do: parse_and_set_conf(): Obey empty parameters; Add doc

parse_and_set_conf() is meant to be used in all situations when there is
a need to set or modify some jail's MAC/do configuration. This entails
passing the information of whether some parameter was explicitly
specified. For example, an administrator setting/modifying jail
parameters may not specify executable paths but only rules, in which
case the executable paths value is copied from the currently-applicable
configuration. The sysctl(8) knobs case always leverages this feature,
since setting a knob changes one parameter at a time.

Currently, a NULL or empty string argument is treated as a non-specified
parameter. This causes a bug where disabling MAC/do in a jail does not
actually work because, to this end, parse_and_set_conf() is passed an
empty string which it then interprets as a request to copy the currently
applicable configuration's value, which may well not be empty.

Fix this problem by only treating NULL as a marker for a non-specified
parameter, in accordance with the original design for this function.

While here, write some documentation to explain the interface. While
here, remove the original herald comment for parse_and_set_rules(),
which was inadvertently pushed apart from the replacing
parse_and_set_conf().

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

ce59a41820-May-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: clone_rules(): Readability improvements, constification

Constify in order to let the compiler check that source and destination
arguments are passed in the proper order in the different call

MAC/do: clone_rules(): Readability improvements, constification

Constify in order to let the compiler check that source and destination
arguments are passed in the proper order in the different calls.

No functional change (intended).

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

11b567e920-May-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Remove superfluous configuration initialization

Configuration objects would be initialized (zeroed, and some
STAILQ_INIT() called) multiple times. Make sure they are so only once,
and add a

MAC/do: Remove superfluous configuration initialization

Configuration objects would be initialized (zeroed, and some
STAILQ_INIT() called) multiple times. Make sure they are so only once,
and add assertions to check that this is actually the case for functions
that expect it.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

4e27cc0820-May-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Move static assertions on constants close to their definitions

And document more clearly their purpose.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
P

MAC/do: Move static assertions on constants close to their definitions

And document more clearly their purpose.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

68cc6aa227-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Constify clone_rules() and clone_exec_paths()'s source argument

Defensive programming.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: ht

MAC/do: Constify clone_rules() and clone_exec_paths()'s source argument

Defensive programming.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

a7a9e6cc28-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Fix releasing a nonexistent reference on configuration parsing error

On parsing error, parse_and_set_conf(), introduced with the recent
"executable paths" feature, has been calling drop_conf

MAC/do: Fix releasing a nonexistent reference on configuration parsing error

On parsing error, parse_and_set_conf(), introduced with the recent
"executable paths" feature, has been calling drop_conf() on the
being-built configuration. However, that configuration structure is
allocated through alloc_conf(), which does not grab a reference.
Calling drop_conf() on it, which releases a reference, is thus
erroneous, and causes the underlying counter to saturate, translating
into a memory leak.

To fix this bug, make alloc_conf() grab a reference on the newly-created
'struct conf', and rename it to new_conf() to be more in line with what
it does. Keep set_conf() as is, i.e., grabbing an additional reference
on behalf of the jail that is going to hold the configuration.
Consequently, make sure that callers of alloc_conf() unconditionally
drop the reference acquired by the latter before returning (i.e., even
if set_conf() has been called).

While here, since hold_conf() is always used to obtain additional
references on a configuration (new_conf() does not use it, instead
directly setting the use count), add an assertion that it is never used
on a configuration that has no references at all (which indicates that
the configuration has been destroyed).

These changes generally simplify the lifecycle of configurations,
reducing the probability of re-introducing reference mismatches (at the
expense of slightly more reference counting operations, but performance
does not matter here).

Reviewed by: bapt
Fixes: 9818224174c4 ("MAC/do: Executable paths feature (GSoC 2025's final state)")
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

4e4cf18b27-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: find_conf(): Return configuration with a true reference

In addition to the applicable configuration, find_conf() was returning
a pointer to the actual jail holding the configuration object,

MAC/do: find_conf(): Return configuration with a true reference

In addition to the applicable configuration, find_conf() was returning
a pointer to the actual jail holding the configuration object, with that
jail's mutex locked in order to ensure liveness of the returned
configuration (if we wouldn't, a concurrent thread modifying the jail's
configuration could destroy this configuration object underneath us).

But:
1. Ensuring configuration stability by owning the holding jail's mutex
requires callers to either keep that mutex locked for a longer period
of time than just accessing the corresponding 'struct prison' (in
general, bad for concurrency with other operations involving jails)
or to perform an additional dance to acquire a real reference in case
the jail's mutex, for some reason (in general, LORs or acquiring
a sleepable lock) must be dropped before use.
2. Most code does not actually need to know which jail holds the
applicable configuration but for unlocking the jail's mutex. Having
to deal with the jail holding the configuration can cause confusion
about which jail (the current one, or the one holding the
configuration) must be used (and actually did in the very initial
version of MAC/do, which had a serious flaw as a consequence).

So, do not keep a lock on the holding jail. Instead, ensure
configuration stability by always acquiring a true reference from the
start and passing it to the caller. Those callers not doing the dance
mentioned above now need to free it when finished (but this need
replaces the one to unlock the prison).

Additionally, only return the holding jail if explicitly requested by
the caller. mac_do_jail_get() is currently the only caller that needs
it, in order to be able to reliably report if the configuration is
inherited.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

cd1ac04427-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: Move hold_conf() and drop_conf() earlier

This is in preparation for using hold_conf() in find_conf().

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pul

MAC/do: Move hold_conf() and drop_conf() earlier

This is in preparation for using hold_conf() in find_conf().

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

cf942ac927-Apr-2026 Olivier Certner <olce@FreeBSD.org>

MAC/do: find_conf(): Turn an MPASS() into a KASSERT()

Turn the pre-existing comment into an assertion message, with an update
following the introduction of the "executable paths" feature.

Explain i

MAC/do: find_conf(): Turn an MPASS() into a KASSERT()

Turn the pre-existing comment into an assertion message, with an update
following the introduction of the "executable paths" feature.

Explain in a comment why this situation cannot happen.

Without INVARIANTS, such a situation would cause an immediate panic()
(NULL is dereferenced in the next iteration of the loop), so leave the
check under INVARIANTS only.

Reviewed by: bapt
MFC after: 1 month
Sponsored by: The FreeBSD Foundation
Pull Request: https://ron-dev.freebsd.org/FreeBSD/src/pulls/38

show more ...

1234