-
Notifications
You must be signed in to change notification settings - Fork 273
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
goto-symex: assumed pointer equalities must update value set #8494
base: develop
Are you sure you want to change the base?
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## develop #8494 +/- ##
===========================================
- Coverage 78.90% 78.89% -0.01%
===========================================
Files 1727 1727
Lines 198425 198452 +27
Branches 18523 18499 -24
===========================================
+ Hits 156561 156568 +7
- Misses 41864 41884 +20 ☔ View full report in Codecov by Sentry. |
Value sets and constant propagation are our only sources of points-to information when resolving dereferences in goto-symex. Therefore, assuming or branching on equalities of pointer-typed variables must have us consider both of their value sets to be equal. Else we may end up with spurious counterexamples as seen with the enclosed regression test (where we previously did not have any known value for `a`). Fixes: diffblue#8492
7834dd5
to
2a27074
Compare
// We have a condition a == b. Make both a's and b's value sets the | ||
// union of their previous value sets (the last "true" argument makes | ||
// sure we add rather than replace value sets). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What would happen in a situation like this ?
p = malloc(4);// o1
q = malloc(4);// o2
__CPROVER_assume(p == q);
// now p and q have both &o1 and &o2 in their value sets
*p = 1; // what happens here ?
*q = 2; // what happens here ?
This is problematic, and needs a deeper discussion. I appreciate this is meant as a fix for #8492, but I'd advise to do a contract-specific fix. |
Value sets and constant propagation are our only sources of points-to information when resolving dereferences in goto-symex. Therefore, assuming or branching on equalities of pointer-typed variables must have us consider both of their value sets to be equal. Else we may end up with spurious counterexamples as seen with the enclosed regression test (where we previously did not have any known value for
a
).Fixes: #8492