aboutsummaryrefslogtreecommitdiffstats
path: root/kernel-rs
diff options
context:
space:
mode:
authorGustav Sörnäs <gustav@sornas.net>2020-11-24 15:14:19 +0100
committerGustav Sörnäs <gustav@sornas.net>2020-11-24 15:15:04 +0100
commitebb4935f56e96597e5993708118cc75711c1c87e (patch)
tree028513ba0c91db9149d20f9baf398664a8c0d1f3 /kernel-rs
parenteba74d74502641a4565dc6011db33742e8450680 (diff)
downloadpintos-rs-ebb4935f56e96597e5993708118cc75711c1c87e.tar.gz
rename kernel -> kernel-rs
Diffstat (limited to 'kernel-rs')
-rw-r--r--kernel-rs/Cargo.toml22
-rw-r--r--kernel-rs/rust-toolchain1
-rw-r--r--kernel-rs/src/lib.rs17
3 files changed, 40 insertions, 0 deletions
diff --git a/kernel-rs/Cargo.toml b/kernel-rs/Cargo.toml
new file mode 100644
index 0000000..738559f
--- /dev/null
+++ b/kernel-rs/Cargo.toml
@@ -0,0 +1,22 @@
+[package]
+name = "kernel"
+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
+
+[lib]
+name = "kernel"
+crate-type = ["staticlib"]
+
+[profile.dev]
+panic = "abort"
+
+[profile.release]
+panic = "abort"
+
+[dependencies.libc]
+version = "0.2"
+default-features = false
+features = ["extra_traits"]
diff --git a/kernel-rs/rust-toolchain b/kernel-rs/rust-toolchain
new file mode 100644
index 0000000..adfa491
--- /dev/null
+++ b/kernel-rs/rust-toolchain
@@ -0,0 +1 @@
+nightly-i686-unknown-linux-gnu
diff --git a/kernel-rs/src/lib.rs b/kernel-rs/src/lib.rs
new file mode 100644
index 0000000..7893919
--- /dev/null
+++ b/kernel-rs/src/lib.rs
@@ -0,0 +1,17 @@
+#![no_std]
+
+#[panic_handler]
+fn panic(_info: &core::panic::PanicInfo) -> ! {
+ loop {}
+}
+
+#[no_mangle]
+pub unsafe extern "C" fn syscall_handler() {
+ printf("c suger lmao xd %d\n".as_ptr(), 69);
+ thread_exit();
+}
+
+extern {
+ fn thread_exit();
+ fn printf(format: *const u8, ...);
+}