Монтажные функции FPU с c

Поэтому я пишу некоторые C со сборкой в ​​AT&T. У меня сейчас небольшая проблема, потому что когда я вызываю первую функцию f_float с параметром float, параметр загружается из стека, и возвращаемое значение является правильным. Но при втором вызове f_double с параметром 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

1 ответ

Изменения movl $*_precision в movw $*_precision решена проблема. Это, конечно, ошибка, но думал, что это перезапишет данные, оставленные в стеке позже. Во всяком случае, проблема совела. Спасибо всем за помощь. - Робс

Другие вопросы по тегам