diff options
author | Cristian Cadar <c.cadar@imperial.ac.uk> | 2015-02-10 13:29:11 +0000 |
---|---|---|
committer | Cristian Cadar <c.cadar@imperial.ac.uk> | 2015-02-10 13:29:11 +0000 |
commit | a743d7072d9ccf11f96e3df45f25ad07da6ad9d6 (patch) | |
tree | 19e77dd4a3eb6bc4102eb59a136ead47b537c372 /test | |
parent | ad4f23ac1b1faa561d199b27e041e1a1afa3adcb (diff) | |
download | klee-a743d7072d9ccf11f96e3df45f25ad07da6ad9d6.tar.gz |
Merged @luckyluke's change for detecting overflow of unsigned add, sub
and mul operations. Refactored tests into two main cases, and disabled them on LLVM 2.9, which does not support -fsanitized=*signed-integer-overflow.
Diffstat (limited to 'test')
-rw-r--r-- | test/Feature/ubsan_signed_overflow.c | 29 | ||||
-rw-r--r-- | test/Feature/ubsan_unsigned_overflow.c | 29 |
2 files changed, 58 insertions, 0 deletions
diff --git a/test/Feature/ubsan_signed_overflow.c b/test/Feature/ubsan_signed_overflow.c new file mode 100644 index 00000000..9816d496 --- /dev/null +++ b/test/Feature/ubsan_signed_overflow.c @@ -0,0 +1,29 @@ +// RUN: %llvmgcc %s -fsanitize=signed-integer-overflow -emit-llvm -g -O0 -c -o %t.bc +// RUN: rm -rf %t.klee-out +// RUN: %klee --output-dir=%t.klee-out %t.bc 2>&1 | FileCheck %s + +// llvm-gcc 2.9 does not support -fsanitize=signed-integer-overflow +// REQUIRES: not-llvm-2.9 + +#include "klee/klee.h" + +int main() +{ + signed int x; + signed int y; + volatile signed int result; + + klee_make_symbolic(&x, sizeof(x), "x"); + klee_make_symbolic(&y, sizeof(y), "y"); + + // CHECK: ubsan_signed_overflow.c:20: overflow on unsigned addition + result = x + y; + + // CHECK: ubsan_signed_overflow.c:23: overflow on unsigned subtraction + result = x - y; + + // CHECK: ubsan_signed_overflow.c:26: overflow on unsigned multiplication + result = x * y; + + return 0; +} diff --git a/test/Feature/ubsan_unsigned_overflow.c b/test/Feature/ubsan_unsigned_overflow.c new file mode 100644 index 00000000..82eacdd7 --- /dev/null +++ b/test/Feature/ubsan_unsigned_overflow.c @@ -0,0 +1,29 @@ +// RUN: %llvmgcc %s -fsanitize=unsigned-integer-overflow -emit-llvm -g -O0 -c -o %t.bc +// RUN: rm -rf %t.klee-out +// RUN: %klee --output-dir=%t.klee-out %t.bc 2>&1 | FileCheck %s + +// llvm-gcc 2.9 does not support -fsanitize=unsigned-integer-overflow +// REQUIRES: not-llvm-2.9 + +#include "klee/klee.h" + +int main() +{ + unsigned int x; + unsigned int y; + volatile unsigned int result; + + klee_make_symbolic(&x, sizeof(x), "x"); + klee_make_symbolic(&y, sizeof(y), "y"); + + // CHECK: ubsan_unsigned_overflow.c:20: overflow on unsigned addition + result = x + y; + + // CHECK: ubsan_unsigned_overflow.c:23: overflow on unsigned subtraction + result = x - y; + + // CHECK: ubsan_unsigned_overflow.c:26: overflow on unsigned multiplication + result = x * y; + + return 0; +} |