Wrap syscalls in user_lib && change xstate to exit_code

pull/15/head
Yifan Wu 5 years ago
parent ad70d96155
commit 17dafb9000

@ -4,7 +4,7 @@ use crate::task::{
run_next_task
};
pub fn sys_exit(xstate: i32) -> ! {
pub fn sys_exit(exit_code: i32) -> ! {
println!("[kernel] Application exited with code {}", xstate);
mark_current_exited();
run_next_task();

@ -4,7 +4,7 @@
#[macro_use]
extern crate user_lib;
use user_lib::sys_yield;
use user_lib::yield_;
const WIDTH: usize = 10;
const HEIGHT: usize = 5;
@ -14,7 +14,7 @@ fn main() -> i32 {
for i in 0..HEIGHT {
for _ in 0..WIDTH { print!("A"); }
println!(" [{}/{}]", i + 1, HEIGHT);
sys_yield();
yield_();
}
println!("Test write_a OK!");
0

@ -4,7 +4,7 @@
#[macro_use]
extern crate user_lib;
use user_lib::sys_yield;
use user_lib::yield_;
const WIDTH: usize = 10;
const HEIGHT: usize = 2;
@ -14,7 +14,7 @@ fn main() -> i32 {
for i in 0..HEIGHT {
for _ in 0..WIDTH { print!("B"); }
println!(" [{}/{}]", i + 1, HEIGHT);
sys_yield();
yield_();
}
println!("Test write_b OK!");
0

@ -4,7 +4,7 @@
#[macro_use]
extern crate user_lib;
use user_lib::sys_yield;
use user_lib::yield_;
const WIDTH: usize = 10;
const HEIGHT: usize = 3;
@ -14,7 +14,7 @@ fn main() -> i32 {
for i in 0..HEIGHT {
for _ in 0..WIDTH { print!("C"); }
println!(" [{}/{}]", i + 1, HEIGHT);
sys_yield();
yield_();
}
println!("Test write_c OK!");
0

@ -1,11 +1,13 @@
use core::fmt::{self, Write};
use crate::syscall::{STDOUT, sys_write};
use super::write;
struct Stdout;
const STDOUT: usize = 1;
impl Write for Stdout {
fn write_str(&mut self, s: &str) -> fmt::Result {
sys_write(STDOUT, s.as_bytes());
write(STDOUT, s.as_bytes());
Ok(())
}
}

@ -12,7 +12,7 @@ mod lang_items;
#[link_section = ".text.entry"]
pub extern "C" fn _start() -> ! {
clear_bss();
syscall::sys_exit(main());
exit(main());
panic!("unreachable after sys_exit!");
}
@ -32,4 +32,8 @@ fn clear_bss() {
});
}
pub use syscall::*;
use syscall::*;
pub fn write(fd: usize, buf: &[u8]) -> isize { sys_write(fd, buf) }
pub fn exit(exit_code: i32) -> isize { sys_exit(exit_code) }
pub fn yield_() -> isize { sys_yield() }

@ -1,5 +1,3 @@
pub const STDOUT: usize = 1;
const SYSCALL_WRITE: usize = 64;
const SYSCALL_EXIT: usize = 93;
const SYSCALL_YIELD: usize = 124;
@ -22,8 +20,8 @@ pub fn sys_write(fd: usize, buffer: &[u8]) -> isize {
syscall(SYSCALL_WRITE, [fd, buffer.as_ptr() as usize, buffer.len()])
}
pub fn sys_exit(xstate: i32) -> isize {
syscall(SYSCALL_EXIT, [xstate as usize, 0, 0])
pub fn sys_exit(exit_code: i32) -> isize {
syscall(SYSCALL_EXIT, [exit_code as usize, 0, 0])
}
pub fn sys_yield() -> isize {

Loading…
Cancel
Save