Skip to content

Commit abd178c

Browse files
committed
!fixup add both
1 parent ca3fbd0 commit abd178c

File tree

2 files changed

+13
-8
lines changed

2 files changed

+13
-8
lines changed

llvm/lib/Analysis/ScalarEvolution.cpp

Lines changed: 8 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -15834,9 +15834,14 @@ void ScalarEvolution::LoopGuards::collectFromBlock(
1583415834
if (isa<SCEVCouldNotCompute>(LHS) || isa<SCEVCouldNotCompute>(RHS))
1583515835
break;
1583615836
}
15837-
From = SE.getMinusSCEV(RHS, LHS);
15838-
FromRewritten = From;
15839-
To = SE.getUMaxExpr(FromRewritten, SE.getOne(From->getType()));
15837+
auto AddSubRewrite = [&](const SCEV *A, const SCEV *B) {
15838+
const SCEV *Sub = SE.getMinusSCEV(A, B);
15839+
AddRewrite(Sub, Sub,
15840+
SE.getUMaxExpr(Sub, SE.getOne(From->getType())));
15841+
};
15842+
AddSubRewrite(LHS, RHS);
15843+
AddSubRewrite(RHS, LHS);
15844+
continue;
1584015845
}
1584115846
break;
1584215847
default:

llvm/test/Analysis/ScalarEvolution/ptrtoint.ll

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -459,7 +459,7 @@ define void @pr46786_c26_char_cmp_ops_swapped(ptr %arg, ptr %arg1, ptr %arg2) {
459459
; X64-NEXT: %i9 = ptrtoint ptr %i7 to i64
460460
; X64-NEXT: --> {(ptrtoint ptr %arg to i64),+,1}<nuw><%bb6> U: full-set S: full-set Exits: (-1 + (ptrtoint ptr %arg1 to i64)) LoopDispositions: { %bb6: Computable }
461461
; X64-NEXT: %i10 = sub i64 %i9, %i4
462-
; X64-NEXT: --> {0,+,1}<nuw><%bb6> U: full-set S: full-set Exits: (-1 + (-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64)) LoopDispositions: { %bb6: Computable }
462+
; X64-NEXT: --> {0,+,1}<nuw><%bb6> U: [0,-1) S: [0,-1) Exits: (-1 + (-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64)) LoopDispositions: { %bb6: Computable }
463463
; X64-NEXT: %i11 = getelementptr inbounds i8, ptr %arg2, i64 %i10
464464
; X64-NEXT: --> {%arg2,+,1}<nw><%bb6> U: full-set S: full-set Exits: (-1 + (-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64) + %arg2) LoopDispositions: { %bb6: Computable }
465465
; X64-NEXT: %i12 = load i8, ptr %i11, align 1
@@ -470,7 +470,7 @@ define void @pr46786_c26_char_cmp_ops_swapped(ptr %arg, ptr %arg1, ptr %arg2) {
470470
; X64-NEXT: --> {(1 + %arg),+,1}<nuw><%bb6> U: full-set S: full-set Exits: ((-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64) + %arg) LoopDispositions: { %bb6: Computable }
471471
; X64-NEXT: Determining loop execution counts for: @pr46786_c26_char_cmp_ops_swapped
472472
; X64-NEXT: Loop %bb6: backedge-taken count is (-1 + (-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64))
473-
; X64-NEXT: Loop %bb6: constant max backedge-taken count is i64 -1
473+
; X64-NEXT: Loop %bb6: constant max backedge-taken count is i64 -2
474474
; X64-NEXT: Loop %bb6: symbolic max backedge-taken count is (-1 + (-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64))
475475
; X64-NEXT: Loop %bb6: Trip multiple is 1
476476
;
@@ -483,9 +483,9 @@ define void @pr46786_c26_char_cmp_ops_swapped(ptr %arg, ptr %arg1, ptr %arg2) {
483483
; X32-NEXT: %i8 = load i8, ptr %i7, align 1
484484
; X32-NEXT: --> %i8 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %bb6: Variant }
485485
; X32-NEXT: %i9 = ptrtoint ptr %i7 to i64
486-
; X32-NEXT: --> {(zext i32 (ptrtoint ptr %arg to i32) to i64),+,1}<nuw><%bb6> U: [0,8589934591) S: [0,8589934591) Exits: ((zext i32 (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32)) to i64) + (zext i32 (ptrtoint ptr %arg to i32) to i64)) LoopDispositions: { %bb6: Computable }
486+
; X32-NEXT: --> {(zext i32 (ptrtoint ptr %arg to i32) to i64),+,1}<nuw><%bb6> U: [0,8589934590) S: [0,8589934590) Exits: ((zext i32 (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32)) to i64) + (zext i32 (ptrtoint ptr %arg to i32) to i64)) LoopDispositions: { %bb6: Computable }
487487
; X32-NEXT: %i10 = sub i64 %i9, %i4
488-
; X32-NEXT: --> {0,+,1}<nuw><%bb6> U: [0,4294967296) S: [0,4294967296) Exits: (zext i32 (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32)) to i64) LoopDispositions: { %bb6: Computable }
488+
; X32-NEXT: --> {0,+,1}<nuw><%bb6> U: [0,4294967295) S: [0,4294967295) Exits: (zext i32 (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32)) to i64) LoopDispositions: { %bb6: Computable }
489489
; X32-NEXT: %i11 = getelementptr inbounds i8, ptr %arg2, i64 %i10
490490
; X32-NEXT: --> {%arg2,+,1}<%bb6> U: full-set S: full-set Exits: (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32) + %arg2) LoopDispositions: { %bb6: Computable }
491491
; X32-NEXT: %i12 = load i8, ptr %i11, align 1
@@ -496,7 +496,7 @@ define void @pr46786_c26_char_cmp_ops_swapped(ptr %arg, ptr %arg1, ptr %arg2) {
496496
; X32-NEXT: --> {(1 + %arg),+,1}<nuw><%bb6> U: full-set S: full-set Exits: ((-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32) + %arg) LoopDispositions: { %bb6: Computable }
497497
; X32-NEXT: Determining loop execution counts for: @pr46786_c26_char_cmp_ops_swapped
498498
; X32-NEXT: Loop %bb6: backedge-taken count is (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32))
499-
; X32-NEXT: Loop %bb6: constant max backedge-taken count is i32 -1
499+
; X32-NEXT: Loop %bb6: constant max backedge-taken count is i32 -2
500500
; X32-NEXT: Loop %bb6: symbolic max backedge-taken count is (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32))
501501
; X32-NEXT: Loop %bb6: Trip multiple is 1
502502
;

0 commit comments

Comments
 (0)