From cbf10dbdd7345434e0ec74526ec3ca3d0391797a Mon Sep 17 00:00:00 2001 From: Cristian Cadar Date: Fri, 20 Oct 2023 16:58:26 +0100 Subject: Concretize constants using seed values, when available. Added two tests (w/ and w/o seed extension) based on FP concretization. --- test/Feature/SeedConcretizeFP.c | 27 +++++++++++++++++++++++++++ test/Feature/SeedConcretizePatchedFP.c | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+) create mode 100644 test/Feature/SeedConcretizeFP.c create mode 100644 test/Feature/SeedConcretizePatchedFP.c (limited to 'test') diff --git a/test/Feature/SeedConcretizeFP.c b/test/Feature/SeedConcretizeFP.c new file mode 100644 index 00000000..bc5246ad --- /dev/null +++ b/test/Feature/SeedConcretizeFP.c @@ -0,0 +1,27 @@ +// RUN: %clang -emit-llvm -c -g %s -o %t.bc +// RUN: rm -rf %t.klee-out +// RUN: %klee --output-dir=%t.klee-out --entry-point=TestGen %t.bc +// RUN: test -f %t.klee-out/test000001.ktest +// RUN: not test -f %t.klee-out/test000002.ktest + +// RUN: rm -rf %t.klee-out-2 +// RUN: %klee --exit-on-error --output-dir=%t.klee-out-2 --seed-file %t.klee-out/test000001.ktest %t.bc 2>&1 | FileCheck %s + +#include "klee/klee.h" + +#include +#include + +void TestGen() { + unsigned x; + klee_make_symbolic(&x, sizeof(x), "x"); + klee_assume(x == 12345678); +} + +int main() { + unsigned i; + klee_make_symbolic(&i, sizeof(i), "i"); + double d = i; + // CHECK: concretizing (reason: floating point) + assert((unsigned) d == 12345678); +} diff --git a/test/Feature/SeedConcretizePatchedFP.c b/test/Feature/SeedConcretizePatchedFP.c new file mode 100644 index 00000000..b8b758b5 --- /dev/null +++ b/test/Feature/SeedConcretizePatchedFP.c @@ -0,0 +1,33 @@ +/* This test checks the case where the seed needs to be patched on re-run */ + +// RUN: %clang -emit-llvm -c %O0opt -g %s -o %t.bc +// RUN: rm -rf %t.klee-out +// RUN: %klee --output-dir=%t.klee-out --entry-point=TestGen %t.bc +// RUN: test -f %t.klee-out/test000001.ktest +// RUN: not test -f %t.klee-out/test000002.ktest + +// RUN: rm -rf %t.klee-out-2 +// RUN: %klee --exit-on-error --output-dir=%t.klee-out-2 --seed-file %t.klee-out/test000001.ktest --allow-seed-extension --zero-seed-extension %t.bc 2>&1 | FileCheck %s + +#include "klee/klee.h" + +#include +#include +#include + +void TestGen() { + uint16_t x; + klee_make_symbolic(&x, sizeof(x), "x"); + klee_assume(x == 1234); +} + +int main() { + uint32_t i; + klee_make_symbolic(&i, sizeof(i), "i"); + + if (i < 5000) { + double d = i; + // CHECK: concretizing (reason: floating point) + assert((unsigned) d < 5001); + } +} -- cgit 1.4.1