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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- linux – 由lsof找到但不是由netstat发现的套接字
- 除了Valgrind之外的任何工具来监视Linux中运行进程的内存使
- 与SSH和Samba的连接受到严重延迟
- debian – Linux FTP上传:“没有这样的文件或目录”,但文件
- 如何在Linux机器上编写Flash Action Scripts?
- 如何在linux中获取文件系统的快照(文件,只有它们的大小,而不
- linux – 计算Docker容器中允许的CPU数量
- linux-kernel – 在linux内核中遍历task_struct-> children
- linux-kernel – 模式切换所涉及的开销是多少?
- linux – 如何禁止外部访问127.0.0.1?