Skip to content

Commit 7ede0fa

Browse files
committed
!fixup add both
1 parent 845cde4 commit 7ede0fa

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
@@ -15841,9 +15841,14 @@ void ScalarEvolution::LoopGuards::collectFromBlock(
1584115841
if (isa<SCEVCouldNotCompute>(LHS) || isa<SCEVCouldNotCompute>(RHS))
1584215842
break;
1584315843
}
15844-
From = SE.getMinusSCEV(RHS, LHS);
15845-
FromRewritten = From;
15846-
To = SE.getUMaxExpr(FromRewritten, SE.getOne(From->getType()));
15844+
auto AddSubRewrite = [&](const SCEV *A, const SCEV *B) {
15845+
const SCEV *Sub = SE.getMinusSCEV(A, B);
15846+
AddRewrite(Sub, Sub,
15847+
SE.getUMaxExpr(Sub, SE.getOne(From->getType())));
15848+
};
15849+
AddSubRewrite(LHS, RHS);
15850+
AddSubRewrite(RHS, LHS);
15851+
continue;
1584715852
}
1584815853
break;
1584915854
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)