From d1ef109cd0b39239ff82c267df314f7ed2da576b Mon Sep 17 00:00:00 2001 From: Giuseppe Scrivano Date: Mon, 9 Sep 2019 15:58:51 +0200 Subject: [PATCH] config-linux: support seccomp flags allow to specify what flags must be passed to seccomp(2) when installing the filter. Signed-off-by: Giuseppe Scrivano --- config-linux.md | 8 ++++++++ schema/config-linux.json | 6 ++++++ schema/defs-linux.json | 8 ++++++++ specs-go/config.go | 4 ++++ 4 files changed, 26 insertions(+) diff --git a/config-linux.md b/config-linux.md index 444f43911..3d2dfd881 100644 --- a/config-linux.md +++ b/config-linux.md @@ -586,6 +586,14 @@ The following parameters can be specified to set up seccomp: * `SCMP_ARCH_PARISC` * `SCMP_ARCH_PARISC64` +* **`flags`** *(array of strings, OPTIONAL)* - list of flags to use with seccomp(2). + + A valid list of constants is shown below. + + * `SECCOMP_FILTER_FLAG_TSYNC` + * `SECCOMP_FILTER_FLAG_LOG` + * `SECCOMP_FILTER_FLAG_SPEC_ALLOW` + * **`syscalls`** *(array of objects, OPTIONAL)* - match a syscall in seccomp. While this property is OPTIONAL, some values of `defaultAction` are not useful without `syscalls` entries. diff --git a/schema/config-linux.json b/schema/config-linux.json index 5aa03c423..5b1fbabe6 100644 --- a/schema/config-linux.json +++ b/schema/config-linux.json @@ -197,6 +197,12 @@ "defaultAction": { "$ref": "defs-linux.json#/definitions/SeccompAction" }, + "flags": { + "type": "array", + "items": { + "$ref": "defs-linux.json#/definitions/SeccompFlag" + } + }, "architectures": { "type": "array", "items": { diff --git a/schema/defs-linux.json b/schema/defs-linux.json index 0735e6b89..c78c9e42e 100644 --- a/schema/defs-linux.json +++ b/schema/defs-linux.json @@ -42,6 +42,14 @@ "SCMP_ACT_ALLOW" ] }, + "SeccompFlag": { + "type": "string", + "enum": [ + "SECCOMP_FILTER_FLAG_TSYNC", + "SECCOMP_FILTER_FLAG_LOG", + "SECCOMP_FILTER_FLAG_SPEC_ALLOW" + ] + }, "SeccompOperators": { "type": "string", "enum": [ diff --git a/specs-go/config.go b/specs-go/config.go index 48e621c99..d8a3689ad 100644 --- a/specs-go/config.go +++ b/specs-go/config.go @@ -556,12 +556,16 @@ type VMImage struct { type LinuxSeccomp struct { DefaultAction LinuxSeccompAction `json:"defaultAction"` Architectures []Arch `json:"architectures,omitempty"` + Flags []LinuxSeccompFlag `json:"flags,omitempty"` Syscalls []LinuxSyscall `json:"syscalls,omitempty"` } // Arch used for additional architectures type Arch string +// LinuxSeccompFlag is a flag to pass to seccomp(2). +type LinuxSeccompFlag string + // Additional architectures permitted to be used for system calls // By default only the native architecture of the kernel is permitted const (