-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2299 from kolyshkin/fs2-init-ctrl
cgroupv2: fix fs2 driver initialization
- Loading branch information
Showing
15 changed files
with
403 additions
and
260 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,111 @@ | ||
package fs2 | ||
|
||
import ( | ||
"fmt" | ||
"io/ioutil" | ||
"os" | ||
"path/filepath" | ||
"strings" | ||
|
||
"github.com/opencontainers/runc/libcontainer/configs" | ||
) | ||
|
||
// neededControllers returns the string to write to cgroup.subtree_control, | ||
// containing the list of controllers to enable (for example, "+cpu +pids"), | ||
// based on (1) controllers available and (2) resources that are being set. | ||
// | ||
// The resulting string does not include "pseudo" controllers such as | ||
// "freezer" and "devices". | ||
func neededControllers(cgroup *configs.Cgroup) ([]string, error) { | ||
var list []string | ||
|
||
if cgroup == nil { | ||
return list, nil | ||
} | ||
|
||
// list of all available controllers | ||
const file = UnifiedMountpoint + "/cgroup.controllers" | ||
content, err := ioutil.ReadFile(file) | ||
if err != nil { | ||
return list, err | ||
} | ||
avail := make(map[string]struct{}) | ||
for _, ctr := range strings.Fields(string(content)) { | ||
avail[ctr] = struct{}{} | ||
} | ||
|
||
// add the controller if available | ||
add := func(controller string) { | ||
if _, ok := avail[controller]; ok { | ||
list = append(list, "+"+controller) | ||
} | ||
} | ||
|
||
if isPidsSet(cgroup) { | ||
add("pids") | ||
} | ||
if isMemorySet(cgroup) { | ||
add("memory") | ||
} | ||
if isIoSet(cgroup) { | ||
add("io") | ||
} | ||
if isCpuSet(cgroup) { | ||
add("cpu") | ||
} | ||
if isCpusetSet(cgroup) { | ||
add("cpuset") | ||
} | ||
if isHugeTlbSet(cgroup) { | ||
add("hugetlb") | ||
} | ||
|
||
return list, nil | ||
} | ||
|
||
// CreateCgroupPath creates cgroupv2 path, enabling all the | ||
// needed controllers in the process. | ||
func CreateCgroupPath(path string, c *configs.Cgroup) (Err error) { | ||
if !strings.HasPrefix(path, UnifiedMountpoint) { | ||
return fmt.Errorf("invalid cgroup path %s", path) | ||
} | ||
|
||
ctrs, err := neededControllers(c) | ||
if err != nil { | ||
return err | ||
} | ||
allCtrs := strings.Join(ctrs, " ") | ||
|
||
elements := strings.Split(path, "/") | ||
elements = elements[3:] | ||
current := "/sys/fs" | ||
for i, e := range elements { | ||
current = filepath.Join(current, e) | ||
if i > 0 { | ||
if err := os.Mkdir(current, 0755); err != nil { | ||
if !os.IsExist(err) { | ||
return err | ||
} | ||
} else { | ||
// If the directory was created, be sure it is not left around on errors. | ||
current := current | ||
defer func() { | ||
if Err != nil { | ||
os.Remove(current) | ||
} | ||
}() | ||
} | ||
} | ||
// enable needed controllers | ||
if i < len(elements)-1 { | ||
file := filepath.Join(current, "cgroup.subtree_control") | ||
if err := ioutil.WriteFile(file, []byte(allCtrs), 0755); err != nil { | ||
// XXX: we can enable _some_ controllers doing it one-by one | ||
// instead of erroring out -- does it makes sense to do so? | ||
return err | ||
} | ||
} | ||
} | ||
|
||
return nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.