aboutsummaryrefslogtreecommitdiff
path: root/utils/utils.go
diff options
context:
space:
mode:
authoropenshift-ci[bot] <75433959+openshift-ci[bot]@users.noreply.github.com>2022-07-13 09:10:57 +0000
committerGitHub <noreply@github.com>2022-07-13 09:10:57 +0000
commit4df6122aaa3bc858e9488d366a2c9c91b6671170 (patch)
tree9c03ee40d0d7c6cd29c881245a3eb24159f8b10b /utils/utils.go
parent6323af78e785f2713497f934f22f5f26719d2175 (diff)
parente3419c03245c5639d457cb27f4081cee400f3a36 (diff)
downloadpodman-4df6122aaa3bc858e9488d366a2c9c91b6671170.tar.gz
podman-4df6122aaa3bc858e9488d366a2c9c91b6671170.tar.bz2
podman-4df6122aaa3bc858e9488d366a2c9c91b6671170.zip
Merge pull request #14904 from giuseppe/move-to-subcgroup-in-a-container
abi: create new cgroup when running in a container
Diffstat (limited to 'utils/utils.go')
-rw-r--r--utils/utils.go30
1 files changed, 30 insertions, 0 deletions
diff --git a/utils/utils.go b/utils/utils.go
index 997de150d..aa1c6a958 100644
--- a/utils/utils.go
+++ b/utils/utils.go
@@ -190,3 +190,33 @@ func MovePauseProcessToScope(pausePidPath string) {
}
}
}
+
+var (
+ maybeMoveToSubCgroupSync sync.Once
+ maybeMoveToSubCgroupSyncErr error
+)
+
+// MaybeMoveToSubCgroup moves the current process in a sub cgroup when
+// it is running in the root cgroup on a system that uses cgroupv2.
+func MaybeMoveToSubCgroup() error {
+ maybeMoveToSubCgroupSync.Do(func() {
+ unifiedMode, err := cgroups.IsCgroup2UnifiedMode()
+ if err != nil {
+ maybeMoveToSubCgroupSyncErr = err
+ return
+ }
+ if !unifiedMode {
+ maybeMoveToSubCgroupSyncErr = nil
+ return
+ }
+ cgroup, err := GetOwnCgroup()
+ if err != nil {
+ maybeMoveToSubCgroupSyncErr = err
+ return
+ }
+ if cgroup == "/" {
+ maybeMoveToSubCgroupSyncErr = MoveUnderCgroupSubtree("init")
+ }
+ })
+ return maybeMoveToSubCgroupSyncErr
+}