From a53fade6e85394ef95dfaaa1c264149e85ea5451 Mon Sep 17 00:00:00 2001 From: Andrea Mattavelli Date: Wed, 22 Nov 2017 17:18:07 +0000 Subject: Added support for KLEE index-based array optimization --- test/ArrayOpt/test_const_arr-idx.c | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 test/ArrayOpt/test_const_arr-idx.c (limited to 'test/ArrayOpt/test_const_arr-idx.c') diff --git a/test/ArrayOpt/test_const_arr-idx.c b/test/ArrayOpt/test_const_arr-idx.c new file mode 100644 index 00000000..25f959a3 --- /dev/null +++ b/test/ArrayOpt/test_const_arr-idx.c @@ -0,0 +1,26 @@ +// RUN: %llvmgcc %s -emit-llvm -O0 -c -o %t.bc +// RUN: rm -rf %t.klee-out +// RUN: %klee --write-kqueries --output-dir=%t.klee-out --optimize-array=index %t.bc > %t.log 2>&1 +// RUN: not FileCheck %s -input-file=%t.log -check-prefix=CHECK-OPT_I + +// CHECK-OPT_I: KLEE: WARNING: OPT_I: successful +// CHECK-CONST_ARR: const_arr + +#include +#include "klee/klee.h" + +unsigned array[5] = {1,2,3,4,5}; +int arr[3] = {0,1,2}; + +int main() { + int x = 2; + unsigned k = arr[x]; + + // CHECK: Yes + if (array[k] == 3) + printf("Yes\n"); + + // CHECK: KLEE: done: completed paths = 1 + + return 0; +} -- cgit 1.4.1