blob: 41c65c2bdbbddaf1fb74ea8f467a547cc27a50ea (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
|
#include <math.h>
float sqrtf(float x)
{
long double t;
/* The long double result has sufficient precision so that
* second rounding to float still keeps the returned value
* correctly rounded, see Pierre Roux, "Innocuous Double
* Rounding of Basic Arithmetic Operations". */
__asm__ ("fsqrt" : "=t"(t) : "0"(x));
return (float)t;
}
|