1
1
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
2
- ; RUN: opt < %s -S -passes='msan' 2>&1 | FileCheck %s
2
+ ; RUN: opt < %s -S -passes='msan' 2>&1 | FileCheck %s --check-prefixes=CHECK,CHECK-PRECISE
3
+ ; RUN: opt < %s -S -passes='msan' -msan-poison-undef-vectors=false 2>&1 | FileCheck %s --check-prefixes=CHECK,CHECK-IMPRECISE
3
4
;
4
- ; Regression test case for computing shadows of partially poisoned vectors
5
+ ; Regression test case for computing shadows of partially poisoned vectors.
6
+ ; Partially poisoned structs and arrays are not correctly implemented.
5
7
6
8
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"
7
9
target triple = "x86_64-unknown-linux-gnu"
@@ -10,7 +12,8 @@ define <2 x i64> @left_poison(ptr %add.ptr) sanitize_memory {
10
12
; CHECK-LABEL: define <2 x i64> @left_poison(
11
13
; CHECK-SAME: ptr [[ADD_PTR:%.*]]) #[[ATTR0:[0-9]+]] {
12
14
; CHECK-NEXT: call void @llvm.donothing()
13
- ; CHECK-NEXT: store <2 x i64> <i64 -1, i64 0>, ptr @__msan_retval_tls, align 8
15
+ ; CHECK-PRECISE: store <2 x i64> <i64 -1, i64 0>, ptr @__msan_retval_tls, align 8
16
+ ; CHECK-IMPRECISE: store <2 x i64> zeroinitializer, ptr @__msan_retval_tls, align 8
14
17
; CHECK-NEXT: ret <2 x i64> <i64 poison, i64 42>
15
18
;
16
19
ret <2 x i64 > <i64 poison, i64 42 >
@@ -20,7 +23,8 @@ define <2 x i64> @right_poison(ptr %add.ptr) sanitize_memory {
20
23
; CHECK-LABEL: define <2 x i64> @right_poison(
21
24
; CHECK-SAME: ptr [[ADD_PTR:%.*]]) #[[ATTR0]] {
22
25
; CHECK-NEXT: call void @llvm.donothing()
23
- ; CHECK-NEXT: store <2 x i64> <i64 0, i64 -1>, ptr @__msan_retval_tls, align 8
26
+ ; CHECK-PRECISE: store <2 x i64> <i64 0, i64 -1>, ptr @__msan_retval_tls, align 8
27
+ ; CHECK-IMPRECISE: store <2 x i64> zeroinitializer, ptr @__msan_retval_tls, align 8
24
28
; CHECK-NEXT: ret <2 x i64> <i64 42, i64 poison>
25
29
;
26
30
ret <2 x i64 > <i64 42 , i64 poison>
@@ -50,7 +54,8 @@ define <2 x i64> @left_undef(ptr %add.ptr) sanitize_memory {
50
54
; CHECK-LABEL: define <2 x i64> @left_undef(
51
55
; CHECK-SAME: ptr [[ADD_PTR:%.*]]) #[[ATTR0]] {
52
56
; CHECK-NEXT: call void @llvm.donothing()
53
- ; CHECK-NEXT: store <2 x i64> <i64 -1, i64 0>, ptr @__msan_retval_tls, align 8
57
+ ; CHECK-PRECISE: store <2 x i64> <i64 -1, i64 0>, ptr @__msan_retval_tls, align 8
58
+ ; CHECK-IMPRECISE: store <2 x i64> zeroinitializer, ptr @__msan_retval_tls, align 8
54
59
; CHECK-NEXT: ret <2 x i64> <i64 undef, i64 42>
55
60
;
56
61
ret <2 x i64 > <i64 undef , i64 42 >
@@ -60,7 +65,8 @@ define <2 x i64> @right_undef(ptr %add.ptr) sanitize_memory {
60
65
; CHECK-LABEL: define <2 x i64> @right_undef(
61
66
; CHECK-SAME: ptr [[ADD_PTR:%.*]]) #[[ATTR0]] {
62
67
; CHECK-NEXT: call void @llvm.donothing()
63
- ; CHECK-NEXT: store <2 x i64> <i64 0, i64 -1>, ptr @__msan_retval_tls, align 8
68
+ ; CHECK-PRECISE: store <2 x i64> <i64 0, i64 -1>, ptr @__msan_retval_tls, align 8
69
+ ; CHECK-IMPRECISE: store <2 x i64> zeroinitializer, ptr @__msan_retval_tls, align 8
64
70
; CHECK-NEXT: ret <2 x i64> <i64 42, i64 undef>
65
71
;
66
72
ret <2 x i64 > <i64 42 , i64 undef >
@@ -70,8 +76,28 @@ define <2 x i64> @full_undef(ptr %add.ptr) sanitize_memory {
70
76
; CHECK-LABEL: define <2 x i64> @full_undef(
71
77
; CHECK-SAME: ptr [[ADD_PTR:%.*]]) #[[ATTR0]] {
72
78
; CHECK-NEXT: call void @llvm.donothing()
73
- ; CHECK-NEXT : store <2 x i64> splat (i64 -1), ptr @__msan_retval_tls, align 8
79
+ ; CHECK: store <2 x i64> splat (i64 -1), ptr @__msan_retval_tls, align 8
74
80
; CHECK-NEXT: ret <2 x i64> undef
75
81
;
76
82
ret <2 x i64 > <i64 undef , i64 undef >
77
83
}
84
+
85
+ define {i64 , i64 } @struct_left_undef () sanitize_memory {
86
+ ; CHECK-LABEL: define { i64, i64 } @struct_left_undef(
87
+ ; CHECK-SAME: ) #[[ATTR0]] {
88
+ ; CHECK-NEXT: call void @llvm.donothing()
89
+ ; CHECK-NEXT: store { i64, i64 } zeroinitializer, ptr @__msan_retval_tls, align 8
90
+ ; CHECK-NEXT: ret { i64, i64 } { i64 undef, i64 42 }
91
+ ;
92
+ ret {i64 , i64 } { i64 undef , i64 42 }
93
+ }
94
+
95
+ define [2x i64 ] @array_right_undef () sanitize_memory {
96
+ ; CHECK-LABEL: define [2 x i64] @array_right_undef(
97
+ ; CHECK-SAME: ) #[[ATTR0]] {
98
+ ; CHECK-NEXT: call void @llvm.donothing()
99
+ ; CHECK-NEXT: store [2 x i64] zeroinitializer, ptr @__msan_retval_tls, align 8
100
+ ; CHECK-NEXT: ret [2 x i64] [i64 42, i64 undef]
101
+ ;
102
+ ret [2x i64 ] [ i64 42 , i64 undef ]
103
+ }
0 commit comments