annotate gcc/testsuite/gcc.dg/optimize-bswapsi-2.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
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 "-march=z900" { 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 extern unsigned char data[4];
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 struct uint32_st {
kono
parents:
diff changeset
12 unsigned char u0, u1, u2, u3;
kono
parents:
diff changeset
13 };
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 uint32_t read_le32_1 (void)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 return data[0] | (data[1] << 8) | (data[2] << 16) | (data[3] << 24);
kono
parents:
diff changeset
18 }
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 uint32_t read_le32_2 (struct uint32_st data)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 return data.u0 | (data.u1 << 8) | (data.u2 << 16) | (data.u3 << 24);
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 uint32_t read_le32_3 (unsigned char *data)
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 return *data | (*(data + 1) << 8) | (*(data + 2) << 16)
kono
parents:
diff changeset
28 | (*(data + 3) << 24);
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 uint32_t read_be32_1 (void)
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 return data[3] | (data[2] << 8) | (data[1] << 16) | (data[0] << 24);
kono
parents:
diff changeset
34 }
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 uint32_t read_be32_2 (struct uint32_st data)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 return data.u3 | (data.u2 << 8) | (data.u1 << 16) | (data.u0 << 24);
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 uint32_t read_be32_3 (unsigned char *data)
kono
parents:
diff changeset
42 {
kono
parents:
diff changeset
43 return *(data + 3) | (*(data + 2) << 8) | (*(data + 1) << 16)
kono
parents:
diff changeset
44 | (*data << 24);
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 /* { dg-final { scan-tree-dump-times "32 bit load in target endianness found at" 3 "bswap" } } */
kono
parents:
diff changeset
48 /* { dg-final { scan-tree-dump-times "32 bit bswap implementation found at" 3 "bswap" } } */