mirror of
https://github.com/opencontainers/runc.git
synced 2025-10-22 23:19:31 +08:00
Fix build-tags in libcontainer/devices
Allows importing this package on Windows (for the types) Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
@@ -168,3 +168,7 @@ func (d *Rule) CgroupString() string {
|
|||||||
}
|
}
|
||||||
return fmt.Sprintf("%c %s:%s %s", d.Type, major, minor, d.Permissions)
|
return fmt.Sprintf("%c %s:%s %s", d.Type, major, minor, d.Permissions)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (d *Rule) Mkdev() (uint64, error) {
|
||||||
|
return mkDev(d)
|
||||||
|
}
|
||||||
|
@@ -4,13 +4,118 @@ package devices
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
"golang.org/x/sys/unix"
|
"golang.org/x/sys/unix"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (d *Rule) Mkdev() (uint64, error) {
|
var (
|
||||||
|
// ErrNotADevice denotes that a file is not a valid linux device.
|
||||||
|
ErrNotADevice = errors.New("not a device node")
|
||||||
|
)
|
||||||
|
|
||||||
|
// Testing dependencies
|
||||||
|
var (
|
||||||
|
unixLstat = unix.Lstat
|
||||||
|
ioutilReadDir = ioutil.ReadDir
|
||||||
|
)
|
||||||
|
|
||||||
|
func mkDev(d *Rule) (uint64, error) {
|
||||||
if d.Major == Wildcard || d.Minor == Wildcard {
|
if d.Major == Wildcard || d.Minor == Wildcard {
|
||||||
return 0, errors.New("cannot mkdev() device with wildcards")
|
return 0, errors.New("cannot mkdev() device with wildcards")
|
||||||
}
|
}
|
||||||
return unix.Mkdev(uint32(d.Major), uint32(d.Minor)), nil
|
return unix.Mkdev(uint32(d.Major), uint32(d.Minor)), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Given the path to a device and its cgroup_permissions(which cannot be easily queried) look up the
|
||||||
|
// information about a linux device and return that information as a Device struct.
|
||||||
|
func DeviceFromPath(path, permissions string) (*Device, error) {
|
||||||
|
var stat unix.Stat_t
|
||||||
|
err := unixLstat(path, &stat)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
devType Type
|
||||||
|
mode = stat.Mode
|
||||||
|
devNumber = uint64(stat.Rdev)
|
||||||
|
major = unix.Major(devNumber)
|
||||||
|
minor = unix.Minor(devNumber)
|
||||||
|
)
|
||||||
|
switch mode & unix.S_IFMT {
|
||||||
|
case unix.S_IFBLK:
|
||||||
|
devType = BlockDevice
|
||||||
|
case unix.S_IFCHR:
|
||||||
|
devType = CharDevice
|
||||||
|
case unix.S_IFIFO:
|
||||||
|
devType = FifoDevice
|
||||||
|
default:
|
||||||
|
return nil, ErrNotADevice
|
||||||
|
}
|
||||||
|
return &Device{
|
||||||
|
Rule: Rule{
|
||||||
|
Type: devType,
|
||||||
|
Major: int64(major),
|
||||||
|
Minor: int64(minor),
|
||||||
|
Permissions: Permissions(permissions),
|
||||||
|
},
|
||||||
|
Path: path,
|
||||||
|
FileMode: os.FileMode(mode &^ unix.S_IFMT),
|
||||||
|
Uid: stat.Uid,
|
||||||
|
Gid: stat.Gid,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// HostDevices returns all devices that can be found under /dev directory.
|
||||||
|
func HostDevices() ([]*Device, error) {
|
||||||
|
return GetDevices("/dev")
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetDevices recursively traverses a directory specified by path
|
||||||
|
// and returns all devices found there.
|
||||||
|
func GetDevices(path string) ([]*Device, error) {
|
||||||
|
files, err := ioutilReadDir(path)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
var out []*Device
|
||||||
|
for _, f := range files {
|
||||||
|
switch {
|
||||||
|
case f.IsDir():
|
||||||
|
switch f.Name() {
|
||||||
|
// ".lxc" & ".lxd-mounts" added to address https://github.com/lxc/lxd/issues/2825
|
||||||
|
// ".udev" added to address https://github.com/opencontainers/runc/issues/2093
|
||||||
|
case "pts", "shm", "fd", "mqueue", ".lxc", ".lxd-mounts", ".udev":
|
||||||
|
continue
|
||||||
|
default:
|
||||||
|
sub, err := GetDevices(filepath.Join(path, f.Name()))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
out = append(out, sub...)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
case f.Name() == "console":
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
device, err := DeviceFromPath(filepath.Join(path, f.Name()), "rwm")
|
||||||
|
if err != nil {
|
||||||
|
if err == ErrNotADevice {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if os.IsNotExist(err) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if device.Type == FifoDevice {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
out = append(out, device)
|
||||||
|
}
|
||||||
|
return out, nil
|
||||||
|
}
|
||||||
|
@@ -1,3 +1,5 @@
|
|||||||
|
// +build !windows
|
||||||
|
|
||||||
package devices
|
package devices
|
||||||
|
|
||||||
import (
|
import (
|
@@ -1,5 +1,5 @@
|
|||||||
package devices
|
package devices
|
||||||
|
|
||||||
func (d *Rule) Mkdev() (uint64, error) {
|
func mkDev(_ *Rule) (uint64, error) {
|
||||||
return 0, nil
|
return 0, nil
|
||||||
}
|
}
|
||||||
|
@@ -1,112 +0,0 @@
|
|||||||
package devices
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
"path/filepath"
|
|
||||||
|
|
||||||
"golang.org/x/sys/unix"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// ErrNotADevice denotes that a file is not a valid linux device.
|
|
||||||
ErrNotADevice = errors.New("not a device node")
|
|
||||||
)
|
|
||||||
|
|
||||||
// Testing dependencies
|
|
||||||
var (
|
|
||||||
unixLstat = unix.Lstat
|
|
||||||
ioutilReadDir = ioutil.ReadDir
|
|
||||||
)
|
|
||||||
|
|
||||||
// Given the path to a device and its cgroup_permissions(which cannot be easily queried) look up the
|
|
||||||
// information about a linux device and return that information as a Device struct.
|
|
||||||
func DeviceFromPath(path, permissions string) (*Device, error) {
|
|
||||||
var stat unix.Stat_t
|
|
||||||
err := unixLstat(path, &stat)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
var (
|
|
||||||
devType Type
|
|
||||||
mode = stat.Mode
|
|
||||||
devNumber = uint64(stat.Rdev)
|
|
||||||
major = unix.Major(devNumber)
|
|
||||||
minor = unix.Minor(devNumber)
|
|
||||||
)
|
|
||||||
switch mode & unix.S_IFMT {
|
|
||||||
case unix.S_IFBLK:
|
|
||||||
devType = BlockDevice
|
|
||||||
case unix.S_IFCHR:
|
|
||||||
devType = CharDevice
|
|
||||||
case unix.S_IFIFO:
|
|
||||||
devType = FifoDevice
|
|
||||||
default:
|
|
||||||
return nil, ErrNotADevice
|
|
||||||
}
|
|
||||||
return &Device{
|
|
||||||
Rule: Rule{
|
|
||||||
Type: devType,
|
|
||||||
Major: int64(major),
|
|
||||||
Minor: int64(minor),
|
|
||||||
Permissions: Permissions(permissions),
|
|
||||||
},
|
|
||||||
Path: path,
|
|
||||||
FileMode: os.FileMode(mode &^ unix.S_IFMT),
|
|
||||||
Uid: stat.Uid,
|
|
||||||
Gid: stat.Gid,
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// HostDevices returns all devices that can be found under /dev directory.
|
|
||||||
func HostDevices() ([]*Device, error) {
|
|
||||||
return GetDevices("/dev")
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetDevices recursively traverses a directory specified by path
|
|
||||||
// and returns all devices found there.
|
|
||||||
func GetDevices(path string) ([]*Device, error) {
|
|
||||||
files, err := ioutilReadDir(path)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
var out []*Device
|
|
||||||
for _, f := range files {
|
|
||||||
switch {
|
|
||||||
case f.IsDir():
|
|
||||||
switch f.Name() {
|
|
||||||
// ".lxc" & ".lxd-mounts" added to address https://github.com/lxc/lxd/issues/2825
|
|
||||||
// ".udev" added to address https://github.com/opencontainers/runc/issues/2093
|
|
||||||
case "pts", "shm", "fd", "mqueue", ".lxc", ".lxd-mounts", ".udev":
|
|
||||||
continue
|
|
||||||
default:
|
|
||||||
sub, err := GetDevices(filepath.Join(path, f.Name()))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
out = append(out, sub...)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
case f.Name() == "console":
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
device, err := DeviceFromPath(filepath.Join(path, f.Name()), "rwm")
|
|
||||||
if err != nil {
|
|
||||||
if err == ErrNotADevice {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if os.IsNotExist(err) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if device.Type == FifoDevice {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
out = append(out, device)
|
|
||||||
}
|
|
||||||
return out, nil
|
|
||||||
}
|
|
Reference in New Issue
Block a user