我正在尝试从ASM中调用一个函数。我知道如何调用它,但我很难找到如何获得此函数的返回值。一个例子如下:
C代码:
int dummy() {
return 5;
}
(N)ASM代码:
dummyFunction:
call dummy
;grab return into eax
inc eax ; eax should be 6 now
ret
有什么想法吗?
答案 0 :(得分:14)
返回值位于eax
。如果您从asm调用了C函数,则可以从eax
读取返回值。如果您尝试从asm函数返回到C,请将预期的返回值存储在eax
中。
对于返回浮点值,long long
值或结构,事情变得有点复杂,所以问你是否需要它,而某人(也许是我)会帮助你。
答案 1 :(得分:8)
虽然答案足以回答OP的问题,但这里有一个摘录,涵盖DJPP's manpage完整性的大部分案例:
返回值
- 整数(任何大小不超过32位)和指针都会在
%eax
寄存器中返回。- 浮点值在387堆栈顶部寄存器
st(0)
中返回。- 类型
long long int
的返回值在%edx:%eax
中返回(%edx
中最重要的单词,%eax
中最不重要的单词)。- 返回结构很复杂,很少有用;尽量避免它。 (请注意,这与返回指向结构的指针不同。)
如果函数返回
void
(例如没有值),则不使用这些寄存器的内容。
答案 2 :(得分:2)
它取决于平台和调用约定,但通常,返回值应该已经在eax
中返回,如果它是基本类型或指针,并且在浮点寄存器中st(0)
如果它是浮点类型,我想。