linux – 为什么我不能从寄存器中sys_write?

参见英文答案 > What happens if you use the 32-bit int 0x80 Linux ABI in 64-bit code?1个
; NASM
push 30 ; '0'

mov rax,4 ; write
mov rbx,1 ; stdout
mov rcx,rsp ; ptr to character on stack
mov rdx,1 ; length of string = 1
int 80h

上面的代码不会向stdout打印任何内容.当我给它一个ptr到一个字符.data中的字符时它工作.我究竟做错了什么?

解决方法

amd64使用与int 0x80不同的系统调用方法,虽然这可能仍然适用于安装32位库等.而在x86上可以做到:
mov eax,SYSCALL_NUMBER
mov ebx,param1
mov ecx,param2
mov edx,param3
int 0x80

在amd64上,我会改为:

mov rax,SYSCALL_NUMBER_64 ; different from the x86 equivalent,usually
mov rdi,param1
mov rsi,param2
mov rdx,param3
syscall

对于您想要做的,请考虑以下示例:

bits 64
        global _start

section .text

_start:
        push            0x0a424242
        mov             rdx,04h
        lea             rsi,[rsp]
        call            write
        call            exit
exit:
        mov             rax,60     ; exit()
        xor             rdi,rdi    ; errno
        syscall

write:
        mov             rax,1      ; write()
        mov             rdi,1      ; stdout
        syscall
        ret

相关文章

/etc/sysctl.conf这个目录主要是配置一些系统信息,/etc/sys...
1.作用 useradd或adduser命令用来建立用户帐号和创建用户的起...
它们都是多模式编辑器,不同的是vim 是vi的升级版本,它不仅...
不管是我们在安装软件还是监测软件的使用性能,我们都要随时...
装好Tomcat7后,发现除了本机能访问外界访问不了,岂有此理。...
修改防火墙配置需要修改 /etc/sysconfig/iptables 这个文件,...