@@ -31,16 +31,12 @@ define i16 @samePatternTwice(i64 %x, i64 %y) {
31
31
; CHECK-LABEL: @samePatternTwice(
32
32
; CHECK-NEXT: entry:
33
33
; CHECK-NEXT: [[CMP_NOT:%.*]] = icmp eq i64 [[Y:%.*]], 0
34
- ; CHECK-NEXT: br i1 [[CMP_NOT]], label [[LAND_END:%.*]], label [[LAND_RHS:%.*]]
35
- ; CHECK: land.rhs:
36
34
; CHECK-NEXT: [[MUL:%.*]] = tail call { i64, i1 } @llvm.umul.with.overflow.i64(i64 [[Y]], i64 [[X:%.*]])
37
35
; CHECK-NEXT: [[MUL_OV:%.*]] = extractvalue { i64, i1 } [[MUL]], 1
38
36
; CHECK-NEXT: [[MUL2:%.*]] = tail call { i64, i1 } @llvm.umul.with.overflow.i64(i64 [[Y]], i64 [[X]])
39
- ; CHECK-NEXT: [[MUL_OV2:%.*]] = extractvalue { i64, i1 } [[MUL]], 1
40
- ; CHECK-NEXT: br label [[LAND_END]]
41
- ; CHECK: land.end:
42
- ; CHECK-NEXT: [[TMP0:%.*]] = phi i1 [ false, [[ENTRY:%.*]] ], [ [[MUL_OV]], [[LAND_RHS]] ]
43
- ; CHECK-NEXT: [[TMP1:%.*]] = phi i1 [ false, [[ENTRY]] ], [ [[MUL_OV2]], [[LAND_RHS]] ]
37
+ ; CHECK-NEXT: [[MUL_OV2:%.*]] = extractvalue { i64, i1 } [[MUL2]], 1
38
+ ; CHECK-NEXT: [[TMP0:%.*]] = select i1 [[CMP_NOT]], i1 false, i1 [[MUL_OV]]
39
+ ; CHECK-NEXT: [[TMP1:%.*]] = select i1 [[CMP_NOT]], i1 false, i1 [[MUL_OV2]]
44
40
; CHECK-NEXT: [[CONV:%.*]] = zext i1 [[TMP0]] to i16
45
41
; CHECK-NEXT: [[CONV2:%.*]] = zext i1 [[TMP1]] to i16
46
42
; CHECK-NEXT: [[TORET:%.*]] = add nsw i16 [[CONV]], [[CONV2]]
@@ -54,7 +50,7 @@ land.rhs: ; preds = %entry
54
50
%mul = tail call { i64 , i1 } @llvm.umul.with.overflow.i64 (i64 %y , i64 %x )
55
51
%mul.ov = extractvalue { i64 , i1 } %mul , 1
56
52
%mul2 = tail call { i64 , i1 } @llvm.umul.with.overflow.i64 (i64 %y , i64 %x )
57
- %mul.ov2 = extractvalue { i64 , i1 } %mul , 1
53
+ %mul.ov2 = extractvalue { i64 , i1 } %mul2 , 1
58
54
br label %land.end
59
55
60
56
land.end: ; preds = %land.rhs, %entry
0 commit comments