1d36efa96SJoshua Cao; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 2 2d36efa96SJoshua Cao; RUN: opt < %s -disable-output "-passes=print<scalar-evolution>" 2>&1 | FileCheck %s 3d36efa96SJoshua Cao 4898a9ca5SJoshua Cao; Tests loops with huge trip counts. Trip count of >=2^32 are huge. Huge trip counts have a trip multiple 5898a9ca5SJoshua Cao; of the greatest power of 2 less than 2^32. 6d36efa96SJoshua Cao 7d36efa96SJoshua Caodeclare void @foo(...) 8d36efa96SJoshua Cao 9d36efa96SJoshua Caodefine void @trip_count_4294967295() { 10d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_4294967295' 11d36efa96SJoshua Cao; CHECK-NEXT: Classifying expressions for: @trip_count_4294967295 12d36efa96SJoshua Cao; CHECK-NEXT: %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 13d36efa96SJoshua Cao; CHECK-NEXT: --> {0,+,1}<nuw><nsw><%for.body> U: [0,4294967295) S: [0,4294967295) Exits: 4294967294 LoopDispositions: { %for.body: Computable } 14d36efa96SJoshua Cao; CHECK-NEXT: %add = add nuw nsw i64 %i.02, 1 15d36efa96SJoshua Cao; CHECK-NEXT: --> {1,+,1}<nuw><nsw><%for.body> U: [1,4294967296) S: [1,4294967296) Exits: 4294967295 LoopDispositions: { %for.body: Computable } 16d36efa96SJoshua Cao; CHECK-NEXT: Determining loop execution counts for: @trip_count_4294967295 17*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: backedge-taken count is i64 4294967294 187755c261SPhilip Reames; CHECK-NEXT: Loop %for.body: constant max backedge-taken count is i64 4294967294 19*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: symbolic max backedge-taken count is i64 4294967294 2088f7dc17SNikita Popov; CHECK-NEXT: Loop %for.body: Trip multiple is 4294967295 21d36efa96SJoshua Cao; 22d36efa96SJoshua Caoentry: 23d36efa96SJoshua Cao br label %for.body 24d36efa96SJoshua Cao 25d36efa96SJoshua Caofor.cond.cleanup: ; preds = %for.body 26d36efa96SJoshua Cao ret void 27d36efa96SJoshua Cao 28d36efa96SJoshua Caofor.body: ; preds = %entry, %for.body 29d36efa96SJoshua Cao %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 30d36efa96SJoshua Cao tail call void (...) @foo() #2 31d36efa96SJoshua Cao %add = add nuw nsw i64 %i.02, 1 32d36efa96SJoshua Cao %exitcond.not = icmp eq i64 %add, 4294967295 33d36efa96SJoshua Cao br i1 %exitcond.not, label %for.cond.cleanup, label %for.body 34d36efa96SJoshua Cao} 35d36efa96SJoshua Cao 36d36efa96SJoshua Caodefine void @trip_count_4294967296() { 37d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_4294967296' 38d36efa96SJoshua Cao; CHECK-NEXT: Classifying expressions for: @trip_count_4294967296 39d36efa96SJoshua Cao; CHECK-NEXT: %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 40d36efa96SJoshua Cao; CHECK-NEXT: --> {0,+,1}<nuw><nsw><%for.body> U: [0,4294967296) S: [0,4294967296) Exits: 4294967295 LoopDispositions: { %for.body: Computable } 41d36efa96SJoshua Cao; CHECK-NEXT: %add = add nuw nsw i64 %i.02, 1 42d36efa96SJoshua Cao; CHECK-NEXT: --> {1,+,1}<nuw><nsw><%for.body> U: [1,4294967297) S: [1,4294967297) Exits: 4294967296 LoopDispositions: { %for.body: Computable } 43d36efa96SJoshua Cao; CHECK-NEXT: Determining loop execution counts for: @trip_count_4294967296 44*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: backedge-taken count is i64 4294967295 457755c261SPhilip Reames; CHECK-NEXT: Loop %for.body: constant max backedge-taken count is i64 4294967295 46*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: symbolic max backedge-taken count is i64 4294967295 4788f7dc17SNikita Popov; CHECK-NEXT: Loop %for.body: Trip multiple is 2147483648 48d36efa96SJoshua Cao; 49d36efa96SJoshua Caoentry: 50d36efa96SJoshua Cao br label %for.body 51d36efa96SJoshua Cao 52d36efa96SJoshua Caofor.cond.cleanup: ; preds = %for.body 53d36efa96SJoshua Cao ret void 54d36efa96SJoshua Cao 55d36efa96SJoshua Caofor.body: ; preds = %entry, %for.body 56d36efa96SJoshua Cao %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 57d36efa96SJoshua Cao tail call void (...) @foo() #2 58d36efa96SJoshua Cao %add = add nuw nsw i64 %i.02, 1 59d36efa96SJoshua Cao %exitcond.not = icmp eq i64 %add, 4294967296 60d36efa96SJoshua Cao br i1 %exitcond.not, label %for.cond.cleanup, label %for.body 61d36efa96SJoshua Cao} 62d36efa96SJoshua Cao 63d36efa96SJoshua Caodefine void @trip_count_8589935692() { 64d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_8589935692' 65d36efa96SJoshua Cao; CHECK-NEXT: Classifying expressions for: @trip_count_8589935692 66d36efa96SJoshua Cao; CHECK-NEXT: %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 67d36efa96SJoshua Cao; CHECK-NEXT: --> {0,+,1}<nuw><nsw><%for.body> U: [0,8589934592) S: [0,8589934592) Exits: 8589934591 LoopDispositions: { %for.body: Computable } 68d36efa96SJoshua Cao; CHECK-NEXT: %add = add nuw nsw i64 %i.02, 1 69d36efa96SJoshua Cao; CHECK-NEXT: --> {1,+,1}<nuw><nsw><%for.body> U: [1,8589934593) S: [1,8589934593) Exits: 8589934592 LoopDispositions: { %for.body: Computable } 70d36efa96SJoshua Cao; CHECK-NEXT: Determining loop execution counts for: @trip_count_8589935692 71*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: backedge-taken count is i64 8589934591 727755c261SPhilip Reames; CHECK-NEXT: Loop %for.body: constant max backedge-taken count is i64 8589934591 73*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: symbolic max backedge-taken count is i64 8589934591 7488f7dc17SNikita Popov; CHECK-NEXT: Loop %for.body: Trip multiple is 2147483648 75d36efa96SJoshua Cao; 76d36efa96SJoshua Caoentry: 77d36efa96SJoshua Cao br label %for.body 78d36efa96SJoshua Cao 79d36efa96SJoshua Caofor.cond.cleanup: ; preds = %for.body 80d36efa96SJoshua Cao ret void 81d36efa96SJoshua Cao 82d36efa96SJoshua Caofor.body: ; preds = %entry, %for.body 83d36efa96SJoshua Cao %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 84d36efa96SJoshua Cao tail call void (...) @foo() #2 85d36efa96SJoshua Cao %add = add nuw nsw i64 %i.02, 1 86d36efa96SJoshua Cao %exitcond.not = icmp eq i64 %add, 8589934592 87d36efa96SJoshua Cao br i1 %exitcond.not, label %for.cond.cleanup, label %for.body 88d36efa96SJoshua Cao} 89d36efa96SJoshua Cao 90d36efa96SJoshua Caodefine void @trip_count_9223372036854775808() { 91d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_9223372036854775808' 92d36efa96SJoshua Cao; CHECK-NEXT: Classifying expressions for: @trip_count_9223372036854775808 93d36efa96SJoshua Cao; CHECK-NEXT: %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 94d36efa96SJoshua Cao; CHECK-NEXT: --> {0,+,1}<nuw><nsw><%for.body> U: [0,-9223372036854775808) S: [0,-9223372036854775808) Exits: 9223372036854775807 LoopDispositions: { %for.body: Computable } 95d36efa96SJoshua Cao; CHECK-NEXT: %add = add nuw nsw i64 %i.02, 1 96d36efa96SJoshua Cao; CHECK-NEXT: --> {1,+,1}<nuw><%for.body> U: [1,-9223372036854775807) S: [1,-9223372036854775807) Exits: -9223372036854775808 LoopDispositions: { %for.body: Computable } 97d36efa96SJoshua Cao; CHECK-NEXT: Determining loop execution counts for: @trip_count_9223372036854775808 98*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: backedge-taken count is i64 9223372036854775807 997755c261SPhilip Reames; CHECK-NEXT: Loop %for.body: constant max backedge-taken count is i64 9223372036854775807 100*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: symbolic max backedge-taken count is i64 9223372036854775807 10188f7dc17SNikita Popov; CHECK-NEXT: Loop %for.body: Trip multiple is 2147483648 102d36efa96SJoshua Cao; 103d36efa96SJoshua Caoentry: 104d36efa96SJoshua Cao br label %for.body 105d36efa96SJoshua Cao 106d36efa96SJoshua Caofor.cond.cleanup: ; preds = %for.body 107d36efa96SJoshua Cao ret void 108d36efa96SJoshua Cao 109d36efa96SJoshua Caofor.body: ; preds = %entry, %for.body 110d36efa96SJoshua Cao %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 111d36efa96SJoshua Cao tail call void (...) @foo() #2 112d36efa96SJoshua Cao %add = add nuw nsw i64 %i.02, 1 113d36efa96SJoshua Cao %exitcond.not = icmp eq i64 %add, 9223372036854775808 114d36efa96SJoshua Cao br i1 %exitcond.not, label %for.cond.cleanup, label %for.body 115d36efa96SJoshua Cao} 116d36efa96SJoshua Cao 117d36efa96SJoshua Caodefine void @trip_count_18446744073709551615() { 118d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_18446744073709551615' 119d36efa96SJoshua Cao; CHECK-NEXT: Classifying expressions for: @trip_count_18446744073709551615 120d36efa96SJoshua Cao; CHECK-NEXT: %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 121d36efa96SJoshua Cao; CHECK-NEXT: --> {0,+,1}<nuw><nsw><%for.body> U: [0,-9223372036854775808) S: [0,-9223372036854775808) Exits: -2 LoopDispositions: { %for.body: Computable } 122d36efa96SJoshua Cao; CHECK-NEXT: %add = add nuw nsw i64 %i.02, 1 123d36efa96SJoshua Cao; CHECK-NEXT: --> {1,+,1}<nuw><%for.body> U: [1,0) S: [1,0) Exits: -1 LoopDispositions: { %for.body: Computable } 124d36efa96SJoshua Cao; CHECK-NEXT: Determining loop execution counts for: @trip_count_18446744073709551615 125*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: backedge-taken count is i64 -2 1267755c261SPhilip Reames; CHECK-NEXT: Loop %for.body: constant max backedge-taken count is i64 -2 127*0d38f21eSPhilip Reames; CHECK-NEXT: Loop %for.body: symbolic max backedge-taken count is i64 -2 12888f7dc17SNikita Popov; CHECK-NEXT: Loop %for.body: Trip multiple is 1 129d36efa96SJoshua Cao; 130d36efa96SJoshua Caoentry: 131d36efa96SJoshua Cao br label %for.body 132d36efa96SJoshua Cao 133d36efa96SJoshua Caofor.cond.cleanup: ; preds = %for.body 134d36efa96SJoshua Cao ret void 135d36efa96SJoshua Cao 136d36efa96SJoshua Caofor.body: ; preds = %entry, %for.body 137d36efa96SJoshua Cao %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ] 138d36efa96SJoshua Cao tail call void (...) @foo() #2 139d36efa96SJoshua Cao %add = add nuw nsw i64 %i.02, 1 140d36efa96SJoshua Cao %exitcond.not = icmp eq i64 %add, 18446744073709551615 141d36efa96SJoshua Cao br i1 %exitcond.not, label %for.cond.cleanup, label %for.body 142d36efa96SJoshua Cao} 143