參考資訊:
https://chromium.googlesource.com/chromiumos/docs/+/HEAD/constants/syscalls.md
https://reverseengineering.stackexchange.com/questions/2869/how-to-use-sysenter-under-linux
main.s
.global main .data msg: .ascii "hello, world!\n" len = . - msg .text main: mov $4, %eax mov $1, %ebx mov $msg, %ecx mov $len, %edx call *%gs:0x10 mov $1, %eax mov $0, %ebx call *%gs:0x10
NR | syscall name | eax | arg0(ebx) | arg1(ecx) | arg2(edx) |
---|---|---|---|---|---|
1 | exit | 1 | int error_code | ||
4 | write | 4 | unsigned int fd | const char *buf | size_t count |
編譯、執行
$ i686-linux-gnu-gcc main.s -o main -static $ qemu-i386 ./main hello, world!