2016-09-01 01:45:21 +02:00
|
|
|
#[naked]
|
|
|
|
pub unsafe extern fn syscall() {
|
2016-09-08 05:16:30 +02:00
|
|
|
#[inline(never)]
|
|
|
|
unsafe fn inner() {
|
|
|
|
extern {
|
|
|
|
fn syscall(a: usize, b: usize, c: usize, d: usize, e: usize, f: usize) -> usize;
|
|
|
|
}
|
|
|
|
|
|
|
|
let mut a;
|
|
|
|
{
|
|
|
|
let b;
|
|
|
|
let c;
|
|
|
|
let d;
|
|
|
|
let e;
|
|
|
|
let f;
|
2016-09-08 23:53:45 +02:00
|
|
|
asm!("" : "={rax}"(a), "={rbx}"(b), "={rcx}"(c), "={rdx}"(d), "={rsi}"(e), "={rdi}"(f)
|
2016-09-08 05:16:30 +02:00
|
|
|
: : : "intel", "volatile");
|
2016-09-01 01:45:21 +02:00
|
|
|
|
2016-09-08 05:16:30 +02:00
|
|
|
a = syscall(a, b, c, d, e, f);
|
|
|
|
}
|
2016-09-01 01:45:21 +02:00
|
|
|
|
2016-09-08 23:53:45 +02:00
|
|
|
asm!("" : : "{rax}"(a) : : "intel", "volatile");
|
2016-09-08 05:16:30 +02:00
|
|
|
}
|
2016-09-01 01:45:21 +02:00
|
|
|
|
2016-09-08 23:53:45 +02:00
|
|
|
asm!("push fs
|
2016-09-08 23:45:26 +02:00
|
|
|
push rax
|
|
|
|
mov rax, 0x18
|
|
|
|
mov fs, ax
|
|
|
|
pop rax"
|
|
|
|
: : : : "intel", "volatile");
|
|
|
|
|
2016-09-08 05:16:30 +02:00
|
|
|
inner();
|
2016-09-01 01:45:21 +02:00
|
|
|
|
2016-09-08 05:16:30 +02:00
|
|
|
// Interrupt return
|
2016-09-08 23:53:45 +02:00
|
|
|
asm!("pop fs
|
2016-09-08 23:45:26 +02:00
|
|
|
iretq"
|
|
|
|
: : : : "intel", "volatile");
|
2016-09-01 01:45:21 +02:00
|
|
|
}
|