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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
extern void exit (int);
extern void abort (void);
typedef struct T
{
char val;
const __as struct T *l, *r;
} tree;
/*
abcd
/ \
ab cd
/ \ / \
a b c d
*/
const __as tree a = { 'a', 0, 0 };
const __as tree b = { 'b', 0, 0 };
const __as tree c = { 'c', 0, 0 };
const __as tree d = { 'd', 0, 0 };
const __as tree ab = { 'A', &a, &b };
const __as tree cd = { 'C', &c, &d };
const __as tree abcd = { '*', &ab, &cd };
static void
test1 (void)
{
if (abcd.val != '*')
abort();
if (abcd.l->val != 'A')
abort();
if (abcd.r->val != 'C')
abort();
if (abcd.l->l->val != 'a')
abort();
if (abcd.l->r->val != 'b')
abort();
if (abcd.r->l->val != 'c')
abort();
if (abcd.r->r->val != 'd')
abort();
}
static void
test2 (const __as tree *t)
{
if (t->val != '*')
abort();
if (t->l->val != 'A')
abort();
if (t->r->val != 'C')
abort();
if (t->l->l->val != 'a')
abort();
if (t->l->r->val != 'b')
abort();
if (t->r->l->val != 'c')
abort();
if (t->r->r->val != 'd')
abort();
}
static void
test3 (const __as tree *pt)
{
tree t = *pt;
if (t.val != '*')
abort();
if (t.l->val != 'A')
abort();
if (t.r->val != 'C')
abort();
if (t.l->l->val != 'a')
abort();
if (t.l->r->val != 'b')
abort();
if (t.r->l->val != 'c')
abort();
if (t.r->r->val != 'd')
abort();
}
int main (void)
{
const __as tree *t = &abcd;
test1();
test2 (&abcd);
test3 (&abcd);
__asm ("" : "+r" (t));
test2 (t);
test3 (t);
exit (0);
return 0;
}
|