diff options
| author | Gustav Sörnäs <gustav@sornas.net> | 2020-11-23 04:07:45 +0100 |
|---|---|---|
| committer | Gustav Sörnäs <gustav@sornas.net> | 2020-11-23 04:07:45 +0100 |
| commit | 3f7102d7193d3c0f6cdda8e3106aac77188bb475 (patch) | |
| tree | 83a1a7b07d83bdabe93c10c0eebbe56d411a76fe | |
| parent | cda174afc8e1bf6b779726965f5eaa030d80b1dc (diff) | |
| download | pintos-rs-3f7102d7193d3c0f6cdda8e3106aac77188bb475.tar.gz | |
intial rs
| -rw-r--r-- | TODO | 19 | ||||
| -rw-r--r-- | halt/Cargo.toml | 18 | ||||
| -rw-r--r-- | halt/main.c | 5 | ||||
| -rw-r--r-- | halt/rust-toolchain | 1 | ||||
| -rw-r--r-- | halt/rust.h | 1 | ||||
| -rw-r--r-- | halt/src/main.rs | 26 |
6 files changed, 70 insertions, 0 deletions
@@ -0,0 +1,19 @@ +1: Hijacka deras Makefiler så de bygger rust, kopierar rust FFI och länkar. +Deras Makefiler fungerar uppenbarligen och koden borde kunna anropa rust FFI utan problem. + +2: Anropa deras libc från Rust, men börja med att typ returnera en int. + +3: userprog/rust.c som skickar allt till rust. + +4: build.rs som hanterar hela bygg-grejen. + +. +. +. + +99: i686-unknown-pintos + +rust.h: +int rust_main(int argc, char **argv); + +Haltar via exit i entry.c diff --git a/halt/Cargo.toml b/halt/Cargo.toml new file mode 100644 index 0000000..160a513 --- /dev/null +++ b/halt/Cargo.toml @@ -0,0 +1,18 @@ +[package] +name = "halt" +version = "0.1.0" +authors = ["Gustav Sörnäs <gustav@sornas.net>"] +edition = "2018" + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[profile.dev] +panic = "abort" + +[profile.release] +panic = "abort" + +[dependencies.libc] +version = "0.2" +default-features = false +features = ["extra_traits"] diff --git a/halt/main.c b/halt/main.c new file mode 100644 index 0000000..c89be21 --- /dev/null +++ b/halt/main.c @@ -0,0 +1,5 @@ +#include "rust.h" + +void _start (int argc, char **argv) { + main(); +} diff --git a/halt/rust-toolchain b/halt/rust-toolchain new file mode 100644 index 0000000..adfa491 --- /dev/null +++ b/halt/rust-toolchain @@ -0,0 +1 @@ +nightly-i686-unknown-linux-gnu diff --git a/halt/rust.h b/halt/rust.h new file mode 100644 index 0000000..eba2976 --- /dev/null +++ b/halt/rust.h @@ -0,0 +1 @@ +int main(void); diff --git a/halt/src/main.rs b/halt/src/main.rs new file mode 100644 index 0000000..8abf38a --- /dev/null +++ b/halt/src/main.rs @@ -0,0 +1,26 @@ +#![no_std] +#![no_main] +#![feature(start)] +//#![feature(asm)] +//#![link_args = "-L -lmain"] + +#[panic_handler] +fn panic(_info: &core::panic::PanicInfo) -> ! { + loop {} +} + +#[no_mangle] +pub unsafe extern "C" fn main() { + exit(0x69); +} + +#[link(name="pintos", kind="static")] +extern { + fn exit(status: i32); +} + +//#[no_mangle] +//#[start] +//unsafe extern "C" fn _start() { +// exit(main()); +//} |
