Skip to content

Commit

Permalink
config: clarify Linux mount options
Browse files Browse the repository at this point in the history
The former wording was inconsistent with runc, crun, youki, etc.

Several `mount(8)` options such as `X-mount.mode` are unimplemented in those OCI runtimes,
and vice versa (`tmpcopyup`, `rro`, etc.)

The option table added in this commit conforms to runc 1.1, but `acl`
and `noacl` are excluded as the runc implementation seems wrong.

Signed-off-by: Akihiro Suda <[email protected]>
  • Loading branch information
AkihiroSuda committed Feb 10, 2023
1 parent 3eb0620 commit 55c5f5e
Showing 1 changed file with 77 additions and 2 deletions.
79 changes: 77 additions & 2 deletions config.md
Original file line number Diff line number Diff line change
Expand Up @@ -77,11 +77,85 @@ For Solaris, the mount entry corresponds to the 'fs' resource in the [zonecfg(1M
* Windows: a local directory on the filesystem of the container host. UNC paths and mapped drives are not supported.
* Solaris: corresponds to "special" of the fs resource in [zonecfg(1M)][zonecfg.1m].
* **`options`** (array of strings, OPTIONAL) Mount options of the filesystem to be used.
* Linux: supported options are listed in the [mount(8)][mount.8] man page.
Note both [filesystem-independent][mount.8-filesystem-independent] and [filesystem-specific][mount.8-filesystem-specific] options are listed.
* Linux: See [Linux mount options](#configLinuxMountOptions) below. The "MUST" options correspond to [`mount(8)`][mount.8].
* Solaris: corresponds to "options" of the fs resource in [zonecfg(1M)][zonecfg.1m].
* Windows: runtimes MUST support `ro`, mounting the filesystem read-only when `ro` is given.

### <a name="configLinuxMountOptions" />Linux mount options

Runtimes MUST/SHOULD/MAY implement the following option strings for Linux:

Option name | Requirement | Description
------------------|-------------|-----------------------------------------------------
`async` | MUST | [^2]
`atime` | MUST | [^2]
`bind` | MUST | [^1] (bind mounts)
`defaults` | MUST | [^2]
`dev` | MUST | [^2]
`diratime` | MUST | [^2]
`dirsync` | MUST | [^2]
`exec` | MUST | [^2]
`iversion` | MUST | [^2]
`lazytime` | MUST | [^2]
`loud` | MUST | [^2]
`mand` | MAY | [^2] (Deprecated in kernel 5.15, util-linux 2.38)
`noatime` | MUST | [^2]
`nodev` | MUST | [^2]
`nodiratime` | MUST | [^2]
`noexec` | MUST | [^2]
`noiversion` | MUST | [^2]
`nolazytime` | MUST | [^2]
`nomand` | MAY | [^2]
`norelatime` | MUST | [^2]
`nostrictatime` | MUST | [^2]
`nosuid` | MUST | [^2]
`nosymfollow` | SHOULD | [^2] (Introduced in kernel 5.10, util-linux 2.38)
`private` | MUST | [^1] (bind mounts)
`ratime` | SHOULD | Recursive `atime` [^3]
`rbind` | MUST | [^1] (bind mounts)
`rdev` | SHOULD | Recursive `dev` [^3]
`rdiratime` | SHOULD | Recursive `diratime` [^3]
`relatime` | MUST | [^2]
`remount` | MUST | [^2]
`rexec` | SHOULD | Recursive `dev` [^3]
`rnoatime` | SHOULD | Recursive `noatime` [^3]
`rnodiratime` | SHOULD | Recursive `nodiratime` [^3]
`rnoexec` | SHOULD | Recursive `noexec` [^3]
`rnorelatime` | SHOULD | Recursive `norelatime` [^3]
`rnostrictatime` | SHOULD | Recursive `nostrictatime` [^3]
`rnosuid` | SHOULD | Recursive `nosuid` [^3]
`rnosymfollow` | SHOULD | Recursive `nosymfollow` [^3]
`ro` | MUST | [^2]
`rprivate` | MUST | [^1] (bind mounts)
`rrelatime ` | SHOULD | Recursive `relatime` [^3]
`rro` | SHOULD | Recursive `ro` [^3]
`rrw` | SHOULD | Recursive `rw` [^3]
`rshared` | MUST | [^1] (bind mounts)
`rslave` | MUST | [^1] (bind mounts)
`rstrictatime` | SHOULD | Recursive `strictatime` [^3]
`rsuid` | SHOULD | Recursive `suid` [^3]
`rsymfollow` | SHOULD | Recursive `symfollow` [^3]
`runbindable` | MUST | [^1] (bind mounts)
`rw` | MUST | [^2]
`shared` | MUST | [^2]
`silent` | MUST | [^2]
`slave` | MUST | [^1] (bind mounts)
`strictatime` | MUST | [^2]
`suid` | MUST | [^2]
`symfollow` | SHOULD | Opposite of `nosymfollow`
`sync` | MUST | [^2]
`tmpcopyup` | MAY | copy up the contents to a tmpfs
`unbindable` | MUST | [^1] (bind mounts)

[^1]: Corresponds to [`mount(8)` (filesystem-specific)][mount.8-filesystem-specific].
[^2]: Corresponds to [`mount(8)` (filesystem-independent)][mount.8-filesystem-independent].
[^3]: These `AT_RECURSIVE` options need kernel 5.12 or later. See [`mount_setattr(2)`][mount_setattr.2]

Runtimes MAY also implement custom option strings that are not listed in the table above.
If a custom option string is already recognized by [`mount(8)`][mount.8], the runtime SHOULD follow the behavior of [`mount(8)`][mount.8].

Runtimes SHOULD pass unknown options to [`mount(2)`][mount.2] via the fifth argument (`const void *data`).

### Example (Windows)

```json
Expand Down Expand Up @@ -1004,6 +1078,7 @@ Here is a full example `config.json` for reference.
[mount.8]: http://man7.org/linux/man-pages/man8/mount.8.html
[mount.8-filesystem-independent]: http://man7.org/linux/man-pages/man8/mount.8.html#FILESYSTEM-INDEPENDENT_MOUNT_OPTIONS
[mount.8-filesystem-specific]: http://man7.org/linux/man-pages/man8/mount.8.html#FILESYSTEM-SPECIFIC_MOUNT_OPTIONS
[mount_setattr.2]: http://man7.org/linux/man-pages/man2/mount_setattr.2.html
[getrlimit.2]: http://man7.org/linux/man-pages/man2/getrlimit.2.html
[getrlimit.3]: http://pubs.opengroup.org/onlinepubs/9699919799/functions/getrlimit.html
[stdin.3]: http://man7.org/linux/man-pages/man3/stdin.3.html
Expand Down

0 comments on commit 55c5f5e

Please sign in to comment.