blob: 86f878d5d73533e5da0f5713236e0465f4cda078 [file] [log] [blame]
/* PR c/68513 */
/* { dg-do compile } */
/* { dg-options "-funsafe-math-optimizations -fno-math-errno -O -Wno-div-by-zero" } */
int i;
unsigned u;
volatile int *e;
#define E (i ? *e : 0)
/* Can't trigger some of them because operand_equal_p will return false
for side-effects. */
/* (x & ~m) | (y & m) -> ((x ^ y) & m) ^ x */
int
fn1 (void)
{
int r = 0;
r += (short) (E & ~u | i & u);
r += -(short) (E & ~u | i & u);
r += (short) -(E & ~u | i & u);
return r;
}
/* sqrt(x) < y is x >= 0 && x != +Inf, when y is large. */
double
fn2 (void)
{
double r;
r = __builtin_sqrt (E) < __builtin_inf ();
return r;
}
/* sqrt(x) < c is the same as x >= 0 && x < c*c. */
double
fn3 (void)
{
double r;
r = __builtin_sqrt (E) < 1.3;
return r;
}
/* copysign(x,y)*copysign(x,y) -> x*x. */
double
fn4 (double y, double x)
{
return __builtin_copysign (E, y) * __builtin_copysign (E, y);
}
/* x <= +Inf is the same as x == x, i.e. !isnan(x). */
int
fn5 (void)
{
return E <= __builtin_inf ();
}
/* Fold (A & ~B) - (A & B) into (A ^ B) - B. */
int
fn6 (void)
{
return (i & ~E) - (i & E);
}
/* Fold (A & B) - (A & ~B) into B - (A ^ B). */
int
fn7 (void)
{
return (i & E) - (i & ~E);
}
/* x + (x & 1) -> (x + 1) & ~1 */
int
fn8 (void)
{
return E + (E & 1);
}
/* Simplify comparison of something with itself. */
int
fn9 (void)
{
return E <= E | E >= E;
}
/* Fold (A & ~B) - (A & B) into (A ^ B) - B. */
int
fn10 (void)
{
return (i & ~E) - (i & E);
}
/* abs(x)*abs(x) -> x*x. Should be valid for all types. */
int
fn11 (void)
{
return __builtin_abs (E) * __builtin_abs (E);
}
/* (x | CST1) & CST2 -> (x & CST2) | (CST1 & CST2) */
int
fn12 (void)
{
return (E | 11) & 12;
}
/* fold_range_test */
int
fn13 (const char *s)
{
return s[E] != '\0' && s[E] != '/';
}
/* fold_comparison */
int
fn14 (void)
{
return (!!i ? : (u *= E / 0)) >= (u = E);
}
/* fold_mult_zconjz */
_Complex int
fn15 (_Complex volatile int *z)
{
return *z * ~*z;
}