blob: dfab14d38c3db43b17f4748cea61589b8c9bdc1b (
plain) (
blame)
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
|
// RUN: %clang %s -emit-llvm -g %O0opt -c -o %t.bc
// RUN: rm -rf %t.klee-out
// RUN: %klee --output-dir=%t.klee-out --use-cex-cache=false %t.bc >%t1.log
// This bug is triggered when using STP up to an including 2.1.0
// See https://github.com/klee/klee/issues/308
// and https://github.com/stp/stp/issues/206
#include "klee/klee.h"
int b, a, g;
int *c = &b, *d = &b, *f = &a;
int safe_div(short p1, int p2) {
return p2 == 0 ? p1 : p2;
}
int main() {
klee_make_symbolic(&b, sizeof b, "b");
if (safe_div(*c, 0))
*f = (int)&b % *c;
safe_div(a && g, *d);
}
|