1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
use syscall::common::*;
#[path="../../kernel/syscall/common.rs"]
pub mod common;
#[cold]
#[inline(never)]
#[cfg(target_arch = "x86")]
pub unsafe fn syscall(mut a: usize, b: usize, c: usize, d: usize) -> usize {
asm!("int 0x80"
: "={eax}"(a)
: "{eax}"(a), "{ebx}"(b), "{ecx}"(c), "{edx}"(d)
: "memory"
: "intel", "volatile");
a
}
#[cold]
#[inline(never)]
#[cfg(target_arch = "x86_64")]
pub unsafe fn syscall(mut a: usize, b: usize, c: usize, d: usize) -> usize {
asm!("int 0x80"
: "={rax}"(a)
: "{rax}"(a), "{rbx}"(b), "{rcx}"(c), "{rdx}"(d)
: "memory"
: "intel", "volatile");
a
}
pub unsafe fn sys_debug(byte: u8) {
syscall(SYS_DEBUG, byte as usize, 0, 0);
}
pub unsafe fn sys_brk(addr: usize) -> usize {
syscall(SYS_BRK, addr, 0, 0)
}
pub unsafe fn sys_chdir(path: *const u8) -> usize {
syscall(SYS_CHDIR, path as usize, 0, 0)
}
pub unsafe fn sys_close(fd: usize) -> usize {
syscall(SYS_CLOSE, fd, 0, 0)
}
pub unsafe fn sys_dup(fd: usize) -> usize {
syscall(SYS_DUP, fd, 0, 0)
}
pub unsafe fn sys_execve(path: *const u8) -> usize {
syscall(SYS_EXECVE, path as usize, 0, 0)
}
pub unsafe fn sys_exit(status: isize) {
syscall(SYS_EXIT, status as usize, 0, 0);
}
pub unsafe fn sys_fork() -> usize {
syscall(SYS_FORK, 0, 0, 0)
}
pub unsafe fn sys_fpath(fd: usize, buf: *mut u8, len: usize) -> usize {
syscall(SYS_FPATH, fd, buf as usize, len)
}
pub unsafe fn sys_fsync(fd: usize) -> usize {
syscall(SYS_FSYNC, fd, 0, 0)
}
#[repr(packed)]
pub struct TV {
pub tv_sec: i64,
pub tv_usec: i32,
}
pub unsafe fn sys_gettimeofday(tv: *mut TV) -> usize{
syscall(SYS_GETTIMEOFDAY, tv as usize, 0, 0)
}
pub unsafe fn sys_link(old: *const u8, new: *const u8) -> usize {
syscall(SYS_LINK, old as usize, new as usize, 0)
}
pub unsafe fn sys_lseek(fd: usize, offset: isize, whence: usize) -> usize {
syscall(SYS_LSEEK, fd, offset as usize, whence)
}
pub unsafe fn sys_open(path: *const u8, flags: usize, mode: usize) -> usize {
syscall(SYS_OPEN, path as usize, flags, mode)
}
pub unsafe fn sys_read(fd: usize, buf: *mut u8, count: usize) -> usize {
syscall(SYS_READ, fd, buf as usize, count)
}
pub unsafe fn sys_unlink(path: *const u8) -> usize {
syscall(SYS_UNLINK, path as usize, 0, 0)
}
pub unsafe fn sys_write(fd: usize, buf: *const u8, count: usize) -> usize {
syscall(SYS_WRITE, fd, buf as usize, count)
}
pub unsafe fn sys_yield() {
syscall(SYS_YIELD, 0, 0, 0);
}
pub unsafe fn sys_alloc(size: usize) -> usize {
syscall(SYS_ALLOC, size, 0, 0)
}
pub unsafe fn sys_realloc(ptr: usize, size: usize) -> usize {
syscall(SYS_REALLOC, ptr, size, 0)
}
pub unsafe fn sys_realloc_inplace(ptr: usize, size: usize) -> usize {
syscall(SYS_REALLOC_INPLACE, ptr, size, 0)
}
pub unsafe fn sys_unalloc(ptr: usize) {
syscall(SYS_UNALLOC, ptr, 0, 0);
}