1; RUN: llc -march=hexagon -mcpu=hexagonv4 -O3 < %s | FileCheck %s 2 3 4; CHECK: test_pos1_ir_ne 5; CHECK: loop0 6; a < b 7define void @test_pos1_ir_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 8entry: 9 %cmp3 = icmp slt i32 32623, %b 10 br i1 %cmp3, label %for.body.lr.ph, label %for.end 11 12for.body.lr.ph: ; preds = %entry 13 br label %for.body 14 15for.body: ; preds = %for.body.lr.ph, %for.body 16 %i.04 = phi i32 [ 32623, %for.body.lr.ph ], [ %inc, %for.body ] 17 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 18 %0 = load i8, i8* %arrayidx, align 1 19 %conv = zext i8 %0 to i32 20 %add = add nsw i32 %conv, 1 21 %conv1 = trunc i32 %add to i8 22 store i8 %conv1, i8* %arrayidx, align 1 23 %inc = add nsw i32 %i.04, 1 24 %cmp = icmp ne i32 %inc, %b 25 br i1 %cmp, label %for.body, label %for.end 26 27for.end: ; preds = %for.body, %entry 28 ret void 29} 30 31 32 33; CHECK: test_pos2_ir_ne 34; CHECK: loop0 35; a < b 36define void @test_pos2_ir_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 37entry: 38 %cmp3 = icmp slt i32 29554, %b 39 br i1 %cmp3, label %for.body.lr.ph, label %for.end 40 41for.body.lr.ph: ; preds = %entry 42 br label %for.body 43 44for.body: ; preds = %for.body.lr.ph, %for.body 45 %i.04 = phi i32 [ 29554, %for.body.lr.ph ], [ %inc, %for.body ] 46 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 47 %0 = load i8, i8* %arrayidx, align 1 48 %conv = zext i8 %0 to i32 49 %add = add nsw i32 %conv, 1 50 %conv1 = trunc i32 %add to i8 51 store i8 %conv1, i8* %arrayidx, align 1 52 %inc = add nsw i32 %i.04, 2 53 %cmp = icmp ne i32 %inc, %b 54 br i1 %cmp, label %for.body, label %for.end 55 56for.end: ; preds = %for.body, %entry 57 ret void 58} 59 60 61 62; CHECK: test_pos4_ir_ne 63; CHECK: loop0 64; a < b 65define void @test_pos4_ir_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 66entry: 67 %cmp3 = icmp slt i32 15692, %b 68 br i1 %cmp3, label %for.body.lr.ph, label %for.end 69 70for.body.lr.ph: ; preds = %entry 71 br label %for.body 72 73for.body: ; preds = %for.body.lr.ph, %for.body 74 %i.04 = phi i32 [ 15692, %for.body.lr.ph ], [ %inc, %for.body ] 75 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 76 %0 = load i8, i8* %arrayidx, align 1 77 %conv = zext i8 %0 to i32 78 %add = add nsw i32 %conv, 1 79 %conv1 = trunc i32 %add to i8 80 store i8 %conv1, i8* %arrayidx, align 1 81 %inc = add nsw i32 %i.04, 4 82 %cmp = icmp ne i32 %inc, %b 83 br i1 %cmp, label %for.body, label %for.end 84 85for.end: ; preds = %for.body, %entry 86 ret void 87} 88 89 90 91; CHECK: test_pos8_ir_ne 92; CHECK: loop0 93; a < b 94define void @test_pos8_ir_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 95entry: 96 %cmp3 = icmp slt i32 10449, %b 97 br i1 %cmp3, label %for.body.lr.ph, label %for.end 98 99for.body.lr.ph: ; preds = %entry 100 br label %for.body 101 102for.body: ; preds = %for.body.lr.ph, %for.body 103 %i.04 = phi i32 [ 10449, %for.body.lr.ph ], [ %inc, %for.body ] 104 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 105 %0 = load i8, i8* %arrayidx, align 1 106 %conv = zext i8 %0 to i32 107 %add = add nsw i32 %conv, 1 108 %conv1 = trunc i32 %add to i8 109 store i8 %conv1, i8* %arrayidx, align 1 110 %inc = add nsw i32 %i.04, 8 111 %cmp = icmp ne i32 %inc, %b 112 br i1 %cmp, label %for.body, label %for.end 113 114for.end: ; preds = %for.body, %entry 115 ret void 116} 117 118 119 120; CHECK: test_pos16_ir_ne 121; CHECK: loop0 122; a < b 123define void @test_pos16_ir_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 124entry: 125 %cmp3 = icmp slt i32 32087, %b 126 br i1 %cmp3, label %for.body.lr.ph, label %for.end 127 128for.body.lr.ph: ; preds = %entry 129 br label %for.body 130 131for.body: ; preds = %for.body.lr.ph, %for.body 132 %i.04 = phi i32 [ 32087, %for.body.lr.ph ], [ %inc, %for.body ] 133 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 134 %0 = load i8, i8* %arrayidx, align 1 135 %conv = zext i8 %0 to i32 136 %add = add nsw i32 %conv, 1 137 %conv1 = trunc i32 %add to i8 138 store i8 %conv1, i8* %arrayidx, align 1 139 %inc = add nsw i32 %i.04, 16 140 %cmp = icmp ne i32 %inc, %b 141 br i1 %cmp, label %for.body, label %for.end 142 143for.end: ; preds = %for.body, %entry 144 ret void 145} 146 147 148 149; CHECK: test_pos1_ri_ne 150; CHECK: loop0 151; a < b 152define void @test_pos1_ri_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 153entry: 154 %cmp3 = icmp slt i32 %a, 3472 155 br i1 %cmp3, label %for.body.lr.ph, label %for.end 156 157for.body.lr.ph: ; preds = %entry 158 br label %for.body 159 160for.body: ; preds = %for.body.lr.ph, %for.body 161 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 162 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 163 %0 = load i8, i8* %arrayidx, align 1 164 %conv = zext i8 %0 to i32 165 %add = add nsw i32 %conv, 1 166 %conv1 = trunc i32 %add to i8 167 store i8 %conv1, i8* %arrayidx, align 1 168 %inc = add nsw i32 %i.04, 1 169 %cmp = icmp ne i32 %inc, 3472 170 br i1 %cmp, label %for.body, label %for.end 171 172for.end: ; preds = %for.body, %entry 173 ret void 174} 175 176 177 178; CHECK: test_pos2_ri_ne 179; CHECK: loop0 180; a < b 181define void @test_pos2_ri_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 182entry: 183 %cmp3 = icmp slt i32 %a, 8730 184 br i1 %cmp3, label %for.body.lr.ph, label %for.end 185 186for.body.lr.ph: ; preds = %entry 187 br label %for.body 188 189for.body: ; preds = %for.body.lr.ph, %for.body 190 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 191 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 192 %0 = load i8, i8* %arrayidx, align 1 193 %conv = zext i8 %0 to i32 194 %add = add nsw i32 %conv, 1 195 %conv1 = trunc i32 %add to i8 196 store i8 %conv1, i8* %arrayidx, align 1 197 %inc = add nsw i32 %i.04, 2 198 %cmp = icmp ne i32 %inc, 8730 199 br i1 %cmp, label %for.body, label %for.end 200 201for.end: ; preds = %for.body, %entry 202 ret void 203} 204 205 206 207; CHECK: test_pos4_ri_ne 208; CHECK: loop0 209; a < b 210define void @test_pos4_ri_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 211entry: 212 %cmp3 = icmp slt i32 %a, 1493 213 br i1 %cmp3, label %for.body.lr.ph, label %for.end 214 215for.body.lr.ph: ; preds = %entry 216 br label %for.body 217 218for.body: ; preds = %for.body.lr.ph, %for.body 219 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 220 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 221 %0 = load i8, i8* %arrayidx, align 1 222 %conv = zext i8 %0 to i32 223 %add = add nsw i32 %conv, 1 224 %conv1 = trunc i32 %add to i8 225 store i8 %conv1, i8* %arrayidx, align 1 226 %inc = add nsw i32 %i.04, 4 227 %cmp = icmp ne i32 %inc, 1493 228 br i1 %cmp, label %for.body, label %for.end 229 230for.end: ; preds = %for.body, %entry 231 ret void 232} 233 234 235 236; CHECK: test_pos8_ri_ne 237; CHECK: loop0 238; a < b 239define void @test_pos8_ri_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 240entry: 241 %cmp3 = icmp slt i32 %a, 1706 242 br i1 %cmp3, label %for.body.lr.ph, label %for.end 243 244for.body.lr.ph: ; preds = %entry 245 br label %for.body 246 247for.body: ; preds = %for.body.lr.ph, %for.body 248 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 249 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 250 %0 = load i8, i8* %arrayidx, align 1 251 %conv = zext i8 %0 to i32 252 %add = add nsw i32 %conv, 1 253 %conv1 = trunc i32 %add to i8 254 store i8 %conv1, i8* %arrayidx, align 1 255 %inc = add nsw i32 %i.04, 8 256 %cmp = icmp ne i32 %inc, 1706 257 br i1 %cmp, label %for.body, label %for.end 258 259for.end: ; preds = %for.body, %entry 260 ret void 261} 262 263 264 265; CHECK: test_pos16_ri_ne 266; CHECK: loop0 267; a < b 268define void @test_pos16_ri_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 269entry: 270 %cmp3 = icmp slt i32 %a, 1886 271 br i1 %cmp3, label %for.body.lr.ph, label %for.end 272 273for.body.lr.ph: ; preds = %entry 274 br label %for.body 275 276for.body: ; preds = %for.body.lr.ph, %for.body 277 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 278 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 279 %0 = load i8, i8* %arrayidx, align 1 280 %conv = zext i8 %0 to i32 281 %add = add nsw i32 %conv, 1 282 %conv1 = trunc i32 %add to i8 283 store i8 %conv1, i8* %arrayidx, align 1 284 %inc = add nsw i32 %i.04, 16 285 %cmp = icmp ne i32 %inc, 1886 286 br i1 %cmp, label %for.body, label %for.end 287 288for.end: ; preds = %for.body, %entry 289 ret void 290} 291 292 293 294; CHECK: test_pos1_rr_ne 295; CHECK: loop0 296; a < b 297define void @test_pos1_rr_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 298entry: 299 %cmp3 = icmp slt i32 %a, %b 300 br i1 %cmp3, label %for.body.lr.ph, label %for.end 301 302for.body.lr.ph: ; preds = %entry 303 br label %for.body 304 305for.body: ; preds = %for.body.lr.ph, %for.body 306 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 307 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 308 %0 = load i8, i8* %arrayidx, align 1 309 %conv = zext i8 %0 to i32 310 %add = add nsw i32 %conv, 1 311 %conv1 = trunc i32 %add to i8 312 store i8 %conv1, i8* %arrayidx, align 1 313 %inc = add nsw i32 %i.04, 1 314 %cmp = icmp ne i32 %inc, %b 315 br i1 %cmp, label %for.body, label %for.end 316 317for.end: ; preds = %for.body, %entry 318 ret void 319} 320 321 322 323; CHECK: test_pos2_rr_ne 324; CHECK: loop0 325; a < b 326define void @test_pos2_rr_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 327entry: 328 %cmp3 = icmp slt i32 %a, %b 329 br i1 %cmp3, label %for.body.lr.ph, label %for.end 330 331for.body.lr.ph: ; preds = %entry 332 br label %for.body 333 334for.body: ; preds = %for.body.lr.ph, %for.body 335 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 336 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 337 %0 = load i8, i8* %arrayidx, align 1 338 %conv = zext i8 %0 to i32 339 %add = add nsw i32 %conv, 1 340 %conv1 = trunc i32 %add to i8 341 store i8 %conv1, i8* %arrayidx, align 1 342 %inc = add nsw i32 %i.04, 2 343 %cmp = icmp ne i32 %inc, %b 344 br i1 %cmp, label %for.body, label %for.end 345 346for.end: ; preds = %for.body, %entry 347 ret void 348} 349 350 351 352; CHECK: test_pos4_rr_ne 353; CHECK: loop0 354; a < b 355define void @test_pos4_rr_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 356entry: 357 %cmp3 = icmp slt i32 %a, %b 358 br i1 %cmp3, label %for.body.lr.ph, label %for.end 359 360for.body.lr.ph: ; preds = %entry 361 br label %for.body 362 363for.body: ; preds = %for.body.lr.ph, %for.body 364 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 365 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 366 %0 = load i8, i8* %arrayidx, align 1 367 %conv = zext i8 %0 to i32 368 %add = add nsw i32 %conv, 1 369 %conv1 = trunc i32 %add to i8 370 store i8 %conv1, i8* %arrayidx, align 1 371 %inc = add nsw i32 %i.04, 4 372 %cmp = icmp ne i32 %inc, %b 373 br i1 %cmp, label %for.body, label %for.end 374 375for.end: ; preds = %for.body, %entry 376 ret void 377} 378 379 380 381; CHECK: test_pos8_rr_ne 382; CHECK: loop0 383; a < b 384define void @test_pos8_rr_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 385entry: 386 %cmp3 = icmp slt i32 %a, %b 387 br i1 %cmp3, label %for.body.lr.ph, label %for.end 388 389for.body.lr.ph: ; preds = %entry 390 br label %for.body 391 392for.body: ; preds = %for.body.lr.ph, %for.body 393 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 394 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 395 %0 = load i8, i8* %arrayidx, align 1 396 %conv = zext i8 %0 to i32 397 %add = add nsw i32 %conv, 1 398 %conv1 = trunc i32 %add to i8 399 store i8 %conv1, i8* %arrayidx, align 1 400 %inc = add nsw i32 %i.04, 8 401 %cmp = icmp ne i32 %inc, %b 402 br i1 %cmp, label %for.body, label %for.end 403 404for.end: ; preds = %for.body, %entry 405 ret void 406} 407 408 409 410; CHECK: test_pos16_rr_ne 411; CHECK: loop0 412; a < b 413define void @test_pos16_rr_ne(i8* nocapture %p, i32 %a, i32 %b) nounwind { 414entry: 415 %cmp3 = icmp slt i32 %a, %b 416 br i1 %cmp3, label %for.body.lr.ph, label %for.end 417 418for.body.lr.ph: ; preds = %entry 419 br label %for.body 420 421for.body: ; preds = %for.body.lr.ph, %for.body 422 %i.04 = phi i32 [ %a, %for.body.lr.ph ], [ %inc, %for.body ] 423 %arrayidx = getelementptr inbounds i8, i8* %p, i32 %i.04 424 %0 = load i8, i8* %arrayidx, align 1 425 %conv = zext i8 %0 to i32 426 %add = add nsw i32 %conv, 1 427 %conv1 = trunc i32 %add to i8 428 store i8 %conv1, i8* %arrayidx, align 1 429 %inc = add nsw i32 %i.04, 16 430 %cmp = icmp ne i32 %inc, %b 431 br i1 %cmp, label %for.body, label %for.end 432 433for.end: ; preds = %for.body, %entry 434 ret void 435} 436 437 438 439