mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-14 21:10:19 +00:00
1e1f44de64
When using software completions, we have to prevent assembler to match input and output operands of sqrtt/sqrtf insn. Add earlyclobber to output operand to avoid unwanted operand matching. 2017-04-14 Uros Bizjak <ubizjak@gmail.com> * sysdeps/alpha/fpu/math_private.h (__ieee754_sqrt): Add earlyclobber to output operand of sqrt insn. (__ieee754_sqrtf): Ditto.
51 lines
1.2 KiB
C
51 lines
1.2 KiB
C
#ifndef ALPHA_MATH_PRIVATE_H
|
|
#define ALPHA_MATH_PRIVATE_H 1
|
|
|
|
/* In bits/mathinline.h we define __isnan et al.
|
|
In sysdeps/alpha/fpu/s_isnan.c we move the identifier out of the way
|
|
via macro hackery. In both cases, tell math/math_private.h that
|
|
we have a local copy of the function. */
|
|
|
|
#ifndef __isnan
|
|
# define __isnan __isnan
|
|
#endif
|
|
#ifndef __isnanf
|
|
# define __isnanf __isnanf
|
|
#endif
|
|
|
|
/* Generic code forces values to memory; we don't need to do that. */
|
|
#define math_opt_barrier(x) \
|
|
({ __typeof (x) __x = (x); __asm ("" : "+frm" (__x)); __x; })
|
|
#define math_force_eval(x) \
|
|
({ __typeof (x) __x = (x); __asm __volatile__ ("" : : "frm" (__x)); })
|
|
|
|
#include_next <math_private.h>
|
|
|
|
#ifdef __alpha_fix__
|
|
extern __always_inline double
|
|
__ieee754_sqrt (double d)
|
|
{
|
|
double ret;
|
|
# ifdef _IEEE_FP_INEXACT
|
|
asm ("sqrtt/suid %1,%0" : "=&f"(ret) : "f"(d));
|
|
# else
|
|
asm ("sqrtt/sud %1,%0" : "=&f"(ret) : "f"(d));
|
|
# endif
|
|
return ret;
|
|
}
|
|
|
|
extern __always_inline float
|
|
__ieee754_sqrtf (float d)
|
|
{
|
|
float ret;
|
|
# ifdef _IEEE_FP_INEXACT
|
|
asm ("sqrts/suid %1,%0" : "=&f"(ret) : "f"(d));
|
|
# else
|
|
asm ("sqrts/sud %1,%0" : "=&f"(ret) : "f"(d));
|
|
# endif
|
|
return ret;
|
|
}
|
|
#endif /* FIX */
|
|
|
|
#endif /* ALPHA_MATH_PRIVATE_H */
|