annotate gcc/testsuite/gcc.dg/combine-subregs.c @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do run { target { stdint_types } } } */
kono
parents:
diff changeset
2 /* { dg-options "-O2" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include <stdint.h>
kono
parents:
diff changeset
5 #include <stdlib.h>
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 void __attribute__ ((noinline))
kono
parents:
diff changeset
8 foo (uint64_t state, uint32_t last)
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 if (state == last) abort ();
kono
parents:
diff changeset
11 }
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 /* This function may do a bad comparision by trying to
kono
parents:
diff changeset
14 use SUBREGS during the compare on machines where comparing
kono
parents:
diff changeset
15 two registers always compares the entire register regardless
kono
parents:
diff changeset
16 of mode. */
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 int __attribute__ ((noinline))
kono
parents:
diff changeset
19 compare (uint64_t state, uint32_t *last, uint8_t buf)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 if (*last == ((state | buf) & 0xFFFFFFFF)) {
kono
parents:
diff changeset
22 foo (state, *last);
kono
parents:
diff changeset
23 return 0;
kono
parents:
diff changeset
24 }
kono
parents:
diff changeset
25 return 1;
kono
parents:
diff changeset
26 }
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 int
kono
parents:
diff changeset
29 main(int argc, char **argv) {
kono
parents:
diff changeset
30 uint64_t state = 0xF00000100U;
kono
parents:
diff changeset
31 uint32_t last = 0x101U;
kono
parents:
diff changeset
32 int ret = compare(state, &last, 0x01);
kono
parents:
diff changeset
33 if (ret != 0)
kono
parents:
diff changeset
34 abort ();
kono
parents:
diff changeset
35 exit (0);
kono
parents:
diff changeset
36 }