mirror of https://github.com/xSmurf/oz.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
3.7 KiB
136 lines
3.7 KiB
9 years ago
|
package ozinit
|
||
9 years ago
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"github.com/subgraph/oz/fs"
|
||
|
"os"
|
||
|
"path"
|
||
|
"syscall"
|
||
|
)
|
||
|
|
||
|
var basicBindDirs = []string{
|
||
|
"/bin", "/lib", "/lib64", "/usr", "/etc",
|
||
|
}
|
||
|
|
||
|
var basicEmptyDirs = []string{
|
||
|
"/sbin", "/var", "/var/lib",
|
||
|
"/var/cache", "/home", "/boot",
|
||
|
"/tmp", "/run", "/run/user",
|
||
|
"/run/lock", "/root",
|
||
|
"/opt", "/srv", "/dev", "/proc",
|
||
|
"/sys", "/mnt", "/media",
|
||
|
//"/run/shm",
|
||
|
}
|
||
|
|
||
|
var basicSymlinks = [][2]string{
|
||
|
{"/run", "/var/run"},
|
||
|
{"/tmp", "/var/tmp"},
|
||
|
{"/run/lock", "/var/lock"},
|
||
|
{"/dev/shm", "/run/shm"},
|
||
|
}
|
||
|
|
||
|
var deviceSymlinks = [][2]string{
|
||
|
{"/proc/self/fd", "/dev/fd"},
|
||
|
{"/proc/self/fd/2", "/dev/stderr"},
|
||
|
{"/proc/self/fd/0", "/dev/stdin"},
|
||
|
{"/proc/self/fd/1", "/dev/stdout"},
|
||
|
{"/dev/pts/ptmx", "/dev/ptmx"},
|
||
|
}
|
||
|
|
||
|
var basicBlacklist = []string{
|
||
9 years ago
|
"/usr/sbin", "/sbin", "/etc/X11",
|
||
|
"${PATH}/sudo", "${PATH}/su",
|
||
9 years ago
|
"${PATH}/xinput", "${PATH}/strace",
|
||
|
"${PATH}/mount", "${PATH}/umount",
|
||
9 years ago
|
"${PATH}/fusermount",
|
||
9 years ago
|
}
|
||
|
|
||
|
type fsDeviceDefinition struct {
|
||
|
path string
|
||
|
mode uint32
|
||
|
dev int
|
||
|
}
|
||
|
|
||
|
const ugorw = syscall.S_IRUSR | syscall.S_IWUSR | syscall.S_IRGRP | syscall.S_IWGRP | syscall.S_IROTH | syscall.S_IWOTH
|
||
|
const urwgr = syscall.S_IRUSR | syscall.S_IWUSR | syscall.S_IRGRP
|
||
|
const urw = syscall.S_IRUSR | syscall.S_IWUSR
|
||
|
|
||
|
var basicDevices = []fsDeviceDefinition{
|
||
9 years ago
|
{path: "/dev/full", mode: syscall.S_IFCHR | ugorw, dev: _makedev(1, 7)},
|
||
|
{path: "/dev/null", mode: syscall.S_IFCHR | ugorw, dev: _makedev(1, 3)},
|
||
|
{path: "/dev/random", mode: syscall.S_IFCHR | ugorw, dev: _makedev(1, 8)},
|
||
|
|
||
|
{path: "/dev/console", mode: syscall.S_IFCHR | urw, dev: _makedev(5, 1)},
|
||
|
{path: "/dev/tty", mode: syscall.S_IFCHR | ugorw, dev: _makedev(5, 0)},
|
||
|
{path: "/dev/tty1", mode: syscall.S_IFREG | urwgr, dev: 0},
|
||
|
{path: "/dev/tty2", mode: syscall.S_IFREG | urwgr, dev: 0},
|
||
|
{path: "/dev/tty3", mode: syscall.S_IFREG | urwgr, dev: 0},
|
||
|
{path: "/dev/tty4", mode: syscall.S_IFREG | urwgr, dev: 0},
|
||
|
|
||
|
{path: "/dev/urandom", mode: syscall.S_IFCHR | ugorw, dev: _makedev(1, 9)},
|
||
|
{path: "/dev/zero", mode: syscall.S_IFCHR | ugorw, dev: _makedev(1, 5)},
|
||
9 years ago
|
}
|
||
|
|
||
|
func _makedev(x, y int) int {
|
||
|
return (((x) << 8) | (y))
|
||
|
}
|
||
|
|
||
|
func setupRootfs(fsys *fs.Filesystem) error {
|
||
|
if err := os.MkdirAll(fsys.Root(), 0755); err != nil {
|
||
|
return fmt.Errorf("could not create rootfs path '%s': %v", fsys.Root(), err)
|
||
|
}
|
||
|
|
||
|
if err := syscall.Mount("", "/", "", syscall.MS_PRIVATE|syscall.MS_REC, ""); err != nil {
|
||
|
return fmt.Errorf("failed to set MS_PRIVATE on '%s': %v", "/", err)
|
||
|
}
|
||
|
|
||
|
flags := uintptr(syscall.MS_NOSUID | syscall.MS_NOEXEC | syscall.MS_NODEV)
|
||
|
if err := syscall.Mount("", fsys.Root(), "tmpfs", flags, "mode=755,gid=0"); err != nil {
|
||
|
return fmt.Errorf("failed to mount tmpfs on '%s': %v", fsys.Root(), err)
|
||
|
}
|
||
|
|
||
|
if err := syscall.Mount("", fsys.Root(), "", syscall.MS_PRIVATE, ""); err != nil {
|
||
|
return fmt.Errorf("failed to set MS_PRIVATE on '%s': %v", fsys.Root(), err)
|
||
|
}
|
||
|
|
||
|
for _, p := range basicBindDirs {
|
||
9 years ago
|
if err := fsys.BindPath(p, fs.BindReadOnly, nil); err != nil {
|
||
9 years ago
|
return fmt.Errorf("failed to bind directory '%s': %v", p, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
for _, p := range basicEmptyDirs {
|
||
|
if err := fsys.CreateEmptyDir(p); err != nil {
|
||
|
return fmt.Errorf("failed to create empty directory '%s': %v", p, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
dp := path.Join(fsys.Root(), "dev")
|
||
|
if err := syscall.Mount("", dp, "tmpfs", syscall.MS_NOSUID|syscall.MS_NOEXEC, "mode=755"); err != nil {
|
||
|
return err
|
||
|
|
||
|
}
|
||
|
for _, d := range basicDevices {
|
||
9 years ago
|
if err := fsys.CreateDevice(d.path, d.dev, d.mode); err != nil {
|
||
9 years ago
|
return err
|
||
|
}
|
||
|
}
|
||
|
|
||
|
for _, sl := range append(basicSymlinks, deviceSymlinks...) {
|
||
|
if err := fsys.CreateSymlink(sl[0], sl[1]); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if err := fsys.CreateBlacklistPaths(); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
for _, bl := range basicBlacklist {
|
||
9 years ago
|
if err := fsys.BlacklistPath(bl, nil); err != nil {
|
||
9 years ago
|
return err
|
||
|
}
|
||
|
}
|
||
|
return nil
|
||
|
}
|