如何在汇编程序中将字符串数组作为参数传递给函数? 例如,假设我想调用execve()函数,如下所示:
int execve(const char *filename, char *const argv[], char *const envp[]);
所以我这样做:
format elf executable
entry main
main:
mov eax, 11 ; execve - executes program
mov ebx, filename ; label name is address of string variable
mov ecx, args ; label name is address of array of strings?
mov edx, 0 ; NULL
int 80h
mov eax, 1 ;exit
int 80h
ret
filename db '/bin/ls', 0 ; path to program
args db '/bin/ls', 0, '.', 0, 0 ; array should end with empty string to
; indicate end of array
all:
~/apps/fasm/fasm ./test.asm
但是当我运行我的程序时,execve()无法执行请求的程序和strace ./test显示此消息:
execve("/bin/ls", [0x6e69622f, 0x736c2f, 0x2e], [/* 0 vars */]) = -1 EFAULT (Bad address)
如何正确地将“args”变量传递给execve函数?
谢谢:)
答案 0 :(得分:2)
你知道这在C中如何运作吗?字符串是指针,字符串数组是指针数组。因此,您需要执行以下操作:
filename db '/bin/ls', 0
dot db '.', 0
args dd filename, dot, 0
请注意,args
是dd
来获取指针大小的项目,并且它填充了字符串的地址。