sandbox/mount: pass custom tmpfs name
The tmpfs driver allows arbitrary fsname. Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
parent
a092b042ab
commit
2eff470091
@ -82,7 +82,7 @@ func bindMount(src, dest string, flags int) error {
|
|||||||
fmt.Sprintf("cannot bind %q on %q:", src, dest))
|
fmt.Sprintf("cannot bind %q on %q:", src, dest))
|
||||||
}
|
}
|
||||||
|
|
||||||
func mountTmpfs(name string, size int, perm os.FileMode) error {
|
func mountTmpfs(fsname, name string, size int, perm os.FileMode) error {
|
||||||
target := toSysroot(name)
|
target := toSysroot(name)
|
||||||
if err := os.MkdirAll(target, perm); err != nil {
|
if err := os.MkdirAll(target, perm); err != nil {
|
||||||
return err
|
return err
|
||||||
@ -91,7 +91,7 @@ func mountTmpfs(name string, size int, perm os.FileMode) error {
|
|||||||
if size > 0 {
|
if size > 0 {
|
||||||
opt += fmt.Sprintf(",size=%d", size)
|
opt += fmt.Sprintf(",size=%d", size)
|
||||||
}
|
}
|
||||||
return fmsg.WrapErrorSuffix(syscall.Mount("tmpfs", target, "tmpfs",
|
return fmsg.WrapErrorSuffix(syscall.Mount(fsname, target, "tmpfs",
|
||||||
syscall.MS_NOSUID|syscall.MS_NODEV, opt),
|
syscall.MS_NOSUID|syscall.MS_NODEV, opt),
|
||||||
fmt.Sprintf("cannot mount tmpfs on %q:", name))
|
fmt.Sprintf("cannot mount tmpfs on %q:", name))
|
||||||
}
|
}
|
||||||
|
@ -87,7 +87,7 @@ func (t *MountTmpfs) apply(*InitParams) error {
|
|||||||
return fmsg.WrapError(syscall.EBADE,
|
return fmsg.WrapError(syscall.EBADE,
|
||||||
fmt.Sprintf("size %d out of bounds", t.Size))
|
fmt.Sprintf("size %d out of bounds", t.Size))
|
||||||
}
|
}
|
||||||
return mountTmpfs(t.Path, t.Size, t.Perm)
|
return mountTmpfs("tmpfs", t.Path, t.Size, t.Perm)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *MountTmpfs) Is(op Op) bool { vt, ok := op.(*MountTmpfs); return ok && *t == *vt }
|
func (t *MountTmpfs) Is(op Op) bool { vt, ok := op.(*MountTmpfs); return ok && *t == *vt }
|
||||||
|
Loading…
Reference in New Issue
Block a user