|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 5 |
| 2 | +; RUN: opt < %s -disable-output "-passes=print<da>" -aa-pipeline=basic-aa 2>&1 \ |
| 3 | +; RUN: | FileCheck %s |
| 4 | + |
| 5 | +; Check that the testcase does not crash the compiler. |
| 6 | +; See https://github.com/llvm/llvm-project/issues/51512 for details. |
| 7 | + |
| 8 | +define void @foo() { |
| 9 | +; CHECK-LABEL: 'foo' |
| 10 | +; CHECK-NEXT: Src: store i32 42, ptr %getelementptr, align 1 --> Dst: store i32 42, ptr %getelementptr, align 1 |
| 11 | +; CHECK-NEXT: da analyze - consistent output [0 S]! |
| 12 | +; CHECK-NEXT: Src: store i32 42, ptr %getelementptr, align 1 --> Dst: store i32 0, ptr %getelementptr5, align 1 |
| 13 | +; CHECK-NEXT: da analyze - output [0 *|<]! |
| 14 | +; CHECK-NEXT: Src: store i32 0, ptr %getelementptr5, align 1 --> Dst: store i32 0, ptr %getelementptr5, align 1 |
| 15 | +; CHECK-NEXT: da analyze - none! |
| 16 | +; |
| 17 | +bb: |
| 18 | + %alloca = alloca [2 x [5 x i32]], align 1 |
| 19 | + br label %outerloop.header |
| 20 | + |
| 21 | +outerloop.header: ; preds = %outerloop.latch, %bb |
| 22 | + %iv.outerloop = phi i32 [ 0, %bb ], [ %iv.outerloop.next, %outerloop.latch ] |
| 23 | + %trunc = trunc i32 %iv.outerloop to i16 |
| 24 | + %add = add i16 %trunc, 3 |
| 25 | + %getelementptr = getelementptr inbounds [2 x [5 x i32]], ptr %alloca, i16 0, i16 %trunc, i16 %add |
| 26 | + br label %innerloop |
| 27 | + |
| 28 | +innerloop: ; preds = %innerloop, %outerloop.header |
| 29 | + %iv.innerloop = phi i32 [ 0, %outerloop.header ], [ %iv.innerloop.next, %innerloop ] |
| 30 | + store i32 42, ptr %getelementptr, align 1 |
| 31 | + %trunc4 = trunc i32 %iv.innerloop to i16 |
| 32 | + %getelementptr5 = getelementptr inbounds [2 x [5 x i32]], ptr %alloca, i16 0, i16 %trunc4, i16 %add |
| 33 | + store i32 0, ptr %getelementptr5, align 1 |
| 34 | + %iv.innerloop.next = add nuw nsw i32 %iv.innerloop, 1 |
| 35 | + br i1 false, label %innerloop, label %outerloop.latch |
| 36 | + |
| 37 | +outerloop.latch: ; preds = %innerloop |
| 38 | + %iv.outerloop.next = add nuw nsw i32 %iv.outerloop, 1 |
| 39 | + %icmp = icmp eq i32 %iv.outerloop, 0 |
| 40 | + br i1 %icmp, label %outerloop.header, label %bb9 |
| 41 | + |
| 42 | +bb9: ; preds = %outerloop.latch |
| 43 | + ret void |
| 44 | +} |
0 commit comments