首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >汇编函数FPU与c

汇编函数FPU与c
EN

Stack Overflow用户
提问于 2015-06-10 00:31:43
回答 1查看 230关注 0票数 1

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

main.cpp

代码语言:javascript
复制
#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

代码语言:javascript
复制
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
EN

回答 1

Stack Overflow用户

发布于 2015-11-06 15:30:53

movl $*_precision更改为movw $*_precision解决了问题。这当然是错误的,但我认为它会覆盖堆栈上留下的数据。不管怎么说,问题解决了。感谢大家的帮助。--抢夺

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30737858

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档