Skip to content

Commit

Permalink
feat: add stdio redirection example
Browse files Browse the repository at this point in the history
  • Loading branch information
sevenautumns committed Jun 18, 2024
1 parent 88206f1 commit 72c3ea0
Show file tree
Hide file tree
Showing 9 changed files with 137 additions and 12 deletions.
15 changes: 11 additions & 4 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 5 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,15 +15,18 @@ members = [
"examples/ping/client",
"examples/ping/server",

"examples/dev_random",

"examples/ping_queue/client",
"examples/ping_queue/server",

"examples/dev_random",

"examples/redirect_stdio"
]

[workspace.dependencies]
a653rs = "0.6"
a653rs-linux.path = "partition"
anyhow = "1.0"
log = "0"
nix = { version = "0.29", features = ["socket", "process", "fs", "uio", "signal", "user", "mount", "event", "sched"] }
memmap2 = "0.9"
Expand Down
2 changes: 1 addition & 1 deletion core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,8 @@ memmap2.workspace = true
procfs.workspace = true
polling.workspace = true
itertools.workspace = true
anyhow.workspace = true

anyhow = "1.0"
log = "0"
walkdir = "2.3"
serde = { version = "1.0", features = ["derive"] }
Expand Down
13 changes: 13 additions & 0 deletions examples/redirect_stdio/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
[package]
name = "redirect_stdio"
version = "0.1.0"
edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
a653rs = { workspace = true, features = ["macros"] }
a653rs-linux.workspace = true
log.workspace = true
nix.workspace = true
anyhow.workspace = true
12 changes: 12 additions & 0 deletions examples/redirect_stdio/redirect_stdio.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
major_frame: 1s
partitions:
- id: 0
name: partition_0
duration: 1s
offset: 0ms
period: 1s
image: ./target/x86_64-unknown-linux-musl/release/redirect_stdio
mounts:
- [ /tmp/redirect_stdio/stdout, /stdout ]
- [ /tmp/redirect_stdio/stderr, /stderr ]
- [ /tmp/redirect_stdio/stdin, /stdin ]
75 changes: 75 additions & 0 deletions examples/redirect_stdio/src/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
use std::fs::OpenOptions;
use std::os::fd::AsRawFd;
use std::path::Path;

use a653rs::partition;
use a653rs::prelude::PartitionExt;
use a653rs_linux::partition::ApexLogger;
use anyhow::Result;
use log::LevelFilter;

fn replace_stdio<T: AsRawFd, U: AsRef<Path>>(stdio: T, new: U, write: bool) -> Result<()> {
let new = OpenOptions::new()
.write(write)
.read(!write)
.truncate(write)
.open(new)?;
nix::unistd::dup2(new.as_raw_fd(), stdio.as_raw_fd())?;
Ok(())
}

fn main() {
replace_stdio(std::io::stdin(), "/stdin", false).unwrap();
replace_stdio(std::io::stdout(), "/stdout", true).unwrap();
replace_stdio(std::io::stderr(), "/stderr", true).unwrap();

ApexLogger::install_panic_hook();
ApexLogger::install_logger(LevelFilter::Trace).unwrap();

redirect_stdio::Partition.run()
}

#[partition(a653rs_linux::partition::ApexLinuxPartition)]
mod redirect_stdio {
use log::info;
use std::{io::BufRead, time::Duration};

#[start(cold)]
fn cold_start(mut ctx: start::Context) {
// create and start an aperiodic process
ctx.create_process_0().unwrap().start().unwrap();
}

// do the same as a cold_start
#[start(warm)]
fn warm_start(ctx: start::Context) {
cold_start(ctx);
}

// this aperiodic process opens /dev/random and reads some random bytes from it
#[aperiodic(
time_capacity = "Infinite",
stack_size = "8KB",
base_priority = 1,
deadline = "Soft"
)]
fn process_0(_: process_0::Context) {
info!("started process_0");

println!("Start reading stdin to stdout");
let stdin = std::io::stdin();
for line in stdin.lock().lines() {
println!("{}", line.unwrap())
}
println!("Finished reading stdin to stdout");

eprintln!("Error was encountered: None");
eprintln!("But it was printed to stderr");

// TODO wait for https://github.com/DLR-FT/a653rs/issues/22 to be fixed
// Hypervisor::set_partition_mode(OperatingMode::Idle);
loop {
std::thread::sleep(Duration::from_secs(10))
}
}
}
20 changes: 17 additions & 3 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,18 @@
name = "hello_part_no_macros";
partitions = [ "hello_part_no_macros" ];
}
{
name = "redirect_stdio";
partitions = [ "redirect_stdio" ];
preRun = ''
tmpdir=$(mktemp -d -t redirect_stdio.XXXXXXXXXX)
cp examples/redirect_stdio/redirect_stdio.yaml $tmpdir/config.yaml
sed -i 's@/tmp/redirect_stdio@'"$tmpdir"'@g' $tmpdir/config.yaml
touch $tmpdir/std{out,err}
echo $'hello\nworld!\n' > $tmpdir/stdin
'';
yaml = "$tmpdir/config.yaml";
}
{
name = "fuel_tank";
partitions = [ "fuel_tank_simulation" "fuel_tank_controller" ];
Expand Down Expand Up @@ -103,7 +115,7 @@
cargoTestOptions = x: x ++ [ "--package" pname ];
} // env;
} // (builtins.listToAttrs (builtins.map
({ name, partitions }: {
({ name, partitions, ... }: {
name = "example-${name}";
value = naersk-lib.buildPackage
rec {
Expand Down Expand Up @@ -181,7 +193,7 @@
inherit (nixpkgs.lib) flatten;
in
flatten (map
({ name, partitions }: [
({ name, partitions, preRun ? "", yaml ? "examples/${name}/${name}.yaml" }: [
{
name = "run-example-${name}";
command = ''
Expand All @@ -192,8 +204,10 @@
# prepend PATH so that partition images can be found
PATH="target/${rust-target}/release:$PATH"
${preRun}
# (build &) run hypervisor
RUST_LOG=''${RUST_LOG:=trace} cargo run --package a653rs-linux-hypervisor --release -- examples/${name}/${name}.yaml $@
RUST_LOG=''${RUST_LOG:=trace} cargo run --package a653rs-linux-hypervisor --release -- ${yaml} $@
'';
help = "Run the ${name} example, consisting of the partitions: ${concatStringsSep "," partitions}";
category = "example";
Expand Down
3 changes: 2 additions & 1 deletion hypervisor/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ polling.workspace = true
itertools.workspace = true
once_cell.workspace = true
bytesize.workspace = true
anyhow = "1.0"
anyhow.workspace = true

tempfile = "3.3"
clone3 = "0.2"
serde = { version = "1.0", features = ["derive"] }
Expand Down
2 changes: 1 addition & 1 deletion partition/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,9 @@ memmap2.workspace = true
procfs.workspace = true
polling.workspace = true
once_cell.workspace = true
anyhow.workspace = true

lazy_static = "1.4"
anyhow = "1.0"
log.workspace = true
tinyvec = "1.6"
oneshot = "0.1.6"

0 comments on commit 72c3ea0

Please sign in to comment.