Started to implement syscall.rs
This commit is contained in:
parent
e117ec2132
commit
8e81358e51
7
Cargo.lock
generated
7
Cargo.lock
generated
@ -6,9 +6,16 @@ version = 3
|
||||
name = "burritos"
|
||||
version = "0.1.0"
|
||||
dependencies = [
|
||||
"cc",
|
||||
"libc",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "cc"
|
||||
version = "1.0.79"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "50d30906286121d95be3d479533b458f87493b30a4b5f79a607db8f5d11aa91f"
|
||||
|
||||
[[package]]
|
||||
name = "libc"
|
||||
version = "0.2.140"
|
||||
|
@ -8,3 +8,6 @@ libc = { version = "0.2.139", features = ["extra_traits"] }
|
||||
|
||||
[registries.crates-io]
|
||||
protocol = "sparse"
|
||||
|
||||
[build-dependencies]
|
||||
cc = "1.0"
|
5
build.rs
Normal file
5
build.rs
Normal file
@ -0,0 +1,5 @@
|
||||
fn main() {
|
||||
cc::Build::new()
|
||||
.file("test/userlib/sys.s")
|
||||
.compile("my-asm-lib");
|
||||
}
|
@ -65,7 +65,7 @@ __start:
|
||||
|
||||
.globl Halt
|
||||
.type __Halt, @function
|
||||
Halt:
|
||||
Shutdown:
|
||||
addi a7,zero,SC_HALT
|
||||
ecall
|
||||
jr ra
|
||||
|
21
test/userlib/syscall.rs
Normal file
21
test/userlib/syscall.rs
Normal file
@ -0,0 +1,21 @@
|
||||
pub struct Burritos_Time {
|
||||
seconds: i64,
|
||||
nanos: i64
|
||||
}
|
||||
pub struct ThreadId{
|
||||
id: u64
|
||||
}
|
||||
pub struct t_error{
|
||||
t: i32
|
||||
}
|
||||
extern "C"{
|
||||
fn Shutdown() -> ();
|
||||
fn SysTime(t: Burritos_Time) -> ();
|
||||
fn Exit(status: i32) -> ();
|
||||
fn Exec(name: String) -> ThreadId;
|
||||
fn newThread(debug_name: String, func: i32, arg: i32) -> ThreadId;
|
||||
fn Join (id: ThreadId) -> t_error;
|
||||
fn Yield() -> ();
|
||||
fn Perror(mess: String) -> ();
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user