aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorGustav Sörnäs <gustav@sornas.net>2020-11-24 01:33:01 +0100
committerGustav Sörnäs <gustav@sornas.net>2020-11-24 01:33:01 +0100
commit431c40e275a5055d9f144de03dbc8cfc90ed3f6e (patch)
treeb311bcda0d5d6b445a123f4be7a2d4f2d756addb /kernel
parent0f45ab11bd271535f178b58aab1ae9c36474d995 (diff)
downloadpintos-rs-431c40e275a5055d9f144de03dbc8cfc90ed3f6e.tar.gz
add kernel-rs
Diffstat (limited to 'kernel')
-rw-r--r--kernel/Cargo.toml22
-rw-r--r--kernel/Makefile12
-rw-r--r--kernel/rust-toolchain1
-rw-r--r--kernel/src/lib.rs17
4 files changed, 52 insertions, 0 deletions
diff --git a/kernel/Cargo.toml b/kernel/Cargo.toml
new file mode 100644
index 0000000..738559f
--- /dev/null
+++ b/kernel/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/Makefile b/kernel/Makefile
new file mode 100644
index 0000000..49a4d42
--- /dev/null
+++ b/kernel/Makefile
@@ -0,0 +1,12 @@
+all: debug
+
+debug:
+ cargo build
+
+release:
+ cargo build --release
+
+clean:
+ cargo clean
+
+.PHONY: all clean debug release
diff --git a/kernel/rust-toolchain b/kernel/rust-toolchain
new file mode 100644
index 0000000..adfa491
--- /dev/null
+++ b/kernel/rust-toolchain
@@ -0,0 +1 @@
+nightly-i686-unknown-linux-gnu
diff --git a/kernel/src/lib.rs b/kernel/src/lib.rs
new file mode 100644
index 0000000..d7dafa1
--- /dev/null
+++ b/kernel/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\n".as_ptr());
+ thread_exit();
+}
+
+extern {
+ fn thread_exit();
+ fn printf(format: *const u8, ...);
+}