blob: 7288a374576cb0495580b5743799fcb8e55dc587 (
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
|
/* PR rtl-optimization/20532 */
/* { dg-do run } */
/* { dg-options "" } */
/* { dg-options "-march=i386" { target { { i?86-*-* x86_64-*-* } && ilp32 } } } */
/* We used to optimize the DImode shift-by-32 to zero because in combine
we turned:
(v << 31) + (v << 31)
into:
(v * (((HOST_WIDE_INT)1 << 31) + ((HOST_WIDE_INT)1 << 31)))
With a 32-bit HOST_WIDE_INT, the coefficient overflowed to zero. */
unsigned long long int badshift(unsigned long long int v)
{
return v << 31 << 1;
}
extern void abort ();
int main() {
if (badshift (1) == 0)
abort ();
return 0;
}
|