annotate gcc/testsuite/gcc.dg/optimize-bswapdi-3.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 /* { dg-do compile } */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2 /* { dg-require-effective-target bswap } */
111
kono
parents:
diff changeset
3 /* { dg-require-effective-target stdint_types } */
kono
parents:
diff changeset
4 /* { dg-options "-O2 -fdump-tree-bswap" } */
kono
parents:
diff changeset
5 /* { dg-additional-options "-mzarch" { target s390*-*-* } } */
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 #include <stdint.h>
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 unsigned char data[8];
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 struct uint64_st {
kono
parents:
diff changeset
12 unsigned char u0, u1, u2, u3, u4, u5, u6, u7;
kono
parents:
diff changeset
13 };
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 uint64_t read_le64_1 (void)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 return (uint64_t) data[0] | ((uint64_t) data[1] << 8)
kono
parents:
diff changeset
18 | ((uint64_t) data[2] << 16) | ((uint64_t) data[3] << 24)
kono
parents:
diff changeset
19 | ((uint64_t) data[4] << 32) | ((uint64_t) data[5] << 40)
kono
parents:
diff changeset
20 | ((uint64_t) data[6] << 48) | ((uint64_t) data[7] << 56);
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 uint64_t read_le64_2 (struct uint64_st data)
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 return (uint64_t) data.u0 | ((uint64_t) data.u1 << 8)
kono
parents:
diff changeset
26 | ((uint64_t) data.u2 << 16) | ((uint64_t) data.u3 << 24)
kono
parents:
diff changeset
27 | ((uint64_t) data.u4 << 32) | ((uint64_t) data.u5 << 40)
kono
parents:
diff changeset
28 | ((uint64_t) data.u6 << 48) | ((uint64_t) data.u7 << 56);
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 uint64_t read_le64_3 (unsigned char *data)
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 return (uint64_t) *data | ((uint64_t) *(data + 1) << 8)
kono
parents:
diff changeset
34 | ((uint64_t) *(data + 2) << 16) | ((uint64_t) *(data + 3) << 24)
kono
parents:
diff changeset
35 | ((uint64_t) *(data + 4) << 32) | ((uint64_t) *(data + 5) << 40)
kono
parents:
diff changeset
36 | ((uint64_t) *(data + 6) << 48) | ((uint64_t) *(data + 7) << 56);
kono
parents:
diff changeset
37 }
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 uint64_t read_be64_1 (void)
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 return (uint64_t) data[7] | ((uint64_t) data[6] << 8)
kono
parents:
diff changeset
42 | ((uint64_t) data[5] << 16) | ((uint64_t) data[4] << 24)
kono
parents:
diff changeset
43 | ((uint64_t) data[3] << 32) | ((uint64_t) data[2] << 40)
kono
parents:
diff changeset
44 | ((uint64_t) data[1] << 48) | ((uint64_t) data[0] << 56);
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 uint64_t read_be64_2 (struct uint64_st data)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 return (uint64_t) data.u7 | ((uint64_t) data.u6 << 8)
kono
parents:
diff changeset
50 | ((uint64_t) data.u5 << 16) | ((uint64_t) data.u4 << 24)
kono
parents:
diff changeset
51 | ((uint64_t) data.u3 << 32) | ((uint64_t) data.u2 << 40)
kono
parents:
diff changeset
52 | ((uint64_t) data.u1 << 48) | ((uint64_t) data.u0 << 56);
kono
parents:
diff changeset
53 }
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 uint64_t read_be64_3 (unsigned char *data)
kono
parents:
diff changeset
56 {
kono
parents:
diff changeset
57 return (uint64_t) *(data + 7) | ((uint64_t) *(data + 6) << 8)
kono
parents:
diff changeset
58 | ((uint64_t) *(data + 5) << 16) | ((uint64_t) *(data + 4) << 24)
kono
parents:
diff changeset
59 | ((uint64_t) *(data + 3) << 32) | ((uint64_t) *(data + 2) << 40)
kono
parents:
diff changeset
60 | ((uint64_t) *(data + 1) << 48) | ((uint64_t) *data << 56);
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 /* { dg-final { scan-tree-dump-times "64 bit load in target endianness found at" 3 "bswap" } } */
kono
parents:
diff changeset
64 /* { dg-final { scan-tree-dump-times "64 bit bswap implementation found at" 3 "bswap" } } */