annotate gcc/testsuite/gcc.dg/tree-ssa/pr31966.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Contributed by Jack Lloyd <lloyd@randombit.net> */
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 /* { dg-options "-O2 -ftree-vectorize" } */
kono
parents:
diff changeset
4 /* { dg-options "-O2 -ftree-vectorize -march=nocona" { target { i?86-*-* x86_64-*-* } } } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 typedef unsigned long long word;
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 const unsigned int MP_WORD_BITS = 64;
kono
parents:
diff changeset
9 const word MP_WORD_MASK = ~((word)0);
kono
parents:
diff changeset
10 const word MP_WORD_TOP_BIT = (word)1 << (8*sizeof(word) - 1);
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 extern void abort (void);
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 word do_div(word n1, word n0, word d)
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 word high = n1 % d, quotient = 0;
kono
parents:
diff changeset
17 unsigned int j;
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 for(j = 0; j != MP_WORD_BITS; ++j)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 word high_top_bit = (high & MP_WORD_TOP_BIT);
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 high <<= 1;
kono
parents:
diff changeset
24 high |= (n0 >> (MP_WORD_BITS-1-j)) & 1;
kono
parents:
diff changeset
25 quotient <<= 1;
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 if(high_top_bit || high >= d)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 high -= d;
kono
parents:
diff changeset
30 quotient |= 1;
kono
parents:
diff changeset
31 }
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 return quotient;
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 int main()
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 word result;
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 result = do_div(0x0000000000200000ll,
kono
parents:
diff changeset
42 0x0000000000000000ll,
kono
parents:
diff changeset
43 0x86E53497CE000000ll);
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 if (result != 0x3CBA83)
kono
parents:
diff changeset
47 abort ();
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 return 0;
kono
parents:
diff changeset
50 }