aboutsummaryrefslogtreecommitdiffhomepage
path: root/test
diff options
context:
space:
mode:
authorDan Liew <daniel.liew@imperial.ac.uk>2013-11-07 12:17:33 +0000
committerDan Liew <daniel.liew@imperial.ac.uk>2014-02-14 18:07:31 +0000
commit207d3aff50cc4bed2adf12819a96fc4254a3d6e6 (patch)
tree802f1d4dcaf78521ec9532546cd32c433d921ff0 /test
parented963d407e5de9b09191324f5e277ea40e1aea0b (diff)
downloadklee-207d3aff50cc4bed2adf12819a96fc4254a3d6e6.tar.gz
Added C test case that checks that concrete and symbolic overshift
behaviour for left shift are identical.
Diffstat (limited to 'test')
-rw-r--r--test/Feature/left-overshift-sym-conc.c63
1 files changed, 63 insertions, 0 deletions
diff --git a/test/Feature/left-overshift-sym-conc.c b/test/Feature/left-overshift-sym-conc.c
new file mode 100644
index 00000000..e962fa28
--- /dev/null
+++ b/test/Feature/left-overshift-sym-conc.c
@@ -0,0 +1,63 @@
+// RUN: %llvmgcc %s -emit-llvm -g -O0 -c -o %t.bc
+// RUN: %klee -use-cex-cache=1 -check-overshift=0 %t.bc
+// RUN: not grep "ASSERTION FAIL" %T/klee-last/messages.txt
+// RUN: grep "KLEE: done: explored paths = 1" %T/klee-last/info
+#include <stdio.h>
+#include <assert.h>
+
+typedef enum
+{
+ TO_ZERO,
+ MASKED,
+ UNKNOWN
+} overshift_t;
+
+int overshift(volatile unsigned int y, const char * type)
+{
+ overshift_t ret;
+ volatile unsigned int x=15;
+ unsigned int limit = sizeof(x)*8;
+
+ volatile unsigned int result;
+ result = x << y; // Potential overshift
+
+ if (result ==0)
+ {
+ printf("%s : Overshift to zero\n", type);
+ ret = TO_ZERO;
+ }
+ else if (result == ( x << (y % limit)) )
+ {
+ printf("%s : Bitmasked overshift\n", type);
+ ret = MASKED;
+ }
+ else
+ {
+ printf("%s : Unrecognised behaviour.\n", type);
+ ret = UNKNOWN;
+ }
+
+ return ret;
+}
+
+int main(int argc, char** argv)
+{
+ // Concrete overshift
+ volatile unsigned int y = sizeof(unsigned int)*8;
+ overshift_t conc = overshift(y, "Concrete");
+ assert( conc == TO_ZERO);
+
+ // Symbolic overshift
+ volatile unsigned int y2;
+ klee_make_symbolic(&y2,sizeof(y),"y2");
+ // Add constraints so only one value possible
+ klee_assume(y2 > (y-1));
+ klee_assume(y2 < (y+1));
+ overshift_t sym = overshift(y2, "Symbolic");
+ assert( sym == TO_ZERO);
+
+ // Concrete and symbolic behaviour should be the same
+ assert( conc == sym);
+
+ return 0;
+}