|
7 | 7 | ;============================ end_copyright_notice ============================= |
8 | 8 |
|
9 | 9 | ; REQUIRES: regkeys |
10 | | -; RUN: igc_opt --regkey=EnableGEPLSRMulExpr=1 --regkey=EnableGEPLSRAnyIntBitWidth=0 -debugify --igc-gep-loop-strength-reduction -check-debugify -S < %s 2>&1 | FileCheck %s --check-prefix=CHECK-BLOCK-ILLEGAL |
11 | | -; RUN: igc_opt --regkey=EnableGEPLSRMulExpr=1 --regkey=EnableGEPLSRAnyIntBitWidth=1 -debugify --igc-gep-loop-strength-reduction -check-debugify -S < %s 2>&1 | FileCheck %s --check-prefix=CHECK-ALLOW-ILLEGAL |
| 10 | +; RUN: igc_opt --regkey=EnableGEPLSRMulExpr=1 --regkey=EnableGEPLSRAnyIntBitWidth=0 -debugify --igc-gep-loop-strength-reduction -check-debugify -S < %s 2>&1 | FileCheck %s --check-prefixes=CHECK,CHECK-BLOCK-ILLEGAL |
| 11 | +; RUN: igc_opt --regkey=EnableGEPLSRMulExpr=1 --regkey=EnableGEPLSRAnyIntBitWidth=1 -debugify --igc-gep-loop-strength-reduction -check-debugify -S < %s 2>&1 | FileCheck %s --check-prefixes=CHECK,CHECK-ALLOW-ILLEGAL |
12 | 12 | ; |
13 | 13 | ; Test for illegal types in SCEV expressions. |
14 | 14 |
|
@@ -75,40 +75,29 @@ for.end: ; preds = %for.cond.for.end_cr |
75 | 75 |
|
76 | 76 | ; Instruction "and" creates SCEV with i7 type: |
77 | 77 | ; (zext i7 {(trunc i64 %b to i7),+,(trunc i64 %a to i7)}<%for.body> to i64) |
| 78 | +; Types <= i8 are correctly legalized. |
78 | 79 | define spir_kernel void @test_and(i32 addrspace(1)* %p, i64 %n, i64 %a, i64 %b) { |
79 | 80 | entry: |
80 | 81 | %cmp1 = icmp slt i64 0, %n |
81 | 82 | br i1 %cmp1, label %for.body.lr.ph, label %for.end |
82 | 83 |
|
83 | | -; CHECK-BLOCK-ILLEGAL-LABEL: for.body.lr.ph: |
84 | | -; CHECK-BLOCK-ILLEGAL: br label %for.body |
85 | | -; CHECK-ALLOW-ILLEGAL-LABEL: for.body.lr.ph: |
86 | | -; CHECK-ALLOW-ILLEGAL: [[TRUNC1:%.*]] = trunc i64 %b to i7 |
87 | | -; CHECK-ALLOW-ILLEGAL: [[INDEX:%.*]] = zext i7 [[TRUNC1]] to i64 |
88 | | -; CHECK-ALLOW-ILLEGAL: [[GEP_PHI1:%.*]] = getelementptr i32, i32 addrspace(1)* %p, i64 [[INDEX]] |
89 | | -; CHECK-ALLOW-ILLEGAL: [[TRUNC2:%.*]] = trunc i64 %a to i7 |
90 | | -; CHECK-ALLOW-ILLEGAL: br label %for.body |
| 84 | +; CHECK-LABEL: for.body.lr.ph: |
| 85 | +; CHECK: [[TRUNC1:%.*]] = trunc i64 %b to i7 |
| 86 | +; CHECK: [[INDEX:%.*]] = zext i7 [[TRUNC1]] to i64 |
| 87 | +; CHECK: [[GEP_PHI1:%.*]] = getelementptr i32, i32 addrspace(1)* %p, i64 [[INDEX]] |
| 88 | +; CHECK: [[TRUNC2:%.*]] = trunc i64 %a to i7 |
| 89 | +; CHECK: br label %for.body |
91 | 90 | for.body.lr.ph: ; preds = %entry |
92 | 91 | br label %for.body |
93 | 92 |
|
94 | | -; CHECK-BLOCK-ILLEGAL-LABEL: for.body: |
95 | | -; CHECK-BLOCK-ILLEGAL: %i.02 = phi i64 [ 0, %for.body.lr.ph ], [ %inc, %for.body ] |
96 | | -; CHECK-BLOCK-ILLEGAL: %0 = mul i64 %i.02, %a |
97 | | -; CHECK-BLOCK-ILLEGAL: %1 = add i64 %0, %b |
98 | | -; CHECK-BLOCK-ILLEGAL: %idxprom = and i64 %1, 127 |
99 | | -; CHECK-BLOCK-ILLEGAL: %arrayidx = getelementptr inbounds i32, i32 addrspace(1)* %p, i64 %idxprom |
100 | | -; CHECK-BLOCK-ILLEGAL: store i32 39, i32 addrspace(1)* %arrayidx, align 4 |
101 | | -; CHECK-BLOCK-ILLEGAL: %inc = add nuw nsw i64 %i.02, 1 |
102 | | -; CHECK-BLOCK-ILLEGAL: %cmp = icmp slt i64 %inc, %n |
103 | | -; CHECK-BLOCK-ILLEGAL: br i1 %cmp, label %for.body, label %for.cond.for.end_crit_edge |
104 | | -; CHECK-ALLOW-ILLEGAL-LABEL: for.body: |
105 | | -; CHECK-ALLOW-ILLEGAL: [[GEP:%.*]] = phi i32 addrspace(1)* [ [[GEP_PHI1]], %for.body.lr.ph ], [ [[GEP_PHI2:%.*]], %for.body ] |
106 | | -; CHECK-ALLOW-ILLEGAL: %i.02 = phi i64 [ 0, %for.body.lr.ph ], [ %inc, %for.body ] |
107 | | -; CHECK-ALLOW-ILLEGAL: store i32 39, i32 addrspace(1)* [[GEP]], align 4 |
108 | | -; CHECK-ALLOW-ILLEGAL: %inc = add nuw nsw i64 %i.02, 1 |
109 | | -; CHECK-ALLOW-ILLEGAL: %cmp = icmp slt i64 %inc, %n |
110 | | -; CHECK-ALLOW-ILLEGAL: [[GEP_PHI2]] = getelementptr i32, i32 addrspace(1)* [[GEP]], i7 [[TRUNC2]] |
111 | | -; CHECK-ALLOW-ILLEGAL: br i1 %cmp, label %for.body, label %for.cond.for.end_crit_edge |
| 93 | +; CHECK-LABEL: for.body: |
| 94 | +; CHECK: [[GEP:%.*]] = phi i32 addrspace(1)* [ [[GEP_PHI1]], %for.body.lr.ph ], [ [[GEP_PHI2:%.*]], %for.body ] |
| 95 | +; CHECK: %i.02 = phi i64 [ 0, %for.body.lr.ph ], [ %inc, %for.body ] |
| 96 | +; CHECK: store i32 39, i32 addrspace(1)* [[GEP]], align 4 |
| 97 | +; CHECK: %inc = add nuw nsw i64 %i.02, 1 |
| 98 | +; CHECK: %cmp = icmp slt i64 %inc, %n |
| 99 | +; CHECK: [[GEP_PHI2]] = getelementptr i32, i32 addrspace(1)* [[GEP]], i7 [[TRUNC2]] |
| 100 | +; CHECK: br i1 %cmp, label %for.body, label %for.cond.for.end_crit_edge |
112 | 101 | for.body: ; preds = %for.body.lr.ph, %for.body |
113 | 102 | %i.02 = phi i64 [ 0, %for.body.lr.ph ], [ %inc, %for.body ] |
114 | 103 | %0 = mul i64 %i.02, %a |
|
0 commit comments