Skip to content

Commit 735ee5c

Browse files
committed
[SCEV] Add test with ptrtoint guards and their order swapped.
Additional test coverage for #160500.
1 parent 9bb0eed commit 735ee5c

File tree

1 file changed

+78
-0
lines changed

1 file changed

+78
-0
lines changed

llvm/test/Analysis/ScalarEvolution/ptrtoint.ll

Lines changed: 78 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -447,6 +447,84 @@ bb5:
447447
ret void
448448
}
449449

450+
define void @pr46786_c26_char_cmp_ops_swapped(ptr %arg, ptr %arg1, ptr %arg2) {
451+
; X64-LABEL: 'pr46786_c26_char_cmp_ops_swapped'
452+
; X64-NEXT: Classifying expressions for: @pr46786_c26_char_cmp_ops_swapped
453+
; X64-NEXT: %i4 = ptrtoint ptr %arg to i64
454+
; X64-NEXT: --> (ptrtoint ptr %arg to i64) U: full-set S: full-set
455+
; X64-NEXT: %i7 = phi ptr [ %arg, %bb3 ], [ %i14, %bb6 ]
456+
; X64-NEXT: --> {%arg,+,1}<nuw><%bb6> U: full-set S: full-set Exits: (-1 + (-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64) + %arg) LoopDispositions: { %bb6: Computable }
457+
; X64-NEXT: %i8 = load i8, ptr %i7, align 1
458+
; X64-NEXT: --> %i8 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %bb6: Variant }
459+
; X64-NEXT: %i9 = ptrtoint ptr %i7 to i64
460+
; 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 }
461+
; 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 }
463+
; X64-NEXT: %i11 = getelementptr inbounds i8, ptr %arg2, i64 %i10
464+
; 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 }
465+
; X64-NEXT: %i12 = load i8, ptr %i11, align 1
466+
; X64-NEXT: --> %i12 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %bb6: Variant }
467+
; X64-NEXT: %i13 = add i8 %i12, %i8
468+
; X64-NEXT: --> (%i12 + %i8) U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %bb6: Variant }
469+
; X64-NEXT: %i14 = getelementptr inbounds i8, ptr %i7, i64 1
470+
; 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 }
471+
; X64-NEXT: Determining loop execution counts for: @pr46786_c26_char_cmp_ops_swapped
472+
; 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
474+
; X64-NEXT: Loop %bb6: symbolic max backedge-taken count is (-1 + (-1 * (ptrtoint ptr %arg to i64)) + (ptrtoint ptr %arg1 to i64))
475+
; X64-NEXT: Loop %bb6: Trip multiple is 1
476+
;
477+
; X32-LABEL: 'pr46786_c26_char_cmp_ops_swapped'
478+
; X32-NEXT: Classifying expressions for: @pr46786_c26_char_cmp_ops_swapped
479+
; X32-NEXT: %i4 = ptrtoint ptr %arg to i64
480+
; X32-NEXT: --> (zext i32 (ptrtoint ptr %arg to i32) to i64) U: [0,4294967296) S: [0,4294967296)
481+
; X32-NEXT: %i7 = phi ptr [ %arg, %bb3 ], [ %i14, %bb6 ]
482+
; X32-NEXT: --> {%arg,+,1}<nuw><%bb6> U: full-set S: full-set Exits: (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32) + %arg) LoopDispositions: { %bb6: Computable }
483+
; X32-NEXT: %i8 = load i8, ptr %i7, align 1
484+
; X32-NEXT: --> %i8 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %bb6: Variant }
485+
; 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 }
487+
; 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 }
489+
; X32-NEXT: %i11 = getelementptr inbounds i8, ptr %arg2, i64 %i10
490+
; 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 }
491+
; X32-NEXT: %i12 = load i8, ptr %i11, align 1
492+
; X32-NEXT: --> %i12 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %bb6: Variant }
493+
; X32-NEXT: %i13 = add i8 %i12, %i8
494+
; X32-NEXT: --> (%i12 + %i8) U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %bb6: Variant }
495+
; X32-NEXT: %i14 = getelementptr inbounds i8, ptr %i7, i64 1
496+
; 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 }
497+
; X32-NEXT: Determining loop execution counts for: @pr46786_c26_char_cmp_ops_swapped
498+
; 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
500+
; X32-NEXT: Loop %bb6: symbolic max backedge-taken count is (-1 + (-1 * (ptrtoint ptr %arg to i32)) + (ptrtoint ptr %arg1 to i32))
501+
; X32-NEXT: Loop %bb6: Trip multiple is 1
502+
;
503+
%i = icmp eq ptr %arg1, %arg
504+
br i1 %i, label %bb5, label %bb3
505+
506+
bb3:
507+
%i4 = ptrtoint ptr %arg to i64
508+
br label %bb6
509+
510+
bb6:
511+
%i7 = phi ptr [ %arg, %bb3 ], [ %i14, %bb6 ]
512+
%i8 = load i8, ptr %i7
513+
%i9 = ptrtoint ptr %i7 to i64
514+
%i10 = sub i64 %i9, %i4
515+
%i11 = getelementptr inbounds i8, ptr %arg2, i64 %i10
516+
%i12 = load i8, ptr %i11
517+
%i13 = add i8 %i12, %i8
518+
store i8 %i13, ptr %i11
519+
%i14 = getelementptr inbounds i8, ptr %i7, i64 1
520+
%i15 = icmp eq ptr %i14, %arg1
521+
br i1 %i15, label %bb5, label %bb6
522+
523+
bb5:
524+
ret void
525+
}
526+
527+
450528
; void pr46786_c26_int(int* start, int *end, int *other) {
451529
; for (int* cur = start; cur != end; ++cur)
452530
; other[cur - start] += *cur;

0 commit comments

Comments
 (0)