1 ; RUN: opt -scalarrepl -disable-output < %s 2 ; RUN: opt -scalarrepl-ssa -disable-output < %s 3 4 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" 5 target triple = "x86_64-apple-darwin10.0.0" 6 7 ; PR9017 8 define void @test1() nounwind readnone ssp { 9 entry: 10 %l_72 = alloca i32*, align 8 11 unreachable 12 13 for.cond: ; preds = %for.cond 14 %tmp1.i = load i32*, i32** %l_72, align 8 15 store i32* %tmp1.i, i32** %l_72, align 8 16 br label %for.cond 17 18 if.end: ; No predecessors! 19 ret void 20 } 21 22 23 define void @test2() { 24 %E = alloca { { i32, float, double, i64 }, { i32, float, double, i64 } } ; <{ { i32, float, double, i64 }, { i32, float, double, i64 } }*> [#uses=1] 25 %tmp.151 = getelementptr { { i32, float, double, i64 }, { i32, float, double, i64 } }, { { i32, float, double, i64 }, { i32, float, double, i64 } }* %E, i64 0, i32 1, i32 3 ; <i64*> [#uses=0] 26 ret void 27 } 28 29 define i32 @test3() { 30 %X = alloca { [4 x i32] } ; <{ [4 x i32] }*> [#uses=1] 31 %Y = getelementptr { [4 x i32] }, { [4 x i32] }* %X, i64 0, i32 0, i64 2 ; <i32*> [#uses=2] 32 store i32 4, i32* %Y 33 %Z = load i32, i32* %Y ; <i32> [#uses=1] 34 ret i32 %Z 35 } 36 37 38 %struct.rtx_def = type { [2 x i8], i32, [1 x %union.rtunion_def] } 39 %union.rtunion_def = type { i32 } 40 41 define void @test4() { 42 entry: 43 %c_addr.i = alloca i8 ; <i8*> [#uses=1] 44 switch i32 0, label %return [ 45 i32 36, label %label.7 46 i32 34, label %label.7 47 i32 41, label %label.5 48 ] 49 label.5: ; preds = %entry 50 ret void 51 label.7: ; preds = %entry, %entry 52 br i1 false, label %then.4, label %switchexit.0 53 then.4: ; preds = %label.7 54 %tmp.0.i = bitcast i8* %c_addr.i to i32* ; <i32*> [#uses=1] 55 store i32 44, i32* %tmp.0.i 56 ret void 57 switchexit.0: ; preds = %label.7 58 ret void 59 return: ; preds = %entry 60 ret void 61 } 62 63 64 define void @test5() { 65 entry: 66 %source_ptr = alloca i8*, align 4 ; <i8**> [#uses=2] 67 br i1 false, label %bb1357, label %cond_next583 68 cond_next583: ; preds = %entry 69 ret void 70 bb1357: ; preds = %entry 71 br i1 false, label %bb1365, label %bb27055 72 bb1365: ; preds = %bb1357 73 switch i32 0, label %cond_next10377 [ 74 i32 0, label %bb4679 75 i32 1, label %bb4679 76 i32 2, label %bb4679 77 i32 3, label %bb4679 78 i32 4, label %bb5115 79 i32 5, label %bb6651 80 i32 6, label %bb7147 81 i32 7, label %bb8683 82 i32 8, label %bb9131 83 i32 9, label %bb9875 84 i32 10, label %bb4679 85 i32 11, label %bb4859 86 i32 12, label %bb4679 87 i32 16, label %bb10249 88 ] 89 bb4679: ; preds = %bb1365, %bb1365, %bb1365, %bb1365, %bb1365, %bb1365 90 ret void 91 bb4859: ; preds = %bb1365 92 ret void 93 bb5115: ; preds = %bb1365 94 ret void 95 bb6651: ; preds = %bb1365 96 ret void 97 bb7147: ; preds = %bb1365 98 ret void 99 bb8683: ; preds = %bb1365 100 ret void 101 bb9131: ; preds = %bb1365 102 ret void 103 bb9875: ; preds = %bb1365 104 %source_ptr9884 = bitcast i8** %source_ptr to i8** ; <i8**> [#uses=1] 105 %tmp9885 = load i8*, i8** %source_ptr9884 ; <i8*> [#uses=0] 106 ret void 107 bb10249: ; preds = %bb1365 108 %source_ptr10257 = bitcast i8** %source_ptr to i16** ; <i16**> [#uses=1] 109 %tmp10258 = load i16*, i16** %source_ptr10257 ; <i16*> [#uses=0] 110 ret void 111 cond_next10377: ; preds = %bb1365 112 ret void 113 bb27055: ; preds = %bb1357 114 ret void 115 } 116 117 118 %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>" = type { %"struct.__gnu_cxx::bitmap_allocator<char>::_Alloc_block"* } 119 %"struct.__gnu_cxx::bitmap_allocator<char>" = type { i8 } 120 %"struct.__gnu_cxx::bitmap_allocator<char>::_Alloc_block" = type { [8 x i8] } 121 122 ; PR1045 123 define void @test6() { 124 entry: 125 %this_addr.i = alloca %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"* ; <%"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"**> [#uses=3] 126 %tmp = alloca %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>", align 4 ; <%"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"*> [#uses=1] 127 store %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"* %tmp, %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"** %this_addr.i 128 %tmp.i = load %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"*, %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"** %this_addr.i ; <%"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"*> [#uses=1] 129 %tmp.i.upgrd.1 = bitcast %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"* %tmp.i to %"struct.__gnu_cxx::bitmap_allocator<char>"* ; <%"struct.__gnu_cxx::bitmap_allocator<char>"*> [#uses=0] 130 %tmp1.i = load %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"*, %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"** %this_addr.i ; <%"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"*> [#uses=1] 131 %tmp.i.upgrd.2 = getelementptr %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>", %"struct.__gnu_cxx::balloc::_Inclusive_between<__gnu_cxx::bitmap_allocator<char>::_Alloc_block*>"* %tmp1.i, i32 0, i32 0 ; <%"struct.__gnu_cxx::bitmap_allocator<char>::_Alloc_block"**> [#uses=0] 132 unreachable 133 } 134 135 %struct.CGPoint = type { float, float } 136 %struct.aal_big_range_t = type { i32, i32 } %struct.aal_callback_t = type { i8* (i8*, i32)*, void (i8*, i8*)* } %struct.aal_edge_pool_t = type { %struct.aal_edge_pool_t*, i32, i32, [0 x %struct.aal_edge_t] } %struct.aal_edge_t = type { %struct.CGPoint, %struct.CGPoint, i32 } 137 %struct.aal_range_t = type { i16, i16 } 138 %struct.aal_span_pool_t = type { %struct.aal_span_pool_t*, [341 x %struct.aal_span_t] } 139 %struct.aal_span_t = type { %struct.aal_span_t*, %struct.aal_big_range_t } 140 %struct.aal_spanarray_t = type { [2 x %struct.aal_range_t] } 141 %struct.aal_spanbucket_t = type { i16, [2 x i8], %struct.anon } 142 %struct.aal_state_t = type { %struct.CGPoint, %struct.CGPoint, %struct.CGPoint, i32, float, float, float, float, %struct.CGPoint, %struct.CGPoint, float, float, float, float, i32, i32, i32, i32, float, float, i8*, i32, i32, %struct.aal_edge_pool_t*, %struct.aal_edge_pool_t*, i8*, %struct.aal_callback_t*, i32, %struct.aal_span_t*, %struct.aal_span_t*, %struct.aal_span_t*, %struct.aal_span_pool_t*, i8, float, i8, i32 } 143 %struct.anon = type { %struct.aal_spanarray_t } 144 145 146 147 define fastcc void @test7() { 148 entry: 149 %SB = alloca %struct.aal_spanbucket_t, align 4 ; <%struct.aal_spanbucket_t*> [#uses=2] 150 br i1 false, label %cond_true, label %cond_next79 151 152 cond_true: ; preds = %entry 153 br i1 false, label %cond_next, label %cond_next114.i 154 155 cond_next114.i: ; preds = %cond_true 156 ret void 157 158 cond_next: ; preds = %cond_true 159 %SB19 = bitcast %struct.aal_spanbucket_t* %SB to i8* ; <i8*> [#uses=1] 160 call void @llvm.memcpy.p0i8.p0i8.i32(i8* %SB19, i8* null, i32 12, i32 0, i1 false) 161 br i1 false, label %cond_next34, label %cond_next79 162 163 cond_next34: ; preds = %cond_next 164 %i.2.reload22 = load i32, i32* null ; <i32> [#uses=1] 165 %tmp51 = getelementptr %struct.aal_spanbucket_t, %struct.aal_spanbucket_t* %SB, i32 0, i32 2, i32 0, i32 0, i32 %i.2.reload22, i32 1 166 ; <i16*> [#uses=0] 167 ret void 168 169 cond_next79: ; preds = %cond_next, %entry 170 ret void 171 } 172 173 174 %struct.c37304a__vrec = type { i8, %struct.c37304a__vrec___disc___XVN } 175 %struct.c37304a__vrec___disc___XVN = type { 176 %struct.c37304a__vrec___disc___XVN___O } 177 %struct.c37304a__vrec___disc___XVN___O = type { } 178 179 ; PR3304 180 define void @test8() { 181 entry: 182 %v = alloca %struct.c37304a__vrec 183 %0 = getelementptr %struct.c37304a__vrec, %struct.c37304a__vrec* %v, i32 0, i32 0 184 store i8 8, i8* %0, align 1 185 unreachable 186 } 187 188 189 190 ; rdar://6808691 - ZeroLengthMemSet 191 %0 = type <{ i32, i16, i8, i8, i64, i64, i16, [0 x i16] }> 192 193 define i32 @test9() { 194 entry: 195 %.compoundliteral = alloca %0 196 %tmp228 = getelementptr %0, %0* %.compoundliteral, i32 0, i32 7 197 %tmp229 = bitcast [0 x i16]* %tmp228 to i8* 198 call void @llvm.memset.p0i8.i64(i8* %tmp229, i8 0, i64 0, i32 2, i1 false) 199 unreachable 200 } 201 202 declare void @llvm.memset.i64(i8* nocapture, i8, i64, i32) nounwind 203 204 205 ; PR4146 - i1 handling 206 %wrapper = type { i1 } 207 define void @test10() { 208 entry: 209 %w = alloca %wrapper, align 8 ; <%wrapper*> [#uses=1] 210 %0 = getelementptr %wrapper, %wrapper* %w, i64 0, i32 0 ; <i1*> 211 store i1 true, i1* %0 212 ret void 213 } 214 215 216 %struct.singlebool = type <{ i8 }> 217 ; PR4286 218 define zeroext i8 @test11() nounwind { 219 entry: 220 %a = alloca %struct.singlebool, align 1 ; <%struct.singlebool*> [#uses=2] 221 %storetmp.i = bitcast %struct.singlebool* %a to i1* ; <i1*> [#uses=1] 222 store i1 true, i1* %storetmp.i 223 %tmp = getelementptr %struct.singlebool, %struct.singlebool* %a, i64 0, i32 0 ; <i8*> [#uses=1] 224 %tmp1 = load i8, i8* %tmp ; <i8> [#uses=1] 225 ret i8 %tmp1 226 } 227 228 229 %struct.Item = type { [4 x i16], %struct.rule* } 230 %struct.rule = type { [4 x i16], i32, i32, i32, %struct.nonterminal*, %struct.pattern*, i8 } 231 %struct.nonterminal = type { i8*, i32, i32, i32, %struct.plankMap*, %struct.rule* } 232 %struct.plankMap = type { %struct.list*, i32, %struct.stateMap* } 233 %struct.list = type { i8*, %struct.list* } 234 %struct.stateMap = type { i8*, %struct.plank*, i32, i16* } 235 %struct.plank = type { i8*, %struct.list*, i32 } 236 %struct.pattern = type { %struct.nonterminal*, %struct.operator*, [2 x %struct.nonterminal*] } 237 %struct.operator = type { i8*, i8, i32, i32, i32, i32, %struct.table* } 238 %struct.table = type { %struct.operator*, %struct.list*, i16*, [2 x %struct.dimension*], %struct.item_set** } 239 %struct.dimension = type { i16*, %struct.Index_Map, %struct.mapping*, i32, %struct.plankMap* } 240 %struct.Index_Map = type { i32, %struct.item_set** } 241 %struct.item_set = type { i32, i32, %struct.operator*, [2 x %struct.item_set*], %struct.item_set*, i16*, %struct.Item*, %struct.Item* } 242 %struct.mapping = type { %struct.list**, i32, i32, i32, %struct.item_set** } 243 244 ; VLAs. 245 define void @test12() { 246 bb4.i: 247 %malloccall = tail call i8* @malloc(i32 0) 248 %0 = bitcast i8* %malloccall to [0 x %struct.Item]* 249 %.sub.i.c.i = getelementptr [0 x %struct.Item], [0 x %struct.Item]* %0, i32 0, i32 0 ; <%struct.Item*> [#uses=0] 250 unreachable 251 } 252 declare noalias i8* @malloc(i32) 253 254 ; PR8680 255 define void @test13() nounwind { 256 entry: 257 %memtmp = alloca i32, align 4 258 %0 = bitcast i32* %memtmp to void ()* 259 call void %0() nounwind 260 ret void 261 } 262 263 ; rdar://11861001 - The dynamic GEP here was incorrectly making all accesses 264 ; to the alloca think they were also dynamic. Inserts and extracts created to 265 ; access the vector were all being based from the dynamic access, even in BBs 266 ; not dominated by the GEP. 267 define fastcc void @test() optsize inlinehint ssp align 2 { 268 entry: 269 %alloc.0.0 = alloca <4 x float>, align 16 270 %bitcast = bitcast <4 x float>* %alloc.0.0 to [4 x float]* 271 %idx3 = getelementptr inbounds [4 x float], [4 x float]* %bitcast, i32 0, i32 3 272 store float 0.000000e+00, float* %idx3, align 4 273 br label %for.body10 274 275 for.body10: ; preds = %for.body10, %entry 276 %loopidx = phi i32 [ 0, %entry ], [ undef, %for.body10 ] 277 %unusedidx = getelementptr inbounds <4 x float>, <4 x float>* %alloc.0.0, i32 0, i32 %loopidx 278 br i1 undef, label %for.end, label %for.body10 279 280 for.end: ; preds = %for.body10 281 store <4 x float> <float -1.000000e+00, float -1.000000e+00, float -1.000000e+00, float 0.000000e+00>, <4 x float>* %alloc.0.0, align 16 282 ret void 283 } 284 285 declare void @llvm.memcpy.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i32, i1) nounwind 286 declare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i32, i1) nounwind 287