All checks were successful
Test / Create distribution (push) Successful in 1m2s
Test / Sandbox (push) Successful in 2m36s
Test / Hakurei (push) Successful in 3m42s
Test / ShareFS (push) Successful in 3m43s
Test / Sandbox (race detector) (push) Successful in 5m3s
Test / Hakurei (race detector) (push) Successful in 6m11s
Test / Flake checks (push) Successful in 1m30s
These are generally useful, and none of them are container-specific. Syscalls subtle to use and requiring container-specific setup remains in container. Signed-off-by: Ophestra <cat@gensokyo.uk>
45 lines
1.3 KiB
Go
45 lines
1.3 KiB
Go
package container
|
|
|
|
import (
|
|
. "syscall"
|
|
"unsafe"
|
|
|
|
"hakurei.app/ext"
|
|
)
|
|
|
|
// SetNoNewPrivs sets the calling thread's no_new_privs attribute.
|
|
func SetNoNewPrivs() error {
|
|
return ext.Prctl(PR_SET_NO_NEW_PRIVS, 1, 0)
|
|
}
|
|
|
|
// schedParam is equivalent to struct sched_param from include/linux/sched.h.
|
|
type schedParam struct {
|
|
// sched_priority
|
|
priority ext.Int
|
|
}
|
|
|
|
// schedSetscheduler sets both the scheduling policy and parameters for the
|
|
// thread whose ID is specified in tid. If tid equals zero, the scheduling
|
|
// policy and parameters of the calling thread will be set.
|
|
//
|
|
// This function is unexported because it is [very subtle to use correctly]. The
|
|
// function signature in libc is misleading: pid actually refers to a thread ID.
|
|
// The glibc wrapper for this system call ignores this semantic and exposes
|
|
// this counterintuitive behaviour.
|
|
//
|
|
// This function is only called from the container setup thread. Do not reuse
|
|
// this if you do not have something similar in place!
|
|
//
|
|
// [very subtle to use correctly]: https://www.openwall.com/lists/musl/2016/03/01/4
|
|
func schedSetscheduler(tid int, policy ext.SchedPolicy, param *schedParam) error {
|
|
if _, _, errno := Syscall(
|
|
SYS_SCHED_SETSCHEDULER,
|
|
uintptr(tid),
|
|
uintptr(policy),
|
|
uintptr(unsafe.Pointer(param)),
|
|
); errno != 0 {
|
|
return errno
|
|
}
|
|
return nil
|
|
}
|