Page MenuHomeFreeBSD

Add PD_KILL option to prison_deref()
ClosedPublic

Authored by jamie on Feb 3 2021, 9:43 PM.
Tags
None
Referenced Files
F133450249: D28473.id84343.diff
Sat, Oct 25, 9:40 PM
F133334756: D28473.id83328.diff
Sat, Oct 25, 12:29 AM
Unknown Object (File)
Tue, Oct 21, 4:00 PM
Unknown Object (File)
Wed, Oct 15, 1:59 AM
Unknown Object (File)
Sun, Oct 5, 9:30 AM
Unknown Object (File)
Sep 23 2025, 11:21 PM
Unknown Object (File)
Sep 21 2025, 8:32 PM
Unknown Object (File)
Sep 15 2025, 10:14 PM
Subscribers

Details

Summary

Add the PD_KILL flag that instruction prison_deref() to take steps to actively kill a prison, namely clearing its PR_PERSIST flag and killing any attached processes.

This replaces a similar loop in sys_jail_remove(), bringing the operation under the same single hold on allprison_lock that it already has. It also replaces a bit of one-off code in kern_jail_set() to handle the destruction of almost-finished prisons.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

jamie requested review of this revision.Feb 3 2021, 9:43 PM
jamie created this revision.
This revision was not accepted when it landed; it landed in state Needs Review.Feb 22 2021, 8:28 PM
This revision was automatically updated to reflect the committed changes.

After this commit running cd /usr/tests/lib/libc/sys && kyua test cpuset_test renders the entire system unusable (and in Jenkins it's triggering a kernel panic)

Sorry I took so long - I confused your note that it should be reverted with a note that it *had been* reverted.