@@ -1435,32 +1435,49 @@ define i32 @and31_add_sexts(i1 %x, i1 %y) {
1435
1435
ret i32 %r
1436
1436
}
1437
1437
1438
- ; Negative test - extra use
1438
+ declare void @use_sexts ( i32 , i32 )
1439
1439
1440
- define i32 @lshr_add_use_sexts (i1 %x , i1 %y , ptr %p ) {
1441
- ; CHECK-LABEL: @lshr_add_use_sexts(
1440
+ ; Negative test
1441
+ define i32 @lshr_add_use_sexts_both (i1 %x , i1 %y , ptr %p ) {
1442
+ ; CHECK-LABEL: @lshr_add_use_sexts_both(
1442
1443
; CHECK-NEXT: [[XS:%.*]] = sext i1 [[X:%.*]] to i32
1444
+ ; CHECK-NEXT: store i32 [[XS]], ptr [[P:%.*]], align 4
1443
1445
; CHECK-NEXT: [[YS:%.*]] = sext i1 [[Y:%.*]] to i32
1446
+ ; CHECK-NEXT: call void @use_sexts(i32 [[XS]], i32 [[YS]])
1444
1447
; CHECK-NEXT: [[SUB:%.*]] = add nsw i32 [[XS]], [[YS]]
1445
1448
; CHECK-NEXT: [[R:%.*]] = lshr i32 [[SUB]], 31
1446
1449
; CHECK-NEXT: ret i32 [[R]]
1447
1450
;
1448
1451
%xs = sext i1 %x to i32
1452
+ store i32 %xs , ptr %p
1449
1453
%ys = sext i1 %y to i32
1454
+ call void @use_sexts (i32 %xs , i32 %ys )
1450
1455
%sub = add i32 %xs , %ys
1451
1456
%r = lshr i32 %sub , 31
1452
1457
ret i32 %r
1453
1458
}
1454
1459
1455
- ; Negative test - extra use
1456
-
1457
1460
define i32 @lshr_add_use_sexts (i1 %x , i1 %y , ptr %p ) {
1458
1461
; CHECK-LABEL: @lshr_add_use_sexts(
1462
+ ; CHECK-NEXT: [[TMP1:%.*]] = or i1 [[X:%.*]], [[Y:%.*]]
1463
+ ; CHECK-NEXT: [[R:%.*]] = zext i1 [[TMP1]] to i32
1464
+ ; CHECK-NEXT: ret i32 [[R]]
1465
+ ;
1466
+ %xs = sext i1 %x to i32
1467
+ %ys = sext i1 %y to i32
1468
+ %sub = add i32 %xs , %ys
1469
+ %r = lshr i32 %sub , 31
1470
+ ret i32 %r
1471
+ }
1472
+
1473
+ ; Negative test - extra use
1474
+
1475
+ define i32 @lshr_add_use_sexts_2 (i1 %x , i1 %y , ptr %p ) {
1476
+ ; CHECK-LABEL: @lshr_add_use_sexts_2(
1459
1477
; CHECK-NEXT: [[XS:%.*]] = sext i1 [[X:%.*]] to i32
1460
1478
; CHECK-NEXT: store i32 [[XS]], ptr [[P:%.*]], align 4
1461
- ; CHECK-NEXT: [[YS:%.*]] = sext i1 [[Y:%.*]] to i32
1462
- ; CHECK-NEXT: [[SUB:%.*]] = add nsw i32 [[XS]], [[YS]]
1463
- ; CHECK-NEXT: [[R:%.*]] = lshr i32 [[SUB]], 31
1479
+ ; CHECK-NEXT: [[TMP1:%.*]] = or i1 [[X]], [[Y:%.*]]
1480
+ ; CHECK-NEXT: [[R:%.*]] = zext i1 [[TMP1]] to i32
1464
1481
; CHECK-NEXT: ret i32 [[R]]
1465
1482
;
1466
1483
%xs = sext i1 %x to i32
@@ -1473,11 +1490,10 @@ define i32 @lshr_add_use_sexts(i1 %x, i1 %y, ptr %p) {
1473
1490
1474
1491
define i32 @lshr_add_use2_sexts (i1 %x , i1 %y , ptr %p ) {
1475
1492
; CHECK-LABEL: @lshr_add_use2_sexts(
1476
- ; CHECK-NEXT: [[XS:%.*]] = sext i1 [[X:%.*]] to i32
1477
1493
; CHECK-NEXT: [[YS:%.*]] = sext i1 [[Y:%.*]] to i32
1478
1494
; CHECK-NEXT: store i32 [[YS]], ptr [[P:%.*]], align 4
1479
- ; CHECK-NEXT: [[SUB :%.*]] = add nsw i32 [[XS ]], [[YS ]]
1480
- ; CHECK-NEXT: [[R:%.*]] = lshr i32 [[SUB]], 31
1495
+ ; CHECK-NEXT: [[TMP1 :%.*]] = or i1 [[X:%.* ]], [[Y ]]
1496
+ ; CHECK-NEXT: [[R:%.*]] = zext i1 [[TMP1]] to i32
1481
1497
; CHECK-NEXT: ret i32 [[R]]
1482
1498
;
1483
1499
%xs = sext i1 %x to i32
@@ -4033,8 +4049,8 @@ define i32 @add_reduce_sqr_sum_varC_invalid2(i32 %a, i32 %b) {
4033
4049
4034
4050
define i32 @fold_sext_addition_or_disjoint (i8 %x ) {
4035
4051
; CHECK-LABEL: @fold_sext_addition_or_disjoint(
4036
- ; CHECK-NEXT: [[SE :%.*]] = sext i8 [[XX :%.*]] to i32
4037
- ; CHECK-NEXT: [[R:%.*]] = add nsw i32 [[SE ]], 1246
4052
+ ; CHECK-NEXT: [[TMP1 :%.*]] = sext i8 [[X :%.*]] to i32
4053
+ ; CHECK-NEXT: [[R:%.*]] = add nsw i32 [[TMP1 ]], 1246
4038
4054
; CHECK-NEXT: ret i32 [[R]]
4039
4055
;
4040
4056
%xx = or disjoint i8 %x , 12
@@ -4058,8 +4074,8 @@ define i32 @fold_sext_addition_fail(i8 %x) {
4058
4074
4059
4075
define i32 @fold_zext_addition_or_disjoint (i8 %x ) {
4060
4076
; CHECK-LABEL: @fold_zext_addition_or_disjoint(
4061
- ; CHECK-NEXT: [[SE :%.*]] = zext i8 [[XX :%.*]] to i32
4062
- ; CHECK-NEXT: [[R:%.*]] = add nuw nsw i32 [[SE ]], 1246
4077
+ ; CHECK-NEXT: [[TMP1 :%.*]] = zext i8 [[X :%.*]] to i32
4078
+ ; CHECK-NEXT: [[R:%.*]] = add nuw nsw i32 [[TMP1 ]], 1246
4063
4079
; CHECK-NEXT: ret i32 [[R]]
4064
4080
;
4065
4081
%xx = or disjoint i8 %x , 12
@@ -4070,9 +4086,9 @@ define i32 @fold_zext_addition_or_disjoint(i8 %x) {
4070
4086
4071
4087
define i32 @fold_zext_addition_or_disjoint2 (i8 %x ) {
4072
4088
; CHECK-LABEL: @fold_zext_addition_or_disjoint2(
4073
- ; CHECK-NEXT: [[XX :%.*]] = add nuw i8 [[X:%.*]], 4
4074
- ; CHECK-NEXT: [[SE :%.*]] = zext i8 [[XX ]] to i32
4075
- ; CHECK-NEXT: ret i32 [[SE ]]
4089
+ ; CHECK-NEXT: [[TMP1 :%.*]] = add nuw i8 [[X:%.*]], 4
4090
+ ; CHECK-NEXT: [[R :%.*]] = zext i8 [[TMP1 ]] to i32
4091
+ ; CHECK-NEXT: ret i32 [[R ]]
4076
4092
;
4077
4093
%xx = or disjoint i8 %x , 18
4078
4094
%se = zext i8 %xx to i32
0 commit comments