Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
F
frama-c
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Deploy
Releases
Container Registry
Model registry
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
pub
frama-c
Commits
6a7f42f7
Commit
6a7f42f7
authored
3 years ago
by
David Bühler
Browse files
Options
Downloads
Patches
Plain Diff
[Eva] Adds a test of builtin memset with uninitialized pointers.
parent
7349a8e6
No related branches found
No related tags found
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
tests/builtins/memset.c
+18
-1
18 additions, 1 deletion
tests/builtins/memset.c
tests/builtins/oracle/memset.res.oracle
+133
-15
133 additions, 15 deletions
tests/builtins/oracle/memset.res.oracle
with
151 additions
and
16 deletions
tests/builtins/memset.c
+
18
−
1
View file @
6a7f42f7
...
@@ -29,7 +29,7 @@ struct s ts[5];
...
@@ -29,7 +29,7 @@ struct s ts[5];
volatile
int
vol
;
volatile
int
vol
;
void
main
()
{
void
test
()
{
void
*
dst
=
memset
(
t1
,
0x11
,
sizeof
(
t1
));
// basic
void
*
dst
=
memset
(
t1
,
0x11
,
sizeof
(
t1
));
// basic
memset
(
t2
+
(
int
)
t2
,
0x12
,
sizeof
(
t2
));
// garbled dest
memset
(
t2
+
(
int
)
t2
,
0x12
,
sizeof
(
t2
));
// garbled dest
memset
(
t3
+
10
,
0x11
,
(
unsigned
long
)
t1
);
// garbled size
memset
(
t3
+
10
,
0x11
,
(
unsigned
long
)
t1
);
// garbled size
...
@@ -71,3 +71,20 @@ void main() {
...
@@ -71,3 +71,20 @@ void main() {
//@ assert Assume: k <= 12;
//@ assert Assume: k <= 12;
memset
(
t12
+
k
*
8
,
1
,
4
);
// Imprecise, because of double congruences
memset
(
t12
+
k
*
8
,
1
,
4
);
// Imprecise, because of double congruences
}
}
/* Should not crash and emit uninitialization alarms.
See gitlab public issue pub/frama-c#2576. */
void
uninit
()
{
void
*
x
;
if
(
vol
)
memset
(
x
,
0
,
2
*
4
);
int
a
;
if
(
vol
)
x
=
&
a
;
memset
(
x
,
0
,
4
);
}
void
main
()
{
test
();
uninit
();
}
This diff is collapsed.
Click to expand it.
tests/builtins/oracle/memset.res.oracle
+
133
−
15
View file @
6a7f42f7
...
@@ -20,6 +20,8 @@
...
@@ -20,6 +20,8 @@
t12[0..99] ∈ {0}
t12[0..99] ∈ {0}
ts[0..4] ∈ {0}
ts[0..4] ∈ {0}
vol ∈ [--..--]
vol ∈ [--..--]
[eva] computing for function test <- main.
Called from tests/builtins/memset.c:88.
[eva] tests/builtins/memset.c:33: Call to builtin memset
[eva] tests/builtins/memset.c:33: Call to builtin memset
[eva] tests/builtins/memset.c:33:
[eva] tests/builtins/memset.c:33:
function memset: precondition 'valid_s' got status valid.
function memset: precondition 'valid_s' got status valid.
...
@@ -88,12 +90,31 @@
...
@@ -88,12 +90,31 @@
function memset: precondition 'valid_s' got status valid.
function memset: precondition 'valid_s' got status valid.
[eva:imprecision] tests/builtins/memset.c:72:
[eva:imprecision] tests/builtins/memset.c:72:
Call to builtin precise_memset(({{ &t12 + [0..384],0%32 }},{1},{4})) failed; destination is not exact
Call to builtin precise_memset(({{ &t12 + [0..384],0%32 }},{1},{4})) failed; destination is not exact
[eva] Recording results for test
[from] Computing for function test
[from] Done for function test
[eva] Done for function test
[eva] computing for function uninit <- main.
Called from tests/builtins/memset.c:89.
[eva:alarm] tests/builtins/memset.c:80: Warning:
accessing uninitialized left-value. assert \initialized(&x);
[eva:alarm] tests/builtins/memset.c:84: Warning:
accessing uninitialized left-value. assert \initialized(&x);
[eva] tests/builtins/memset.c:84: Call to builtin memset
[eva] tests/builtins/memset.c:84:
function memset: precondition 'valid_s' got status valid.
[eva] Recording results for uninit
[from] Computing for function uninit
[from] Done for function uninit
[eva] Done for function uninit
[eva] Recording results for main
[eva] Recording results for main
[from] Computing for function main
[from] Computing for function main
[from] Done for function main
[from] Done for function main
[eva] done for function main
[eva] done for function main
[eva] tests/builtins/memset.c:80:
assertion 'Eva,initialization' got final status invalid.
[eva] ====== VALUES COMPUTED ======
[eva] ====== VALUES COMPUTED ======
[eva:final-states] Values at end of function
main
:
[eva:final-states] Values at end of function
test
:
t1[0..99] ∈ {286331153}
t1[0..99] ∈ {286331153}
t2[0..99] ∈ [--..--]
t2[0..99] ∈ [--..--]
t3[0..9] ∈ {0}
t3[0..9] ∈ {0}
...
@@ -147,46 +168,119 @@
...
@@ -147,46 +168,119 @@
s ∈ {12; 36}
s ∈ {12; 36}
s1 ∈ {8; 16}
s1 ∈ {8; 16}
k ∈ [0..12]
k ∈ [0..12]
[eva:final-states] Values at end of function uninit:
x ∈ {{ (void *)&a }}
a ∈ {0}
[eva:final-states] Values at end of function main:
t1[0..99] ∈ {286331153}
t2[0..99] ∈ [--..--]
t3[0..9] ∈ {0}
[10..99]# ∈ {0; 17} repeated %8
t4[0..99] ∈ {0}
t5[0..99] ∈
{{ garbled mix of &{t1}
(origin: Misaligned {tests/builtins/memset.c:41}) }}
t6[0..9] ∈ {0}
[10..13]# ∈ {0; 34} repeated %8
[14..99] ∈ {0}
t7[0..3]# ∈ {0; 34} repeated %8
[4..99] ∈ {0}
t8[0..3]# ∈ {0; 34} repeated %8
[4..99] ∈ {0}
t9[0..19] ∈ {0}
[20..99]# ∈ {0; 254} repeated %8
t10[0..3] ∈ {0}
[4..6]# ∈ {136} repeated %8
[7..12]# ∈ {0; 136} repeated %8
[13..99] ∈ {0}
t11[0..1] ∈ {0}
[2]# ∈ {0; 153} repeated %8
[3]# ∈ {153} repeated %8
[4..6]# ∈ {0; 153} repeated %8
[7..99] ∈ {0}
t12[0..96]# ∈ {0; 1} repeated %8
[97..99] ∈ {0}
ts[0].f1 ∈ {-2; 0}
[0].[bits 8 to 15] ∈ {0; 254}
[0].f2 ∈ {-258; 0}
[0]{.f3; .f4[0..2]} ∈ {-16843010; 0}
[1].f1 ∈ {-2; 0}
[1].[bits 8 to 15] ∈ {0; 254}
[1].f2 ∈ {-258; 0}
[1]{.f3; .f4[0..2]} ∈ {-16843010; 0}
[2].f1 ∈ {-2; 0}
[2].[bits 8 to 15] ∈ {0; 254}
[2].f2 ∈ {-258; 0}
[2]{.f3; .f4[0..2]} ∈ {-16843010; 0}
[3].f1 ∈ {-2; 0}
[3].[bits 8 to 15] ∈ {0; 254}
[3].f2 ∈ {-258; 0}
[3]{.f3; .f4[0..2]} ∈ {-16843010; 0}
[4].f1 ∈ {-2; 0}
[4].[bits 8 to 15] ∈ {0; 254}
[4].f2 ∈ {-258; 0}
[4]{.f3; .f4[0..2]} ∈ {-16843010; 0}
[from] ====== DISPLAYING CALLWISE DEPENDENCIES ======
[from] ====== DISPLAYING CALLWISE DEPENDENCIES ======
[from] call to memset at tests/builtins/memset.c:33 (by
main
):
[from] call to memset at tests/builtins/memset.c:33 (by
test
):
t1[0..99] FROM c
t1[0..99] FROM c
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:34 (by
main
):
[from] call to memset at tests/builtins/memset.c:34 (by
test
):
t2[0..99] FROM c (and SELF)
t2[0..99] FROM c (and SELF)
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:35 (by
main
):
[from] call to memset at tests/builtins/memset.c:35 (by
test
):
t3[10..99] FROM c (and SELF)
t3[10..99] FROM c (and SELF)
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:38 (by
main
):
[from] call to memset at tests/builtins/memset.c:38 (by
test
):
t4[1..99] FROM c
t4[1..99] FROM c
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:41 (by
main
):
[from] call to memset at tests/builtins/memset.c:41 (by
test
):
t5[0..99] FROM c
t5[0..99] FROM c
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:44 (by
main
):
[from] call to memset at tests/builtins/memset.c:44 (by
test
):
t6[10..13] FROM c (and SELF)
t6[10..13] FROM c (and SELF)
t7[0..3] FROM c (and SELF)
t7[0..3] FROM c (and SELF)
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:47 (by
main
):
[from] call to memset at tests/builtins/memset.c:47 (by
test
):
t8[0..3] FROM c (and SELF)
t8[0..3] FROM c (and SELF)
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:54 (by
main
):
[from] call to memset at tests/builtins/memset.c:54 (by
test
):
t9[20..99] FROM c (and SELF)
t9[20..99] FROM c (and SELF)
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:58 (by
main
):
[from] call to memset at tests/builtins/memset.c:58 (by
test
):
t10[4..6] FROM c
t10[4..6] FROM c
[7..12] FROM c (and SELF)
[7..12] FROM c (and SELF)
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:65 (by
main
):
[from] call to memset at tests/builtins/memset.c:65 (by
test
):
t11{[2]; [4..6]} FROM c (and SELF)
t11{[2]; [4..6]} FROM c (and SELF)
[3] FROM c
[3] FROM c
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:68 (by
main
):
[from] call to memset at tests/builtins/memset.c:68 (by
test
):
ts[0..4] FROM c
ts[0..4] FROM c
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:72 (by
main
):
[from] call to memset at tests/builtins/memset.c:72 (by
test
):
t12[0..96] FROM c (and SELF)
t12[0..96] FROM c (and SELF)
\result FROM s
\result FROM s
[from] call to memset at tests/builtins/memset.c:84 (by uninit):
a FROM c
\result FROM s
[from] call to test at tests/builtins/memset.c:88 (by main):
t1[0..99] FROM \nothing
t2[0..99] FROM \nothing (and SELF)
t3[10..99] FROM \nothing (and SELF)
t4[1..99] FROM vol (and SELF)
t5[0..99] FROM \nothing
t6[10..13] FROM \nothing (and SELF)
t7[0..3] FROM \nothing (and SELF)
t8[0..3] FROM \nothing (and SELF)
t9[20..99] FROM \nothing (and SELF)
t10[4..6] FROM \nothing
[7..12] FROM \nothing (and SELF)
t11{[2]; [4..6]} FROM \nothing (and SELF)
[3] FROM \nothing
t12[0..96] FROM \nothing (and SELF)
ts[0..4] FROM vol (and SELF)
[from] call to uninit at tests/builtins/memset.c:89 (by main):
NO EFFECTS
[from] entry point:
[from] entry point:
t1[0..99] FROM \nothing
t1[0..99] FROM \nothing
t2[0..99] FROM \nothing (and SELF)
t2[0..99] FROM \nothing (and SELF)
...
@@ -204,10 +298,34 @@
...
@@ -204,10 +298,34 @@
t12[0..96] FROM \nothing (and SELF)
t12[0..96] FROM \nothing (and SELF)
ts[0..4] FROM vol (and SELF)
ts[0..4] FROM vol (and SELF)
[from] ====== END OF CALLWISE DEPENDENCIES ======
[from] ====== END OF CALLWISE DEPENDENCIES ======
[inout] Out (internal) for function
main
:
[inout] Out (internal) for function
test
:
t1[0..99]; t2[0..99]; t3[10..99]; t4[1..99]; t5[0..99]; t6[10..13];
t1[0..99]; t2[0..99]; t3[10..99]; t4[1..99]; t5[0..99]; t6[10..13];
t7[0..3]; t8[0..3]; t9[20..99]; t10[4..12]; t11[2..6]; t12[0..96];
t7[0..3]; t8[0..3]; t9[20..99]; t10[4..12]; t11[2..6]; t12[0..96];
ts[0..4]; dst; p; tmp_0; s; s1; k
ts[0..4]; dst; p; tmp_0; s; s1; k
[inout] Inputs for function test:
vol
[inout] InOut (internal) for function test:
Operational inputs:
vol
Operational inputs on termination:
vol
Sure outputs:
t1[0..99]; t5[0..99]; t10[4..6]; t11[3]; dst; p; tmp_0; s; s1; k
[inout] Out (internal) for function uninit:
x; a
[inout] Inputs for function uninit:
vol
[inout] InOut (internal) for function uninit:
Operational inputs:
vol; x
Operational inputs on termination:
vol; x
Sure outputs:
a
[inout] Out (internal) for function main:
t1[0..99]; t2[0..99]; t3[10..99]; t4[1..99]; t5[0..99]; t6[10..13];
t7[0..3]; t8[0..3]; t9[20..99]; t10[4..12]; t11[2..6]; t12[0..96];
ts[0..4]
[inout] Inputs for function main:
[inout] Inputs for function main:
vol
vol
[inout] InOut (internal) for function main:
[inout] InOut (internal) for function main:
...
@@ -216,4 +334,4 @@
...
@@ -216,4 +334,4 @@
Operational inputs on termination:
Operational inputs on termination:
vol
vol
Sure outputs:
Sure outputs:
t1[0..99]; t5[0..99]; t10[4..6]; t11[3]
; dst; p; tmp_0; s; s1; k
t1[0..99]; t5[0..99]; t10[4..6]; t11[3]
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment