Skip to content

Commit 3d9ff65

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

File tree

2 files changed

+90
-0
lines changed

2 files changed

+90
-0
lines changed
Lines changed: 80 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,80 @@
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", (_Bool)0);
20+
21+
union UNIONNAME u;
22+
assert(__CPROVER_get_field(&u, "field2") == 0);
23+
assert(__CPROVER_get_field(&(u.x1), "field2") == 0);
24+
assert(__CPROVER_get_field(&(u.x2), "field2") == 0);
25+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 0);
26+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 0);
27+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
28+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 0);
29+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 0);
30+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 0);
31+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 0);
32+
33+
__CPROVER_set_field(&(u.x1), "field2", 1);
34+
assert(__CPROVER_get_field(&u, "field2") == 1);
35+
assert(__CPROVER_get_field(&(u.x1), "field2") == 1);
36+
assert(__CPROVER_get_field(&(u.x2), "field2") == 1);
37+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 1);
38+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 1);
39+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
40+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 1);
41+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 1);
42+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
43+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 1);
44+
45+
__CPROVER_set_field(&(u.x2.y1), "field2", 0);
46+
assert(__CPROVER_get_field(&u, "field2") == 1);
47+
assert(__CPROVER_get_field(&(u.x1), "field2") == 1);
48+
assert(__CPROVER_get_field(&(u.x2), "field2") == 1);
49+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 0);
50+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 1);
51+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
52+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 1);
53+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 0);
54+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
55+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 1);
56+
57+
__CPROVER_set_field(&(u.x2.y2), "field2", 0);
58+
assert(__CPROVER_get_field(&u, "field2") == 1);
59+
assert(__CPROVER_get_field(&(u.x1), "field2") == 1);
60+
assert(__CPROVER_get_field(&(u.x2), "field2") == 0);
61+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 0);
62+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 0);
63+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 0);
64+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 7);
65+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 0);
66+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
67+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 0);
68+
69+
__CPROVER_set_field(&(u.x2.y3), "field2", 1);
70+
assert(__CPROVER_get_field(&u, "field2") == 1);
71+
assert(__CPROVER_get_field(&(u.x1), "field2") == 1);
72+
assert(__CPROVER_get_field(&(u.x2), "field2") == 1);
73+
assert(__CPROVER_get_field(&(u.x2.y1), "field2") == 0);
74+
assert(__CPROVER_get_field(&(u.x2.y2), "field2") == 0);
75+
assert(__CPROVER_get_field(&(u.x2.y3), "field2") == 1);
76+
// Not allowed: assert(__CPROVER_get_field(u.x3, "field2") == 7);
77+
assert(__CPROVER_get_field(&(u.x3[0]), "field2") == 0);
78+
assert(__CPROVER_get_field(&(u.x3[1]), "field2") == 1);
79+
assert(__CPROVER_get_field(&(u.x3[2]), "field2") == 0);
80+
}
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+

0 commit comments

Comments
 (0)