【发布时间】:2013-11-12 21:41:31
【问题描述】:
我正在尝试编写一个执行fork() 系统调用的程序,并且子/父分别编写不同的字符串和exit(0)。
问题是 - 尽管fork() 是成功的(因为我看到了 2 行输出),但由于某种原因,父进程和子进程都输出了父字符串。
代码如下:
BITS 64
section .data
msg1: db "Hello from child", 0x0a
len1: equ $-msg1
msg2: db "Hello from parent", 0x0a
len2: equ $-msg2
section .text
global start
start:
xor rax,rax
mov rax,0x2000002 ; fork() syscall
syscall
test eax,eax
jne flow_parent
mov rax, 0x2000004 ; SYS_write
mov rdi, 1 ; stdout
mov rsi, msg1
mov rdx, len1
syscall
xor rdi,rdi
mov rax,0x2000001
syscall
flow_parent:
mov rax, 0x2000004 ; SYS_write
mov rdi, 1 ; stdout
mov rsi, msg2
mov rdx, len2
syscall
xor rdi,rdi
mov rax,0x2000001
syscall
我的输出:
$ nasm -f macho64 code.s -o code.o
$ ld -o code -e start -macosx_version_min 10.7 code.o
$ ./code
Hello from parent
Hello from parent
$
关于如何解决这个问题的任何想法?
【问题讨论】:
标签: assembly fork x86-64 system-calls shellcode