gpt4 book ai didi

c - 汇编函数 FPU with c

转载 作者:太空宇宙 更新时间:2023-11-04 04:35:49 26 4
gpt4 key购买 nike

所以我在 AT&T 中用汇编写了一些 C。我现在遇到了一个小问题,因为当我用 float 参数调用 f_float 的第一个函数时,参数从堆栈加载并且返回值是正确的。但是在第二次调用带有双参数的 f_double 时,该值不是从堆栈加载的。我在 linux Mint 17.1,gcc 版本 4.9.2(Ubuntu4.9.2-0ubuntu1~14.04)。有什么建议吗?

主要.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;
}

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

最佳答案

movl $*_precision 更改为 movw $*_precision 解决了问题。那当然是错误的,但认为它会覆盖稍后留在堆栈中的数据。无论如何,问题解决了。感谢大家的帮助。 – 抢劫

关于c - 汇编函数 FPU with c,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30737858/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com