@@ -1435,11 +1435,26 @@ define i32 @and31_add_sexts(i1 %x, i1 %y) {
1435
1435
ret i32 %r
1436
1436
}
1437
1437
1438
- ; Negative test - extra use
1439
-
1440
1438
define i32 @lshr_add_use_sexts (i1 %x , i1 %y , ptr %p ) {
1441
1439
; CHECK-LABEL: @lshr_add_use_sexts(
1442
1440
; CHECK-NEXT: [[XS:%.*]] = sext i1 [[X:%.*]] to i32
1441
+ ; CHECK-NEXT: [[YS:%.*]] = sext i1 [[Y:%.*]] to i32
1442
+ ; CHECK-NEXT: store i32 [[YS]], ptr [[P:%.*]], align 4
1443
+ ; CHECK-NEXT: [[SUB:%.*]] = add nsw i32 [[XS]], [[YS]]
1444
+ ; CHECK-NEXT: [[R:%.*]] = lshr i32 [[SUB]], 31
1445
+ ; CHECK-NEXT: ret i32 [[R]]
1446
+ ;
1447
+ %xs = sext i1 %x to i32
1448
+ %ys = sext i1 %y to i32
1449
+ store i32 %ys , ptr %p
1450
+ %sub = add i32 %xs , %ys
1451
+ %r = lshr i32 %sub , 31
1452
+ ret i32 %r
1453
+ }
1454
+
1455
+ define i32 @lshr_add_use_sexts_2 (i1 %x , i1 %y , ptr %p ) {
1456
+ ; CHECK-LABEL: @lshr_add_use_sexts_2(
1457
+ ; CHECK-NEXT: [[XS:%.*]] = sext i1 [[X:%.*]] to i32
1443
1458
; CHECK-NEXT: store i32 [[XS]], ptr [[P:%.*]], align 4
1444
1459
; CHECK-NEXT: [[YS:%.*]] = sext i1 [[Y:%.*]] to i32
1445
1460
; CHECK-NEXT: [[SUB:%.*]] = add nsw i32 [[XS]], [[YS]]
@@ -1456,18 +1471,20 @@ define i32 @lshr_add_use_sexts(i1 %x, i1 %y, ptr %p) {
1456
1471
1457
1472
; Negative test - extra use
1458
1473
1459
- define i32 @lshr_add_use2_sexts (i1 %x , i1 %y , ptr %p ) {
1460
- ; CHECK-LABEL: @lshr_add_use2_sexts(
1474
+ declare void @use_sexts (i32 , i32 )
1475
+
1476
+ define i32 @lshr_add_use_sexts_both (i1 %x , i1 %y ) {
1477
+ ; CHECK-LABEL: @lshr_add_use_sexts_both(
1461
1478
; CHECK-NEXT: [[XS:%.*]] = sext i1 [[X:%.*]] to i32
1462
1479
; CHECK-NEXT: [[YS:%.*]] = sext i1 [[Y:%.*]] to i32
1463
- ; CHECK-NEXT: store i32 [[YS ]], ptr [[P:%.*]], align 4
1480
+ ; CHECK-NEXT: call void @use_sexts( i32 [[XS ]], i32 [[YS]])
1464
1481
; CHECK-NEXT: [[SUB:%.*]] = add nsw i32 [[XS]], [[YS]]
1465
1482
; CHECK-NEXT: [[R:%.*]] = lshr i32 [[SUB]], 31
1466
1483
; CHECK-NEXT: ret i32 [[R]]
1467
1484
;
1468
1485
%xs = sext i1 %x to i32
1469
1486
%ys = sext i1 %y to i32
1470
- store i32 %ys , ptr %p
1487
+ call void @use_sexts ( i32 %xs , i32 %ys )
1471
1488
%sub = add i32 %xs , %ys
1472
1489
%r = lshr i32 %sub , 31
1473
1490
ret i32 %r
@@ -4018,8 +4035,8 @@ define i32 @add_reduce_sqr_sum_varC_invalid2(i32 %a, i32 %b) {
4018
4035
4019
4036
define i32 @fold_sext_addition_or_disjoint (i8 %x ) {
4020
4037
; CHECK-LABEL: @fold_sext_addition_or_disjoint(
4021
- ; CHECK-NEXT: [[SE :%.*]] = sext i8 [[XX :%.*]] to i32
4022
- ; CHECK-NEXT: [[R:%.*]] = add nsw i32 [[SE ]], 1246
4038
+ ; CHECK-NEXT: [[TMP1 :%.*]] = sext i8 [[X :%.*]] to i32
4039
+ ; CHECK-NEXT: [[R:%.*]] = add nsw i32 [[TMP1 ]], 1246
4023
4040
; CHECK-NEXT: ret i32 [[R]]
4024
4041
;
4025
4042
%xx = or disjoint i8 %x , 12
@@ -4043,8 +4060,8 @@ define i32 @fold_sext_addition_fail(i8 %x) {
4043
4060
4044
4061
define i32 @fold_zext_addition_or_disjoint (i8 %x ) {
4045
4062
; CHECK-LABEL: @fold_zext_addition_or_disjoint(
4046
- ; CHECK-NEXT: [[SE :%.*]] = zext i8 [[XX :%.*]] to i32
4047
- ; CHECK-NEXT: [[R:%.*]] = add nuw nsw i32 [[SE ]], 1246
4063
+ ; CHECK-NEXT: [[TMP1 :%.*]] = zext i8 [[X :%.*]] to i32
4064
+ ; CHECK-NEXT: [[R:%.*]] = add nuw nsw i32 [[TMP1 ]], 1246
4048
4065
; CHECK-NEXT: ret i32 [[R]]
4049
4066
;
4050
4067
%xx = or disjoint i8 %x , 12
@@ -4055,9 +4072,9 @@ define i32 @fold_zext_addition_or_disjoint(i8 %x) {
4055
4072
4056
4073
define i32 @fold_zext_addition_or_disjoint2 (i8 %x ) {
4057
4074
; CHECK-LABEL: @fold_zext_addition_or_disjoint2(
4058
- ; CHECK-NEXT: [[XX :%.*]] = add nuw i8 [[X:%.*]], 4
4059
- ; CHECK-NEXT: [[SE :%.*]] = zext i8 [[XX ]] to i32
4060
- ; CHECK-NEXT: ret i32 [[SE ]]
4075
+ ; CHECK-NEXT: [[TMP1 :%.*]] = add nuw i8 [[X:%.*]], 4
4076
+ ; CHECK-NEXT: [[R :%.*]] = zext i8 [[TMP1 ]] to i32
4077
+ ; CHECK-NEXT: ret i32 [[R ]]
4061
4078
;
4062
4079
%xx = or disjoint i8 %x , 18
4063
4080
%se = zext i8 %xx to i32
0 commit comments