所以我在AT& T中用汇编写了一些C.我现在遇到了小问题,因为当我用浮点参数调用f_float的第一个函数时,参数从堆栈加载并且返回的值是正确的。但是第二次使用double参数调用f_double时,值不是从堆栈加载。我在linux Mint 17.1上,gcc版本4.9.2(Ubuntu4.9.2-0ubuntu1~14.04)。有什么建议吗?
的main.cpp
#include <stdio.h>
float f_float(float);
double f_double(double);
int main()
{
float a, f_result;
double b, d_result;
printf("\nInsert float number: ");
scanf("%f", &a);
printf("\nInsert double number: ");
scanf("%lf", &b);
f_result = f_float(a);
d_result = f_double(b);
printf("\nResult of float with f function: %f", f_result);
printf("\nResult of double with f function: %lf", d_result);
return 0;
}
functions.s
s_precision = 0x007f
d_precision = 0x027f
#(x^2)/(sqrt(x^2 +1) +1)
.globl f_float
.type f_float, @function
f_float:
pushl %ebp
movl %esp, %ebp
subl $2, %esp
finit
movl $s_precision, -2(%ebp)
fldcw -2(%ebp)
flds 8(%ebp)
fmul %st(0)
fld1
fadd %st(1), %st(0)
fsqrt
fld1
fsubr %st(1), %st(0)
movl %ebp, %esp
pop %ebp
ret
.globl f_double
.type f_double, @function
f_double:
pushl %ebp
movl %esp, %ebp
subl $2, %esp
finit
movl $d_precision, -2(%ebp)
fldcw -2(%ebp)
fldl 8(%ebp)
fmul %st(0)
fld1
fadd %st(1), %st(0)
fsqrt
fld1
fsubr %st(1), %st(0)
movl %ebp, %esp
pop %ebp
ret
答案 0 :(得分:0)
将movl $*_precision
更改为movw $*_precision
解决了问题。当然这是错误的,但认为它将覆盖以后堆栈上留下的数据。无论如何,问题猛烈。感谢大家的帮助。 - 罗布斯