diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-10-22 22:51:04 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-10-22 22:51:04 +0000 |
commit | 6b53e224ebcd0b99be4db9fc12e9d080c69c04b9 (patch) | |
tree | 04b05b8af1551a91587247f9f9fcc1a03f524f18 /clang/test/CodeGen/bounds-checking.c | |
parent | 106260c5746ab00e12ef3df483c438484279d5f4 (diff) | |
download | bcm5719-llvm-6b53e224ebcd0b99be4db9fc12e9d080c69c04b9.tar.gz bcm5719-llvm-6b53e224ebcd0b99be4db9fc12e9d080c69c04b9.zip |
Split -fsanitize=bounds to -fsanitize=array-bounds (for the frontend-inserted
check using the ubsan runtime) and -fsanitize=local-bounds (for the middle-end
check which inserts traps).
Remove -fsanitize=local-bounds from -fsanitize=undefined. It does not produce
useful diagnostics and has false positives (PR17635), and is not a good
compromise position between UBSan's checks and ASan's checks.
Map -fbounds-checking to -fsanitize=local-bounds to restore Clang's historical
behavior for that flag.
llvm-svn: 193205
Diffstat (limited to 'clang/test/CodeGen/bounds-checking.c')
-rw-r--r-- | clang/test/CodeGen/bounds-checking.c | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/clang/test/CodeGen/bounds-checking.c b/clang/test/CodeGen/bounds-checking.c index fa7541f8141..d93cd3ede7d 100644 --- a/clang/test/CodeGen/bounds-checking.c +++ b/clang/test/CodeGen/bounds-checking.c @@ -1,26 +1,29 @@ -// RUN: %clang_cc1 -fsanitize=bounds -emit-llvm -triple x86_64-apple-darwin10 < %s | FileCheck %s +// RUN: %clang_cc1 -fsanitize=local-bounds -emit-llvm -triple x86_64-apple-darwin10 %s -o - | FileCheck %s +// RUN: %clang_cc1 -fsanitize=array-bounds -O -fsanitize-undefined-trap-on-error -emit-llvm -triple x86_64-apple-darwin10 -DNO_DYNAMIC %s -o - | FileCheck %s -// CHECK: @f +// CHECK-LABEL: @f double f(int b, int i) { double a[b]; - // CHECK: trap + // CHECK: call {{.*}} @llvm.trap return a[i]; } -// CHECK: @f2 +// CHECK-LABEL: @f2 void f2() { // everything is constant; no trap possible - // CHECK-NOT: trap + // CHECK-NOT: call {{.*}} @llvm.trap int a[2]; a[1] = 42; - + +#ifndef NO_DYNAMIC short *b = malloc(64); b[5] = *a + a[1] + 2; +#endif } -// CHECK: @f3 +// CHECK-LABEL: @f3 void f3() { int a[1]; - // CHECK: trap + // CHECK: call {{.*}} @llvm.trap a[2] = 1; } |