From ae89383daa64d4bce7facda54ba5a04a12b801a8 Mon Sep 17 00:00:00 2001 From: Evgeniy Stepanov Date: Thu, 21 Nov 2013 11:37:16 +0000 Subject: [PATCH] Use multiple filecheck prefixes in msan instrumentation tests. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@195342 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../MemorySanitizer/check_access_address.ll | 28 +++++ .../MemorySanitizer/msan_basic.ll | 101 +++++------------- 2 files changed, 57 insertions(+), 72 deletions(-) create mode 100644 test/Instrumentation/MemorySanitizer/check_access_address.ll diff --git a/test/Instrumentation/MemorySanitizer/check_access_address.ll b/test/Instrumentation/MemorySanitizer/check_access_address.ll new file mode 100644 index 00000000000..566022600ea --- /dev/null +++ b/test/Instrumentation/MemorySanitizer/check_access_address.ll @@ -0,0 +1,28 @@ +; RUN: opt < %s -msan -msan-check-access-address=1 -S | FileCheck %s + +target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128" +target triple = "x86_64-unknown-linux-gnu" + + +; Test byval argument shadow alignment + +define <2 x i64> @ByValArgumentShadowLargeAlignment(<2 x i64>* byval %p) sanitize_memory { +entry: + %x = load <2 x i64>* %p + ret <2 x i64> %x +} + +; CHECK: @ByValArgumentShadowLargeAlignment +; CHECK: call void @llvm.memcpy.p0i8.p0i8.i64(i8* {{.*}}, i8* {{.*}}, i64 16, i32 8, i1 false) +; CHECK: ret <2 x i64> + + +define i16 @ByValArgumentShadowSmallAlignment(i16* byval %p) sanitize_memory { +entry: + %x = load i16* %p + ret i16 %x +} + +; CHECK: @ByValArgumentShadowSmallAlignment +; CHECK: call void @llvm.memcpy.p0i8.p0i8.i64(i8* {{.*}}, i8* {{.*}}, i64 2, i32 2, i1 false) +; CHECK: ret i16 diff --git a/test/Instrumentation/MemorySanitizer/msan_basic.ll b/test/Instrumentation/MemorySanitizer/msan_basic.ll index 72a992dd590..fceb3f00753 100644 --- a/test/Instrumentation/MemorySanitizer/msan_basic.ll +++ b/test/Instrumentation/MemorySanitizer/msan_basic.ll @@ -1,6 +1,5 @@ ; RUN: opt < %s -msan -msan-check-access-address=0 -S | FileCheck %s -; RUN: opt < %s -msan -msan-check-access-address=0 -msan-track-origins=1 -S | FileCheck -check-prefix=CHECK-ORIGINS %s -; RUN: opt < %s -msan -msan-check-access-address=1 -S | FileCheck %s -check-prefix=CHECK-AA +; RUN: opt < %s -msan -msan-check-access-address=0 -msan-track-origins=1 -S | FileCheck -check-prefix=CHECK -check-prefix=CHECK-ORIGINS %s target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128" target triple = "x86_64-unknown-linux-gnu" @@ -32,20 +31,16 @@ entry: ; CHECK: @Store ; CHECK: load {{.*}} @__msan_param_tls +; CHECK-ORIGINS: load {{.*}} @__msan_param_origin_tls ; CHECK: store -; CHECK: store -; CHECK: ret void -; CHECK-ORIGINS: @Store -; CHECK-ORIGINS: load {{.*}} @__msan_param_tls -; CHECK-ORIGINS: store ; CHECK-ORIGINS: icmp ; CHECK-ORIGINS: br i1 ; CHECK-ORIGINS: