Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 27 additions & 0 deletions cmd/oci-runtime-tool/generate.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ import (
"github.com/opencontainers/runtime-tools/generate"
"github.com/opencontainers/runtime-tools/generate/seccomp"
"github.com/urfave/cli"

mpolCheck "github.com/opencontainers/runtime-tools/validate/memorypolicy"
)

var generateFlags = []cli.Flag{
Expand Down Expand Up @@ -64,6 +66,9 @@ var generateFlags = []cli.Flag{
cli.StringFlag{Name: "linux-mems", Usage: "list of memory nodes in the cpuset (default is to use any available memory node)"},
cli.Uint64Flag{Name: "linux-mem-swap", Usage: "total memory limit (memory + swap) (in bytes)"},
cli.Uint64Flag{Name: "linux-mem-swappiness", Usage: "how aggressive the kernel will swap memory pages (Range from 0 to 100)"},
cli.StringFlag{Name: "linux-memorypolicy-mode", Usage: "memory policy defines from which nodes memory is allocated by default, e.g MPOL_INTERLEAVE"},
cli.StringFlag{Name: "linux-memorypolicy-nodes", Usage: "memory nodes related to the linux-memorypolicy-mode, e.g 0-3,7"},
cli.StringSliceFlag{Name: "linux-memorypolicy-flags", Usage: "optional memory policy mode flags, e.g MPOL_F_STATIC_NODES"},
cli.StringFlag{Name: "linux-mount-label", Usage: "selinux mount context label"},
cli.StringSliceFlag{Name: "linux-namespace-add", Usage: "adds a namespace to the set of namespaces to create or join of the form 'ns[:path]'"},
cli.StringSliceFlag{Name: "linux-namespace-remove", Usage: "removes a namespace from the set of namespaces to create or join of the form 'ns'"},
Expand Down Expand Up @@ -782,6 +787,28 @@ func setupSpec(g *generate.Generator, context *cli.Context) error {
g.SetLinuxResourcesMemorySwappiness(context.Uint64("linux-mem-swappiness"))
}

if context.IsSet("linux-memorypolicy-mode") {
mpolMode := context.String("linux-memorypolicy-mode")
if err := mpolCheck.MpolModeValid(mpolMode); err != nil {
return err
}
g.SetLinuxMemoryPolicyMode(mpolMode)
}

if context.IsSet("linux-memorypolicy-nodes") {
g.SetLinuxMemoryPolicyNodes(context.String("linux-memorypolicy-nodes"))
}

if context.IsSet("linux-memorypolicy-flags") {
mpolFlags := context.StringSlice("linux-memorypolicy-flags")
for _, flag := range mpolFlags {
if err := mpolCheck.MpolFlagValid(flag); err != nil {
return err
}
}
g.SetLinuxMemoryPolicyFlags(mpolFlags)
}

if context.IsSet("linux-network-classid") {
g.SetLinuxResourcesNetworkClassID(uint32(context.Int("linux-network-classid")))
}
Expand Down
7 changes: 7 additions & 0 deletions generate/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,13 @@ func (g *Generator) initConfigLinuxResourcesMemory() {
}
}

func (g *Generator) initConfigLinuxMemoryPolicy() {
g.initConfigLinux()
if g.Config.Linux.MemoryPolicy == nil {
g.Config.Linux.MemoryPolicy = &rspec.LinuxMemoryPolicy{}
}
}

func (g *Generator) initConfigLinuxResourcesNetwork() {
g.initConfigLinuxResources()
if g.Config.Linux.Resources.Network == nil {
Expand Down
20 changes: 20 additions & 0 deletions generate/generate.go
Original file line number Diff line number Diff line change
Expand Up @@ -926,6 +926,26 @@ func (g *Generator) SetLinuxResourcesMemorySwappiness(swappiness uint64) {
g.Config.Linux.Resources.Memory.Swappiness = &swappiness
}

// SetLinuxMemoryPolicyMode sets g.Config.Linux.MemoryPolicy.Mode
func (g *Generator) SetLinuxMemoryPolicyMode(mode string) {
g.initConfigLinuxMemoryPolicy()
g.Config.Linux.MemoryPolicy.Mode = rspec.MemoryPolicyModeType(mode)
}

// SetLinuxMemoryPolicyNodes sets g.Config.Linux.MemoryPolicy.Nodes
func (g *Generator) SetLinuxMemoryPolicyNodes(nodes string) {
g.initConfigLinuxMemoryPolicy()
g.Config.Linux.MemoryPolicy.Nodes = nodes
}

// SetLinuxMemoryPolicyFlags sets g.Config.Linux.MemoryPolicy.Flags
func (g *Generator) SetLinuxMemoryPolicyFlags(flags []string) {
g.initConfigLinuxMemoryPolicy()
for _, flag := range flags {
g.Config.Linux.MemoryPolicy.Flags = append(g.Config.Linux.MemoryPolicy.Flags, rspec.MemoryPolicyFlagType(flag))
}
}

// SetLinuxResourcesMemoryDisableOOMKiller sets g.Config.Linux.Resources.Memory.DisableOOMKiller.
func (g *Generator) SetLinuxResourcesMemoryDisableOOMKiller(disable bool) {
g.initConfigLinuxResourcesMemory()
Expand Down
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ require (
github.com/moby/sys/capability v0.4.0
github.com/moby/sys/mountinfo v0.7.2
github.com/mrunalp/fileutils v0.5.0
github.com/opencontainers/runtime-spec v1.1.0
github.com/opencontainers/runtime-spec v1.2.2-0.20250804081626-bfdffd548aa6
github.com/opencontainers/selinux v1.9.1
github.com/sirupsen/logrus v1.8.1
github.com/stretchr/testify v1.3.0
Expand Down
8 changes: 4 additions & 4 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -11,14 +11,14 @@ github.com/hashicorp/go-multierror v1.1.1 h1:H5DkEtf6CXdFp0N0Em5UCwQpXMWke8IA0+l
github.com/hashicorp/go-multierror v1.1.1/go.mod h1:iw975J/qwKPdAO1clOe2L8331t/9/fmwbPZ6JB6eMoM=
github.com/mndrix/tap-go v0.0.0-20171203230836-629fa407e90b h1:Ga1nclDSe8gOw37MVLMhfu2QKWtD6gvtQ298zsKVh8g=
github.com/mndrix/tap-go v0.0.0-20171203230836-629fa407e90b/go.mod h1:pzzDgJWZ34fGzaAZGFW22KVZDfyrYW+QABMrWnJBnSs=
github.com/moby/sys/mountinfo v0.7.2 h1:1shs6aH5s4o5H2zQLn796ADW1wMrIwHsyJ2v9KouLrg=
github.com/moby/sys/mountinfo v0.7.2/go.mod h1:1YOa8w8Ih7uW0wALDUgT1dTTSBrZ+HiBLGws92L2RU4=
github.com/moby/sys/capability v0.4.0 h1:4D4mI6KlNtWMCM1Z/K0i7RV1FkX+DBDHKVJpCndZoHk=
github.com/moby/sys/capability v0.4.0/go.mod h1:4g9IK291rVkms3LKCDOoYlnV8xKwoDTpIrNEE35Wq0I=
github.com/moby/sys/mountinfo v0.7.2 h1:1shs6aH5s4o5H2zQLn796ADW1wMrIwHsyJ2v9KouLrg=
github.com/moby/sys/mountinfo v0.7.2/go.mod h1:1YOa8w8Ih7uW0wALDUgT1dTTSBrZ+HiBLGws92L2RU4=
github.com/mrunalp/fileutils v0.5.0 h1:NKzVxiH7eSk+OQ4M+ZYW1K6h27RUV3MI6NUTsHhU6Z4=
github.com/mrunalp/fileutils v0.5.0/go.mod h1:M1WthSahJixYnrXQl/DFQuteStB1weuxD2QJNHXfbSQ=
github.com/opencontainers/runtime-spec v1.1.0 h1:HHUyrt9mwHUjtasSbXSMvs4cyFxh+Bll4AjJ9odEGpg=
github.com/opencontainers/runtime-spec v1.1.0/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
github.com/opencontainers/runtime-spec v1.2.2-0.20250804081626-bfdffd548aa6 h1:6S6r1L8VO9b1UfgIQi+nteqlElma9KDlzZw/nM3ctI0=
github.com/opencontainers/runtime-spec v1.2.2-0.20250804081626-bfdffd548aa6/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
github.com/opencontainers/selinux v1.9.1 h1:b4VPEF3O5JLZgdTDBmGepaaIbAo0GqoF6EBRq5f/g3Y=
github.com/opencontainers/selinux v1.9.1/go.mod h1:2i0OySw99QjzBBQByd1Gr9gSjvuho1lHsJxIJ3gGbJI=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
Expand Down
46 changes: 46 additions & 0 deletions validate/memorypolicy/validate.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
package memorypolicy

import (
"fmt"
"strings"

rspec "github.com/opencontainers/runtime-spec/specs-go"
)

var (
knownModes map[rspec.MemoryPolicyModeType]struct{} = map[rspec.MemoryPolicyModeType]struct{}{
rspec.MpolDefault: {},
rspec.MpolBind: {},
rspec.MpolInterleave: {},
rspec.MpolWeightedInterleave: {},
rspec.MpolPreferred: {},
rspec.MpolPreferredMany: {},
rspec.MpolLocal: {},
}

knownModeFlags map[rspec.MemoryPolicyFlagType]struct{} = map[rspec.MemoryPolicyFlagType]struct{}{
rspec.MpolFNumaBalancing: {},
rspec.MpolFRelativeNodes: {},
rspec.MpolFStaticNodes: {},
}
)

func MpolModeValid(mode string) error {
if !strings.HasPrefix(mode, "MPOL_") {
return fmt.Errorf("memory policy mode %q must start with 'MPOL_'", mode)
}
if _, ok := knownModes[rspec.MemoryPolicyModeType(mode)]; !ok {
return fmt.Errorf("invalid memory policy mode %q", mode)
}
return nil
}

func MpolFlagValid(flag string) error {
if !strings.HasPrefix(flag, "MPOL_F_") {
return fmt.Errorf("memory policy flag %q must start with 'MPOL_F_'", flag)
}
if _, ok := knownModeFlags[rspec.MemoryPolicyFlagType(flag)]; !ok {
return fmt.Errorf("invalid memory policy flag %q", flag)
}
return nil
}
12 changes: 12 additions & 0 deletions validate/validate_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import (
rspec "github.com/opencontainers/runtime-spec/specs-go"
osFilepath "github.com/opencontainers/runtime-tools/filepath"
"github.com/opencontainers/runtime-tools/specerror"
mpolCheck "github.com/opencontainers/runtime-tools/validate/memorypolicy"
"github.com/opencontainers/selinux/go-selinux/label"
"github.com/sirupsen/logrus"
)
Expand Down Expand Up @@ -221,5 +222,16 @@ func (v *Validator) CheckLinux() (errs error) {
}
}

if v.spec.Linux.MemoryPolicy != nil {
if err := mpolCheck.MpolModeValid(string(v.spec.Linux.MemoryPolicy.Mode)); err != nil {
errs = multierror.Append(errs, err)
}
for _, flag := range v.spec.Linux.MemoryPolicy.Flags {
if err := mpolCheck.MpolFlagValid(string(flag)); err != nil {
errs = multierror.Append(errs, err)
}
}
}

return
}
Loading