about summary refs log tree commit diff homepage
path: root/test/regression
diff options
context:
space:
mode:
authorRichard Trembecký <richardt@centrum.sk>2016-04-29 22:33:41 +0200
committerCristian Cadar <c.cadar@imperial.ac.uk>2018-05-24 14:08:27 +0100
commita0cd85b41f02ce5c476612eec182aa1ff3e6fe2b (patch)
treeb7d938116cae4f4a18225e9aef2f8934b761e063 /test/regression
parent870f2d6aac35457e7524078a4b4a8b011f84c45c (diff)
downloadklee-a0cd85b41f02ce5c476612eec182aa1ff3e6fe2b.tar.gz
test: add versions of some tests for LLVM 3.7
Clone some tests to have their 3.7 version. 'call's, 'load's and
'getelementptr's match the new specification in them.

@andreamattavelli: Fixed test cases: BitCastAlias test cases included
modification to alias specifications that require LLVM 3.8

[v2] added comments what was changed and why
[v3] the new tests are without suffix, the old ones have ".leq36".

Signed-off-by: Jiri Slaby <jirislaby@gmail.com>
Diffstat (limited to 'test/regression')
-rw-r--r--test/regression/2007-08-16-invalid-constant-value.c5
-rw-r--r--test/regression/2007-08-16-invalid-constant-value.leq36.c33
2 files changed, 36 insertions, 2 deletions
diff --git a/test/regression/2007-08-16-invalid-constant-value.c b/test/regression/2007-08-16-invalid-constant-value.c
index 5b17e68b..fd011f2e 100644
--- a/test/regression/2007-08-16-invalid-constant-value.c
+++ b/test/regression/2007-08-16-invalid-constant-value.c
@@ -1,3 +1,4 @@
+// REQUIRES: geq-llvm-3.7
 // RUN: rm -f %t4.out %t4.err %t4.log
 // RUN: %llvmgcc %s -emit-llvm -O2 -c -o %t1.bc
 // RUN: llvm-as -f %p/../Feature/_utils._ll -o %t2.bc
@@ -18,12 +19,12 @@ int main() {
   // value was being created when implied value did not
   // subtract using the proper type (so overflowed into
   // invalid bits)
-  if (util_make_concat2(a+0xCD,0xCD) == 0xABCD) { 
+  if (util_make_concat2(a + 0xCD, 0xCD) == 0xABCD) {
     assert(!klee_is_symbolic(a));
     printf("add constant case: %d\n", a);
   }
 
-  if (util_make_concat2(0x0B-a,0xCD) == 0xABCD) { 
+  if (util_make_concat2(0x0B - a, 0xCD) == 0xABCD) {
     assert(!klee_is_symbolic(a));
     printf("sub constant case: %d\n", a);
   }
diff --git a/test/regression/2007-08-16-invalid-constant-value.leq36.c b/test/regression/2007-08-16-invalid-constant-value.leq36.c
new file mode 100644
index 00000000..bf9f7561
--- /dev/null
+++ b/test/regression/2007-08-16-invalid-constant-value.leq36.c
@@ -0,0 +1,33 @@
+// REQUIRES: lt-llvm-3.7
+// RUN: rm -f %t4.out %t4.err %t4.log
+// RUN: %llvmgcc %s -emit-llvm -O2 -c -o %t1.bc
+// RUN: llvm-as -f %p/../Feature/_utils.leq36._ll -o %t2.bc
+// RUN: llvm-link %t1.bc %t2.bc -o %t3.bc
+// RUN: rm -rf %t.klee-out
+// RUN: %klee --output-dir=%t.klee-out %t3.bc
+
+#include <assert.h>
+
+#include "../Feature/utils.h"
+
+int main() {
+  unsigned char a;
+
+  klee_make_symbolic(&a, sizeof a, "a");
+
+  // demand was firing here because an invalid constant
+  // value was being created when implied value did not
+  // subtract using the proper type (so overflowed into
+  // invalid bits)
+  if (util_make_concat2(a+0xCD,0xCD) == 0xABCD) { 
+    assert(!klee_is_symbolic(a));
+    printf("add constant case: %d\n", a);
+  }
+
+  if (util_make_concat2(0x0B-a,0xCD) == 0xABCD) { 
+    assert(!klee_is_symbolic(a));
+    printf("sub constant case: %d\n", a);
+  }
+
+  return 0;
+}