加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

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

发布时间:2020-12-14 02:25:56 所属栏目:Linux 来源:网络整理
导读:参见英文答案 What happens if you use the 32-bit int 0x80 Linux ABI in 64-bit code?1个 ; NASMpush 30 ; '0'mov rax,4 ; writemov rbx,1 ; stdoutmov rcx,rsp ; ptr to character on stackmov rdx,1 ; length of string = 1int 80h 上面的代码不会向stdo
参见英文答案 > 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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读