Skip to content

Commit 4acc051

Browse files
Add tests for integer-valued shadow memory access to unions
Checks that multi-byte accesses to integer-valued shadow memory for unions returns the maximum of the constituting bytes.
1 parent f743b53 commit 4acc051

File tree

2 files changed

+91
-0
lines changed

2 files changed

+91
-0
lines changed
Lines changed: 81 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,81 @@
1+
#include <assert.h>
2+
#include <stdlib.h>
3+
4+
union UNIONNAME
5+
{
6+
int x1;
7+
struct
8+
{
9+
char y1;
10+
// char padding;
11+
short y2;
12+
short y3;
13+
} x2;
14+
char x3[3];
15+
};
16+
17+
int main()
18+
{
19+
__CPROVER_field_decl_local("field2", (__CPROVER_bitvector[6])0);
20+
21+
union UNIONNAME u;
22+
23+
assert(__CPROVER_get_field(&u, "field2") == 0);
24+
assert(__CPROVER_get_field(&(u.x1), "field2") == 0);
25+
assert(__CPROVER_get_field(&(u.x2), "field2") == 0);
26+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 0);
27+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 0);
28+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
29+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 0);
30+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 0);
31+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 0);
32+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 0);
33+
34+
__CPROVER_set_field(&(u.x1), "field2", 1);
35+
assert(__CPROVER_get_field(&u, "field2") == 1);
36+
assert(__CPROVER_get_field(&(u.x1), "field2") == 1);
37+
assert(__CPROVER_get_field(&(u.x2), "field2") == 1);
38+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 1);
39+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 1);
40+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
41+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 1);
42+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 1);
43+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
44+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 1);
45+
46+
__CPROVER_set_field(&(u.x2.y1), "field2", 2);
47+
assert(__CPROVER_get_field(&u, "field2") == 2);
48+
assert(__CPROVER_get_field(&(u.x1), "field2") == 2);
49+
assert(__CPROVER_get_field(&(u.x2), "field2") == 2);
50+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 2);
51+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 1);
52+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
53+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 2);
54+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 2);
55+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
56+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 1);
57+
58+
__CPROVER_set_field(&(u.x2.y2), "field2", 3);
59+
assert(__CPROVER_get_field(&u, "field2") == 3);
60+
assert(__CPROVER_get_field(&(u.x1), "field2") == 2);
61+
assert(__CPROVER_get_field(&(u.x2), "field2") == 3);
62+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 2);
63+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 3);
64+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
65+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 3);
66+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 2);
67+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
68+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 3);
69+
70+
__CPROVER_set_field(&(u.x2.y3), "field2", 4);
71+
assert(__CPROVER_get_field(&u, "field2") == 4);
72+
assert(__CPROVER_get_field(&(u.x1), "field2") == 2);
73+
assert(__CPROVER_get_field(&(u.x2), "field2") == 4);
74+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 2);
75+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 3);
76+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 4);
77+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 3);
78+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 2);
79+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
80+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 3);
81+
}
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
FUTURE
2+
main.c
3+
4+
^EXIT=0$
5+
^SIGNAL=0$
6+
^VERIFICATION SUCCESSFUL$
7+
--
8+
^warning: ignoring
9+
--
10+
Not implemented yet.

0 commit comments

Comments
 (0)