redox/programs/contain/src/main.rs

37 lines
816 B
Rust
Raw Normal View History

extern crate syscall;
2016-11-17 20:12:02 +01:00
use std::os::unix::process::CommandExt;
use std::process::Command;
pub fn main() {
2016-11-17 20:12:02 +01:00
let names = [
"file",
"rand",
"tcp",
"udp"
];
let command = "sh";
2016-11-17 06:14:02 +01:00
let pid = unsafe { syscall::clone(0).unwrap() };
if pid == 0 {
2016-11-17 20:12:02 +01:00
let mut name_ptrs = Vec::new();
for name in names.iter() {
name_ptrs.push([name.as_ptr() as usize, name.len()]);
}
2016-11-17 06:14:02 +01:00
2016-11-17 20:12:02 +01:00
syscall::setns(&name_ptrs).unwrap();
2016-11-17 06:14:02 +01:00
2016-11-17 20:12:02 +01:00
println!("Entering container: {}", command);
2016-11-17 06:14:02 +01:00
2016-11-17 20:12:02 +01:00
let err = Command::new(command).exec();
panic!("contain: failed to launch {}: {}", command, err);
} else {
let mut status = 0;
syscall::waitpid(pid, &mut status, 0).unwrap();
2016-11-17 20:12:02 +01:00
println!("Exiting container: {:X}", status);
}
}