1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py 2; RUN: opt -S -passes=indvars -verify-scev %s | FileCheck %s 3target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128-ni:1" 4target triple = "x86_64-unknown-linux-gnu" 5 6define i32 @testDiv(ptr %p, ptr %p1) { 7; CHECK-LABEL: @testDiv( 8; CHECK-NEXT: entry: 9; CHECK-NEXT: br label [[LOOP1:%.*]] 10; CHECK: loop1: 11; CHECK-NEXT: [[INDVARS_IV:%.*]] = phi i64 [ [[INDVARS_IV_NEXT:%.*]], [[LOOP2_EXIT:%.*]] ], [ 8, [[ENTRY:%.*]] ] 12; CHECK-NEXT: [[EXITCOND:%.*]] = icmp eq i64 [[INDVARS_IV]], 15 13; CHECK-NEXT: br i1 [[EXITCOND]], label [[EXIT:%.*]], label [[GENERAL_CASE24:%.*]] 14; CHECK: general_case24: 15; CHECK-NEXT: br i1 false, label [[LOOP2_PREHEADER:%.*]], label [[LOOP2_EXIT]] 16; CHECK: loop2.preheader: 17; CHECK-NEXT: br label [[LOOP2:%.*]] 18; CHECK: loop2: 19; CHECK-NEXT: [[I4:%.*]] = load atomic i64, ptr [[P1:%.*]] unordered, align 8 20; CHECK-NEXT: [[I6:%.*]] = sub i64 [[I4]], -1 21; CHECK-NEXT: store atomic i64 [[I6]], ptr [[P1]] unordered, align 8 22; CHECK-NEXT: br i1 true, label [[LOOP2_EXIT_LOOPEXIT:%.*]], label [[LOOP2]] 23; CHECK: loop2.exit.loopexit: 24; CHECK-NEXT: br label [[LOOP2_EXIT]] 25; CHECK: loop2.exit: 26; CHECK-NEXT: [[INDVARS_IV_NEXT]] = add nuw nsw i64 [[INDVARS_IV]], 1 27; CHECK-NEXT: br i1 false, label [[EXIT]], label [[LOOP1]] 28; CHECK: exit: 29; CHECK-NEXT: ret i32 0 30; 31entry: 32 br label %loop1 33 34loop1: ; preds = %loop2.exit, %entry 35 %local_0_ = phi i32 [ 8, %entry ], [ %i9, %loop2.exit ] 36 %local_2_ = phi i32 [ 63864, %entry ], [ %local_2_43, %loop2.exit ] 37 %local_3_ = phi i32 [ 51, %entry ], [ %local_3_44, %loop2.exit ] 38 %i = udiv i32 14, %local_0_ 39 %i1 = icmp ugt i32 %local_0_, 14 40 br i1 %i1, label %exit, label %general_case24 41 42general_case24: ; preds = %loop1 43 %i2 = udiv i32 60392, %i 44 br i1 false, label %loop2, label %loop2.exit 45 46loop2: ; preds = %loop2, %general_case24 47 %local_1_56 = phi i32 [ %i2, %general_case24 ], [ %i3, %loop2 ] 48 %local_2_57 = phi i32 [ 1, %general_case24 ], [ %i7, %loop2 ] 49 %i3 = add i32 %local_1_56, -1 50 %i4 = load atomic i64, ptr %p1 unordered, align 8 51 %i5 = sext i32 %i3 to i64 52 %i6 = sub i64 %i4, %i5 53 store atomic i64 %i6, ptr %p1 unordered, align 8 54 %i7 = add nuw nsw i32 %local_2_57, 1 55 %i8 = icmp ugt i32 %local_2_57, 7 56 br i1 %i8, label %loop2.exit, label %loop2 57 58loop2.exit: ; preds = %loop2, %general_case24 59 %local_2_43 = phi i32 [ %local_2_, %general_case24 ], [ 9, %loop2 ] 60 %local_3_44 = phi i32 [ %local_3_, %general_case24 ], [ %local_1_56, %loop2 ] 61 %i9 = add nuw nsw i32 %local_0_, 1 62 %i10 = icmp ugt i32 %local_0_, 129 63 br i1 %i10, label %exit, label %loop1 64 65exit: ; preds = %loop2.exit, %loop1 66 ret i32 0 67} 68 69define i32 @testRem(ptr %p, ptr %p1) { 70; CHECK-LABEL: @testRem( 71; CHECK-NEXT: entry: 72; CHECK-NEXT: br label [[LOOP1:%.*]] 73; CHECK: loop1: 74; CHECK-NEXT: [[LOCAL_0_:%.*]] = phi i32 [ 8, [[ENTRY:%.*]] ], [ [[I9:%.*]], [[LOOP2_EXIT:%.*]] ] 75; CHECK-NEXT: [[EXITCOND:%.*]] = icmp eq i32 [[LOCAL_0_]], 15 76; CHECK-NEXT: br i1 [[EXITCOND]], label [[EXIT:%.*]], label [[GENERAL_CASE24:%.*]] 77; CHECK: general_case24: 78; CHECK-NEXT: br i1 false, label [[LOOP2_PREHEADER:%.*]], label [[LOOP2_EXIT]] 79; CHECK: loop2.preheader: 80; CHECK-NEXT: br label [[LOOP2:%.*]] 81; CHECK: loop2: 82; CHECK-NEXT: [[I4:%.*]] = load atomic i64, ptr [[P1:%.*]] unordered, align 8 83; CHECK-NEXT: [[I6:%.*]] = sub i64 [[I4]], -1 84; CHECK-NEXT: store atomic i64 [[I6]], ptr [[P1]] unordered, align 8 85; CHECK-NEXT: br i1 true, label [[LOOP2_EXIT_LOOPEXIT:%.*]], label [[LOOP2]] 86; CHECK: loop2.exit.loopexit: 87; CHECK-NEXT: br label [[LOOP2_EXIT]] 88; CHECK: loop2.exit: 89; CHECK-NEXT: [[I9]] = add nuw nsw i32 [[LOCAL_0_]], 1 90; CHECK-NEXT: br i1 false, label [[EXIT]], label [[LOOP1]] 91; CHECK: exit: 92; CHECK-NEXT: ret i32 0 93; 94entry: 95 br label %loop1 96 97loop1: ; preds = %loop2.exit, %entry 98 %local_0_ = phi i32 [ 8, %entry ], [ %i9, %loop2.exit ] 99 %local_2_ = phi i32 [ 63864, %entry ], [ %local_2_43, %loop2.exit ] 100 %local_3_ = phi i32 [ 51, %entry ], [ %local_3_44, %loop2.exit ] 101 %i = udiv i32 14, %local_0_ 102 %i1 = icmp ugt i32 %local_0_, 14 103 br i1 %i1, label %exit, label %general_case24 104 105general_case24: ; preds = %loop1 106 %i2 = urem i32 60392, %i 107 br i1 false, label %loop2, label %loop2.exit 108 109loop2: ; preds = %loop2, %general_case24 110 %local_1_56 = phi i32 [ %i2, %general_case24 ], [ %i3, %loop2 ] 111 %local_2_57 = phi i32 [ 1, %general_case24 ], [ %i7, %loop2 ] 112 %i3 = add i32 %local_1_56, -1 113 %i4 = load atomic i64, ptr %p1 unordered, align 8 114 %i5 = sext i32 %i3 to i64 115 %i6 = sub i64 %i4, %i5 116 store atomic i64 %i6, ptr %p1 unordered, align 8 117 %i7 = add nuw nsw i32 %local_2_57, 1 118 %i8 = icmp ugt i32 %local_2_57, 7 119 br i1 %i8, label %loop2.exit, label %loop2 120 121loop2.exit: ; preds = %loop2, %general_case24 122 %local_2_43 = phi i32 [ %local_2_, %general_case24 ], [ 9, %loop2 ] 123 %local_3_44 = phi i32 [ %local_3_, %general_case24 ], [ %local_1_56, %loop2 ] 124 %i9 = add nuw nsw i32 %local_0_, 1 125 %i10 = icmp ugt i32 %local_0_, 129 126 br i1 %i10, label %exit, label %loop1 127 128exit: ; preds = %loop2.exit, %loop1 129 ret i32 0 130} 131