Skip to content

Commit

Permalink
cgroupv2: move sanity path check to common code
Browse files Browse the repository at this point in the history
The fs2 cgroup driver has a sanity check for path.
Since systemd driver is relying on the same path,
it makes sense to move this check to the common code.

Signed-off-by: Kir Kolyshkin <[email protected]>
  • Loading branch information
kolyshkin committed Apr 19, 2020
1 parent dbeff89 commit 60eaed2
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 11 deletions.
6 changes: 1 addition & 5 deletions libcontainer/cgroups/fs2/fs2.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,11 +30,7 @@ func NewManager(config *configs.Cgroup, dirPath string, rootless bool) (cgroups.
if config == nil {
config = &configs.Cgroup{}
}
if dirPath != "" {
if filepath.Clean(dirPath) != dirPath || !filepath.IsAbs(dirPath) {
return nil, errors.Errorf("invalid dir path %q", dirPath)
}
} else {
if dirPath == "" {
var err error
dirPath, err = defaultDirPath(config)
if err != nil {
Expand Down
18 changes: 12 additions & 6 deletions libcontainer/factory_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,16 +51,22 @@ func InitArgs(args ...string) func(*LinuxFactory) error {
}

func getUnifiedPath(paths map[string]string) string {
unifiedPath := ""
path := ""
for k, v := range paths {
if unifiedPath == "" {
unifiedPath = v
} else if v != unifiedPath {
panic(errors.Errorf("expected %q path to be unified path %q, got %q", k, unifiedPath, v))
if path == "" {
path = v
} else if v != path {
panic(errors.Errorf("expected %q path to be unified path %q, got %q", k, path, v))
}
}
// can be empty
return unifiedPath
if path != "" {
if filepath.Clean(path) != path || !filepath.IsAbs(path) {
panic(errors.Errorf("invalid dir path %q", path))
}
}

return path
}

func systemdCgroupV2(l *LinuxFactory, rootless bool) error {
Expand Down

0 comments on commit 60eaed2

Please sign in to comment.