这是我代码的一部分:
.data
.text
.global fx
fx:
pushl %ebp
movl %esp,%ebp
finit
fldl 8(%ebp)
我从C调用这个函数。因为8字节应该有我调用的值,对吗?但我在gdb看到的是:
(gdb) info float
=>R7: Valid 0x3bf2bd04000000000000 +1.00272590169167575e-312
R6: Empty 0x00000000000000000000
R5: Empty 0x00000000000000000000
R4: Empty 0x00000000000000000000
R3: Empty 0x00000000000000000000
R2: Empty 0x00000000000000000000
R1: Empty 0x00000000000000000000
R0: Empty 0x00000000000000000000
Status Word: 0x3802 DE
TOP: 7
Control Word: 0x037f IM DM ZM OM UM PM
PC: Extended Precision (64-bits)
RC: Round to nearest
Tag Word: 0x3fff
Instruction Pointer: 0x00:0x0804849b
Operand Pointer: 0x00:0xffffcbb0
Opcode: 0xdd45
这就在fldl 8之后。我的朋友做了同样的程序,而且成功了。我做错了什么?
在我的C函数下面:
#include <stdio.h>
float fx(float x);
float gx(float x);
int main(){
float x;
printf("Podaj wartosc x: ");
scanf("%f",&x);
float wynik1 = fx(x);
float wynik2 = gx(x);
printf("\nWynik funkcji f(x)=%f\nWynik funkcji g(x)=%f\n",wynik1,wynik2);
return 0;
}
最佳答案
加载的是双精度(fldl
)而不是浮点(flds
)。
关于c - 组装-堆叠编号,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/30446565/