diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2019-07-18 19:50:22 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-07-18 19:50:22 +0200 |
commit | 2254a35d3a61c6d0793b8d6994698ab5bad1d6ac (patch) | |
tree | 241a88f597c90da1a54df2406c4d9f3d8edd1455 /pkg/spec/config_linux.go | |
parent | 1065548f9134e0e02bc6ce947da8c140c1a83040 (diff) | |
parent | 350ede1eeb6ab33bce2918d7768b940c255e63c6 (diff) | |
download | podman-2254a35d3a61c6d0793b8d6994698ab5bad1d6ac.tar.gz podman-2254a35d3a61c6d0793b8d6994698ab5bad1d6ac.tar.bz2 podman-2254a35d3a61c6d0793b8d6994698ab5bad1d6ac.zip |
Merge pull request #3593 from giuseppe/rootless-privileged-devices
rootless: add host devices with --privileged
Diffstat (limited to 'pkg/spec/config_linux.go')
-rw-r--r-- | pkg/spec/config_linux.go | 41 |
1 files changed, 39 insertions, 2 deletions
diff --git a/pkg/spec/config_linux.go b/pkg/spec/config_linux.go index 9f6a4a058..a84e9a72f 100644 --- a/pkg/spec/config_linux.go +++ b/pkg/spec/config_linux.go @@ -8,6 +8,7 @@ import ( "path/filepath" "strings" + "github.com/containers/libpod/pkg/rootless" "github.com/opencontainers/runc/libcontainer/configs" "github.com/opencontainers/runc/libcontainer/devices" spec "github.com/opencontainers/runtime-spec/specs-go" @@ -118,8 +119,44 @@ func (c *CreateConfig) addPrivilegedDevices(g *generate.Generator) error { return err } g.ClearLinuxDevices() - for _, d := range hostDevices { - g.AddDevice(Device(d)) + + if rootless.IsRootless() { + mounts := make(map[string]interface{}) + for _, m := range g.Mounts() { + mounts[m.Destination] = true + } + newMounts := []spec.Mount{} + for _, d := range hostDevices { + devMnt := spec.Mount{ + Destination: d.Path, + Type: TypeBind, + Source: d.Path, + Options: []string{"slave", "nosuid", "noexec", "rw", "rbind"}, + } + if d.Path == "/dev/ptmx" || strings.HasPrefix(d.Path, "/dev/tty") { + continue + } + if _, found := mounts[d.Path]; found { + continue + } + st, err := os.Stat(d.Path) + if err != nil { + if err == unix.EPERM { + continue + } + return errors.Wrapf(err, "stat %s", d.Path) + } + // Skip devices that the user has not access to. + if st.Mode()&0007 == 0 { + continue + } + newMounts = append(newMounts, devMnt) + } + g.Config.Mounts = append(newMounts, g.Config.Mounts...) + } else { + for _, d := range hostDevices { + g.AddDevice(Device(d)) + } } // Add resources device - need to clear the existing one first. |