Skip to content

Commit

Permalink
validate/validate: Linux rlimits extend the POSIX rlimits
Browse files Browse the repository at this point in the history
So don't duplicate those values.  Also drop RLIMIT_LOCKS, which the
man page documents as an obsolete-by-Linux-2.6 value [1].  A quick way
to get a set of strings from the man page is:

  $ curl -s 'https://git.kernel.org/pub/scm/docs/man-pages/man-pages.git/plain/man2/getrlimit.2?h=man-pages-4.13' |
  >   sed -n 's/^\.BR\? \(RLIMIT_[^ ]*\)/\1/p' | sort | uniq

Also rename the old default*Rlimits, because these are valid-value
arrays, not defaults.

[1]: https://git.kernel.org/pub/scm/docs/man-pages/man-pages.git/tree/man2/getrlimit.2?h=man-pages-4.13#n209

Signed-off-by: W. Trevor King <wking@tremily.us>
  • Loading branch information
wking committed Sep 21, 2017
1 parent 3a6f748 commit aff40e1
Showing 1 changed file with 7 additions and 13 deletions.
20 changes: 7 additions & 13 deletions validate/validate.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@ import (
const specConfig = "config.json"

var (
defaultRlimits = []string{
// http://pubs.opengroup.org/onlinepubs/9699919799/functions/getrlimit.html
posixRlimits = []string{
"RLIMIT_AS",
"RLIMIT_CORE",
"RLIMIT_CPU",
Expand All @@ -40,24 +41,17 @@ var (
"RLIMIT_STACK",
}

defaultLinuxRlimits = []string{
"RLIMIT_AS",
"RLIMIT_CORE",
"RLIMIT_CPU",
"RLIMIT_DATA",
"RLIMIT_FSIZE",
"RLIMIT_LOCKS",
// https://git.kernel.org/pub/scm/docs/man-pages/man-pages.git/tree/man2/getrlimit.2?h=man-pages-4.13
linuxRlimits = append(posixRlimits, []string{
"RLIMIT_MEMLOCK",
"RLIMIT_MSGQUEUE",
"RLIMIT_NICE",
"RLIMIT_NOFILE",
"RLIMIT_NPROC",
"RLIMIT_RSS",
"RLIMIT_RTPRIO",
"RLIMIT_RTTIME",
"RLIMIT_SIGPENDING",
"RLIMIT_STACK",
}
})

configSchemaTemplate = "https://raw.githubusercontent.com/opencontainers/runtime-spec/v%s/schema/config-schema.json"
)
Expand Down Expand Up @@ -879,14 +873,14 @@ func (v *Validator) rlimitValid(rlimit rspec.POSIXRlimit) (errs error) {
}

if v.platform == "linux" {
for _, val := range defaultLinuxRlimits {
for _, val := range linuxRlimits {
if val == rlimit.Type {
return
}
}
errs = multierror.Append(errs, fmt.Errorf("rlimit type %q is invalid", rlimit.Type))
} else if v.platform == "solaris" {
for _, val := range defaultRlimits {
for _, val := range posixRlimits {
if val == rlimit.Type {
return
}
Expand Down

0 comments on commit aff40e1

Please sign in to comment.