如何将字符串数组作为参数传递给函数?

时间:2016-03-27 13:59:57

标签: linux assembly x86 fasm

如何在汇编程序中将字符串数组作为参数传递给函数? 例如,假设我想调用execve()函数,如下所示:

int execve(const char *filename, char *const argv[], char *const envp[]);

所以我这样做:

TEST.ASM

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函数?

谢谢:)

1 个答案:

答案 0 :(得分:2)

你知道这在C中如何运作吗?字符串是指针,字符串数组是指针数组。因此,您需要执行以下操作:

filename db '/bin/ls', 0 
dot db '.', 0
args dd filename, dot, 0

请注意,argsdd来获取指针大小的项目,并且它填充了字符串的地址。