2

我是新手,所以我的表达方式可能不准确。我需要使用汇编程序在 C 中进行系统调用“execve”。我不使用任何库。不起作用的部分是

char *nul=(char *)0;
char *argv[] = { "/bin/date", nul };
char *envp[] = { nul };
long ret;
asm volatile ("int $0x80" : "=a" (ret) : "a" (11), "b" (argv[0]), "c" (argv), "d" (envp));
//"a" (11) ... 11 correspondes to execve

我编译代码(既没有错误也没有警告)

gcc -m32 -nostdlib -nostdinc -static -O2 sysc.c -o sysc

当我尝试运行该程序时,我看到此消息:

A NULL argv[0] was passed through an exec system call.
Aborted
4

2 回答 2

1

如果您查看生成的代码,您会看到编译器优化了 and 的初始化,argv假设envp您的 asm 块没有访问它们(因为您只声明需要指针本身)。

解决方案:添加一个"memory"clobber来告诉编译器你可以读取或写入任何内存。

于 2014-04-29T23:18:31.870 回答
0

函数族的参数exec()有点奇怪。

特别是, arg0 和 arg1 大致相同:

char *args [] = {"./path/to/program", "arg1", "arg2", NULL};

int rc = execve (args[0], args, envp);
于 2014-04-29T23:22:53.710 回答