blob: 59d3a1baffcceb2c262332a6f4caa3cbdea05966 (
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
/* { dg-do compile } */
/* { dg-options "-O1 -fdump-tree-dom2 -std=gnu89" } */
extern void abort (void);
union tree_node;
typedef union tree_node *tree;
enum tree_code
{
SET_TYPE,
RECORD_TYPE,
LAST_AND_UNUSED_TREE_CODE
};
extern const char tree_code_type[];
struct tree_common
{
enum tree_code code:8;
};
union tree_node
{
struct tree_common common;
};
readonly_fields_p (type)
tree type;
{
if (type->common.code != RECORD_TYPE)
return;
if (tree_code_type[type->common.code] != 't')
abort ();
return;
}
/* A good optimizer would realize that the cast to (unsigned int) is
useless as the earlier cast of the same value of (unsigned char) will
always produce the same result. */
/* { dg-final { scan-tree-dump-times "\\(unsigned int\\)" 0 "dom2"} } */
/* There should be one load of ->common.code. We currently fail this
because we load from ->common.code using different types. */
/* { dg-final { scan-tree-dump-times "common\.code" 1 "dom2"} } */
|