blob: 42f6a4cc646879891fb3a7605e883d6d0bece06d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
/* { dg-do compile } */
/* { dg-options "-O1 -fdump-tree-optimized" } */
extern void link_error (void);
/*
test that a condition is propagated inside an if
*/
void test5 (int x)
{
extern int foo (int);
if (x == 0)
foo (x);
else if (x == 0 )
link_error ();
}
void test55 (int x, int y)
{
int u;
if (x == 5 && y)
{
u = x + 22;
if (u != 27)
link_error ();
}
}
/* There should be not link_error calls, if there is any the
optimization has failed */
/* ??? Ug. This one may or may not fail based on how fold decides
that the && should be emitted (based on BRANCH_COST). Fix this
by teaching dom to look through && and register all components
as true. */
/* { dg-final { scan-tree-dump-times "link_error" 0 "optimized" { xfail { ! "alpha*-*-* arm*-*-* aarch64*-*-* powerpc*-*-* cris-*-* crisv32-*-* hppa*-*-* i?86-*-* mmix-*-* mips*-*-* m68k*-*-* moxie-*-* nds32*-*-* sparc*-*-* spu-*-* visium-*-* x86_64-*-*" } } } } */
/* { dg-final { cleanup-tree-dump "optimized" } } */
|