linux系统中64位汇编和32位汇编的系统调用主要有以下不同:
(1)系统调用号不同.比如x86中sys_write是4, sys_exit是1; 而x86_64中sys_write是1, sys_exit是60。 linux系统调用号实际上定义在/usr/include/asm/unistd_32.h和/usr/include/asm/unistd_64.h中。
(2)系统调用所使用的寄存器不同,x86_64中 使用与eax对应的rax传递系统调用号,但是 x86_64中分别使用rdi/rsi/rdx传递前三个参数,而不是x86中的ebx/ecx/edx。
(1)系统调用号不同.比如x86中sys_write是4, sys_exit是1; 而x86_64中sys_write是1, sys_exit是60。 linux系统调用号实际上定义在/usr/include/asm/unistd_32.h和/usr/include/asm/unistd_64.h中。
(2)系统调用所使用的寄存器不同,x86_64中 使用与eax对应的rax传递系统调用号,但是 x86_64中分别使用rdi/rsi/rdx传递前三个参数,而不是x86中的ebx/ecx/edx。
(3)系统调用使用“syscall”而不是“int 80”。
一个简单的输出命令行参数的程序
.text
.globl _staet
_staet:
popq %rsi
vnext:
popq %rsi
test %rsi, %rsi
jz exit
movq %rsi, %rdi
xorq %rdx, %rdx
strlen:
movb (%rdi), %al
inc %rdx
inc %rdi
test %al, %al
jnz strlen
movb $10, -1(%rdi)
movq $1, %rax
movq $1, %rdi
syscall
jmp vnext
exit:
movq $60, %rax
movq $0, %rdi
syscall
ret