| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --check-globals none --version 5 |
| ; RUN: opt -p loop-vectorize -mtriple riscv64 -mattr=+v < %s -S | FileCheck %s |
| |
| ; Make sure we don't duplicate the safe divisor cost in the VPlan cost model. |
| |
| define void @pr154103(ptr noalias %a, ptr noalias %b, ptr noalias %c, ptr noalias %d) { |
| ; CHECK-LABEL: define void @pr154103( |
| ; CHECK-SAME: ptr noalias [[A:%.*]], ptr noalias [[B:%.*]], ptr noalias [[C:%.*]], ptr noalias [[D:%.*]]) #[[ATTR0:[0-9]+]] { |
| ; CHECK-NEXT: [[ENTRY:.*]]: |
| ; CHECK-NEXT: br label %[[LOOP:.*]] |
| ; CHECK: [[LOOP]]: |
| ; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 1, %[[ENTRY]] ], [ [[IV_NEXT:%.*]], %[[LATCH:.*]] ] |
| ; CHECK-NEXT: [[GEP:%.*]] = getelementptr i8, ptr [[A]], i64 [[IV]] |
| ; CHECK-NEXT: [[X:%.*]] = load i8, ptr [[GEP]], align 1 |
| ; CHECK-NEXT: [[CONV:%.*]] = zext i8 [[X]] to i64 |
| ; CHECK-NEXT: [[DIV:%.*]] = sdiv i64 0, [[CONV]] |
| ; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i64 [[DIV]], 0 |
| ; CHECK-NEXT: br i1 [[CMP]], label %[[THEN:.*]], label %[[LATCH]] |
| ; CHECK: [[THEN]]: |
| ; CHECK-NEXT: [[Y:%.*]] = load i8, ptr [[B]], align 1 |
| ; CHECK-NEXT: [[ZEXT:%.*]] = zext i8 [[Y]] to i64 |
| ; CHECK-NEXT: [[NOT:%.*]] = xor i64 [[ZEXT]], 0 |
| ; CHECK-NEXT: br label %[[LATCH]] |
| ; CHECK: [[LATCH]]: |
| ; CHECK-NEXT: [[COND:%.*]] = phi i64 [ [[NOT]], %[[THEN]] ], [ 0, %[[LOOP]] ] |
| ; CHECK-NEXT: [[TRUNC:%.*]] = trunc i64 [[COND]] to i16 |
| ; CHECK-NEXT: store i16 [[TRUNC]], ptr [[C]], align 2 |
| ; CHECK-NEXT: store i32 0, ptr [[D]], align 4 |
| ; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 7 |
| ; CHECK-NEXT: [[DONE:%.*]] = icmp eq i64 [[IV]], 0 |
| ; CHECK-NEXT: br i1 [[DONE]], label %[[EXIT:.*]], label %[[LOOP]] |
| ; CHECK: [[EXIT]]: |
| ; CHECK-NEXT: ret void |
| ; |
| entry: |
| br label %loop |
| |
| loop: |
| %iv = phi i64 [ 1, %entry ], [ %iv.next, %latch ] |
| %gep = getelementptr i8, ptr %a, i64 %iv |
| %x = load i8, ptr %gep, align 1 |
| %conv = zext i8 %x to i64 |
| %div = sdiv i64 0, %conv |
| %cmp = icmp sgt i64 %div, 0 |
| br i1 %cmp, label %then, label %latch |
| |
| then: |
| %y = load i8, ptr %b |
| %zext = zext i8 %y to i64 |
| %not = xor i64 %zext, 0 |
| br label %latch |
| |
| latch: |
| %cond = phi i64 [ %not, %then ], [ 0, %loop ] |
| %trunc = trunc i64 %cond to i16 |
| store i16 %trunc, ptr %c |
| store i32 0, ptr %d |
| %iv.next = add i64 %iv, 7 |
| %done = icmp eq i64 %iv, 0 |
| br i1 %done, label %exit, label %loop |
| |
| exit: |
| ret void |
| } |