Skip to content

Commit b85c8c4

Browse files
committed
LiveIntervals: Remove assertion
This testcase is invalid, and caught by the verifier. For the verifier to catch it, the live interval computation needs to complete. Remove the assert so the verifier catches this, which is less confusing. In this testcase there is an undefined use of a subregister, and lanes which aren't used or defined. An equivalent testcase with the super-register shrunk to have no untouched lanes already hit this verifier error. llvm-svn: 371792
1 parent 8382ce5 commit b85c8c4

File tree

2 files changed

+30
-1
lines changed

2 files changed

+30
-1
lines changed

llvm/lib/CodeGen/LiveInterval.cpp

+2-1
Original file line numberDiff line numberDiff line change
@@ -917,7 +917,8 @@ static void stripValuesNotDefiningMask(unsigned Reg, LiveInterval::SubRange &SR,
917917
for (VNInfo *VNI : ToBeRemoved)
918918
SR.removeValNo(VNI);
919919

920-
assert(!SR.empty() && "At least one value should be defined by this mask");
920+
// If the subrange is empty at this point, the MIR is invalid. Do not assert
921+
// and let the verifier catch this case.
921922
}
922923

923924
void LiveInterval::refineSubRanges(
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
# RUN: not llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx906 -verify-machineinstrs -run-pass=machine-scheduler -verify-misched -o /dev/null %s 2>&1 | FileCheck %s
2+
3+
# CHECK: *** Bad machine code: No live subrange at use ***
4+
# CHECK-NEXT: - function: at_least_one_value_should_be_defined_by_this_mask
5+
# CHECK-NEXT: - basic block: %bb.0
6+
# CHECK-NEXT: - instruction: 48B dead undef %2.sub0:vreg_128 = COPY %0.sub0:vreg_128
7+
# CHECK-NEXT: - operand 1: %0.sub0:vreg_128
8+
# CHECK-NEXT: - interval: %0 [16r,48r:0) 0@16r L00000002 [16r,32r:0) 0@16r weight:0.000000e+00
9+
10+
# This used to assert with: !SR.empty() && "At least one value should be defined by this mask"
11+
12+
# This MIR is invalid and should be caught by the verifier. %0.sub0 is
13+
# used, but not defined. There are also lanes in %0 that are not used
14+
# or defined anywhere. Previously there was an assertion in the
15+
# LiveInterval computation, which was more confusing. The invalid
16+
# LiveRange should be produced and the verifier will catch it.
17+
18+
---
19+
name: at_least_one_value_should_be_defined_by_this_mask
20+
tracksRegLiveness: true
21+
body: |
22+
bb.0:
23+
24+
undef %0.sub1:vreg_128 = V_MOV_B32_e32 0, implicit $exec
25+
%1:vreg_128 = COPY %0
26+
undef %2.sub0:vreg_128 = COPY %0.sub0
27+
28+
...

0 commit comments

Comments
 (0)