about summary refs log tree commit diff homepage
path: root/test
diff options
context:
space:
mode:
authorCristian Cadar <c.cadar@imperial.ac.uk>2022-06-25 21:02:58 +0100
committerMartinNowack <2443641+MartinNowack@users.noreply.github.com>2022-09-26 09:42:07 +0100
commit667ce0f1ef33c32fbe2d1836fc1b334066e244ca (patch)
treebc338c8c00a2adc7577366eba9cecdc7ee5b3e82 /test
parent21146a3653cdb29790a9d0f557f0f1651befbe9e (diff)
downloadklee-667ce0f1ef33c32fbe2d1836fc1b334066e244ca.tar.gz
Improve the message for when large arrays become symbolic. Only print this warning once per array. Add test case.
Diffstat (limited to 'test')
-rw-r--r--test/Feature/LargeArrayBecomesSym.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/test/Feature/LargeArrayBecomesSym.c b/test/Feature/LargeArrayBecomesSym.c
new file mode 100644
index 00000000..a875e99e
--- /dev/null
+++ b/test/Feature/LargeArrayBecomesSym.c
@@ -0,0 +1,33 @@
+/* This test checks that KLEE emits a warning when a large (> 4096) 
+   concrete array becomes symbolic. */
+
+// RUN: %clang %s -emit-llvm %O0opt -c -o %t1.bc
+// RUN: rm -rf %t.klee-out
+/* The solver timeout is needed as some solvers, such as metaSMT+CVC4, time out here. */
+// RUN: %klee --max-solver-time=2 --output-dir=%t.klee-out %t1.bc 2>&1 | FileCheck %s
+
+#include "klee/klee.h"
+
+#include <assert.h>
+#include <stdio.h>
+
+#define N 4100
+
+int main() {
+  char a[N] = {
+      1,
+      2,
+  };
+
+  unsigned k;
+  klee_make_symbolic(&k, sizeof(k), "k");
+  klee_assume(k < N);
+  a[k] = 3;
+  // CHECK: KLEE: WARNING ONCE: Symbolic memory access will send the following array of 4100 bytes to the constraint solver
+
+  unsigned i;
+  klee_make_symbolic(&i, sizeof(i), "i");
+  klee_assume(i < N);
+  if (a[i] == 2)
+    assert(i == 1);
+}