1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -analyze -basicaa -da | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; ModuleID = 'SymbolicRDIV.bc' 4*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128" 5*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-macosx10.6.0" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker;; for (long int i = 0; i < n1; i++) 9*9880d681SAndroid Build Coastguard Worker;; A[2*i + n1] = i; 10*9880d681SAndroid Build Coastguard Worker;; for (long int j = 0; j < n2; j++) 11*9880d681SAndroid Build Coastguard Worker;; *B++ = A[3*j + 3*n1]; 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv0(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp { 14*9880d681SAndroid Build Coastguard Workerentry: 15*9880d681SAndroid Build Coastguard Worker %cmp4 = icmp eq i64 %n1, 0 16*9880d681SAndroid Build Coastguard Worker br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv0' 19*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 20*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 21*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 22*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 23*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 24*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 27*9880d681SAndroid Build Coastguard Worker br label %for.body 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit: ; preds = %for.body 30*9880d681SAndroid Build Coastguard Worker br label %for.cond1.preheader 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader: ; preds = %for.cond1.preheader.loopexit, %entry 33*9880d681SAndroid Build Coastguard Worker %cmp21 = icmp eq i64 %n2, 0 34*9880d681SAndroid Build Coastguard Worker br i1 %cmp21, label %for.end11, label %for.body4.preheader 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Workerfor.body4.preheader: ; preds = %for.cond1.preheader 37*9880d681SAndroid Build Coastguard Worker br label %for.body4 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 40*9880d681SAndroid Build Coastguard Worker %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ] 41*9880d681SAndroid Build Coastguard Worker %conv = trunc i64 %i.05 to i32 42*9880d681SAndroid Build Coastguard Worker %mul = shl nsw i64 %i.05, 1 43*9880d681SAndroid Build Coastguard Worker %add = add i64 %mul, %n1 44*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add 45*9880d681SAndroid Build Coastguard Worker store i32 %conv, i32* %arrayidx, align 4 46*9880d681SAndroid Build Coastguard Worker %inc = add nsw i64 %i.05, 1 47*9880d681SAndroid Build Coastguard Worker %exitcond = icmp ne i64 %inc, %n1 48*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Workerfor.body4: ; preds = %for.body4.preheader, %for.body4 51*9880d681SAndroid Build Coastguard Worker %j.03 = phi i64 [ %inc10, %for.body4 ], [ 0, %for.body4.preheader ] 52*9880d681SAndroid Build Coastguard Worker %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ] 53*9880d681SAndroid Build Coastguard Worker %mul56 = add i64 %j.03, %n1 54*9880d681SAndroid Build Coastguard Worker %add7 = mul i64 %mul56, 3 55*9880d681SAndroid Build Coastguard Worker %arrayidx8 = getelementptr inbounds i32, i32* %A, i64 %add7 56*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx8, align 4 57*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1 58*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %B.addr.02, align 4 59*9880d681SAndroid Build Coastguard Worker %inc10 = add nsw i64 %j.03, 1 60*9880d681SAndroid Build Coastguard Worker %exitcond7 = icmp ne i64 %inc10, %n2 61*9880d681SAndroid Build Coastguard Worker br i1 %exitcond7, label %for.body4, label %for.end11.loopexit 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Workerfor.end11.loopexit: ; preds = %for.body4 64*9880d681SAndroid Build Coastguard Worker br label %for.end11 65*9880d681SAndroid Build Coastguard Worker 66*9880d681SAndroid Build Coastguard Workerfor.end11: ; preds = %for.end11.loopexit, %for.cond1.preheader 67*9880d681SAndroid Build Coastguard Worker ret void 68*9880d681SAndroid Build Coastguard Worker} 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Worker;; for (long int i = 0; i < n1; i++) 72*9880d681SAndroid Build Coastguard Worker;; A[2*i + 5*n2] = i; 73*9880d681SAndroid Build Coastguard Worker;; for (long int j = 0; j < n2; j++) 74*9880d681SAndroid Build Coastguard Worker;; *B++ = A[3*j + 2*n2]; 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv1(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp { 77*9880d681SAndroid Build Coastguard Workerentry: 78*9880d681SAndroid Build Coastguard Worker %cmp4 = icmp eq i64 %n1, 0 79*9880d681SAndroid Build Coastguard Worker br i1 %cmp4, label %for.cond2.preheader, label %for.body.preheader 80*9880d681SAndroid Build Coastguard Worker 81*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv1' 82*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 83*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 84*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 85*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 86*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 87*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 88*9880d681SAndroid Build Coastguard Worker 89*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 90*9880d681SAndroid Build Coastguard Worker br label %for.body 91*9880d681SAndroid Build Coastguard Worker 92*9880d681SAndroid Build Coastguard Workerfor.cond2.preheader.loopexit: ; preds = %for.body 93*9880d681SAndroid Build Coastguard Worker br label %for.cond2.preheader 94*9880d681SAndroid Build Coastguard Worker 95*9880d681SAndroid Build Coastguard Workerfor.cond2.preheader: ; preds = %for.cond2.preheader.loopexit, %entry 96*9880d681SAndroid Build Coastguard Worker %cmp31 = icmp eq i64 %n2, 0 97*9880d681SAndroid Build Coastguard Worker br i1 %cmp31, label %for.end12, label %for.body5.preheader 98*9880d681SAndroid Build Coastguard Worker 99*9880d681SAndroid Build Coastguard Workerfor.body5.preheader: ; preds = %for.cond2.preheader 100*9880d681SAndroid Build Coastguard Worker br label %for.body5 101*9880d681SAndroid Build Coastguard Worker 102*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 103*9880d681SAndroid Build Coastguard Worker %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ] 104*9880d681SAndroid Build Coastguard Worker %conv = trunc i64 %i.05 to i32 105*9880d681SAndroid Build Coastguard Worker %mul = shl nsw i64 %i.05, 1 106*9880d681SAndroid Build Coastguard Worker %mul1 = mul i64 %n2, 5 107*9880d681SAndroid Build Coastguard Worker %add = add i64 %mul, %mul1 108*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add 109*9880d681SAndroid Build Coastguard Worker store i32 %conv, i32* %arrayidx, align 4 110*9880d681SAndroid Build Coastguard Worker %inc = add nsw i64 %i.05, 1 111*9880d681SAndroid Build Coastguard Worker %exitcond = icmp ne i64 %inc, %n1 112*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.body, label %for.cond2.preheader.loopexit 113*9880d681SAndroid Build Coastguard Worker 114*9880d681SAndroid Build Coastguard Workerfor.body5: ; preds = %for.body5.preheader, %for.body5 115*9880d681SAndroid Build Coastguard Worker %j.03 = phi i64 [ %inc11, %for.body5 ], [ 0, %for.body5.preheader ] 116*9880d681SAndroid Build Coastguard Worker %B.addr.02 = phi i32* [ %incdec.ptr, %for.body5 ], [ %B, %for.body5.preheader ] 117*9880d681SAndroid Build Coastguard Worker %mul6 = mul nsw i64 %j.03, 3 118*9880d681SAndroid Build Coastguard Worker %mul7 = shl i64 %n2, 1 119*9880d681SAndroid Build Coastguard Worker %add8 = add i64 %mul6, %mul7 120*9880d681SAndroid Build Coastguard Worker %arrayidx9 = getelementptr inbounds i32, i32* %A, i64 %add8 121*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx9, align 4 122*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1 123*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %B.addr.02, align 4 124*9880d681SAndroid Build Coastguard Worker %inc11 = add nsw i64 %j.03, 1 125*9880d681SAndroid Build Coastguard Worker %exitcond6 = icmp ne i64 %inc11, %n2 126*9880d681SAndroid Build Coastguard Worker br i1 %exitcond6, label %for.body5, label %for.end12.loopexit 127*9880d681SAndroid Build Coastguard Worker 128*9880d681SAndroid Build Coastguard Workerfor.end12.loopexit: ; preds = %for.body5 129*9880d681SAndroid Build Coastguard Worker br label %for.end12 130*9880d681SAndroid Build Coastguard Worker 131*9880d681SAndroid Build Coastguard Workerfor.end12: ; preds = %for.end12.loopexit, %for.cond2.preheader 132*9880d681SAndroid Build Coastguard Worker ret void 133*9880d681SAndroid Build Coastguard Worker} 134*9880d681SAndroid Build Coastguard Worker 135*9880d681SAndroid Build Coastguard Worker 136*9880d681SAndroid Build Coastguard Worker;; for (long int i = 0; i < n1; i++) 137*9880d681SAndroid Build Coastguard Worker;; A[2*i - n2] = i; 138*9880d681SAndroid Build Coastguard Worker;; for (long int j = 0; j < n2; j++) 139*9880d681SAndroid Build Coastguard Worker;; *B++ = A[-j + 2*n1]; 140*9880d681SAndroid Build Coastguard Worker 141*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv2(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp { 142*9880d681SAndroid Build Coastguard Workerentry: 143*9880d681SAndroid Build Coastguard Worker %cmp4 = icmp eq i64 %n1, 0 144*9880d681SAndroid Build Coastguard Worker br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader 145*9880d681SAndroid Build Coastguard Worker 146*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv2' 147*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 148*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 149*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 150*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 151*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 152*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 153*9880d681SAndroid Build Coastguard Worker 154*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 155*9880d681SAndroid Build Coastguard Worker br label %for.body 156*9880d681SAndroid Build Coastguard Worker 157*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit: ; preds = %for.body 158*9880d681SAndroid Build Coastguard Worker br label %for.cond1.preheader 159*9880d681SAndroid Build Coastguard Worker 160*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader: ; preds = %for.cond1.preheader.loopexit, %entry 161*9880d681SAndroid Build Coastguard Worker %cmp21 = icmp eq i64 %n2, 0 162*9880d681SAndroid Build Coastguard Worker br i1 %cmp21, label %for.end10, label %for.body4.preheader 163*9880d681SAndroid Build Coastguard Worker 164*9880d681SAndroid Build Coastguard Workerfor.body4.preheader: ; preds = %for.cond1.preheader 165*9880d681SAndroid Build Coastguard Worker br label %for.body4 166*9880d681SAndroid Build Coastguard Worker 167*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 168*9880d681SAndroid Build Coastguard Worker %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ] 169*9880d681SAndroid Build Coastguard Worker %conv = trunc i64 %i.05 to i32 170*9880d681SAndroid Build Coastguard Worker %mul = shl nsw i64 %i.05, 1 171*9880d681SAndroid Build Coastguard Worker %sub = sub i64 %mul, %n2 172*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %A, i64 %sub 173*9880d681SAndroid Build Coastguard Worker store i32 %conv, i32* %arrayidx, align 4 174*9880d681SAndroid Build Coastguard Worker %inc = add nsw i64 %i.05, 1 175*9880d681SAndroid Build Coastguard Worker %exitcond = icmp ne i64 %inc, %n1 176*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit 177*9880d681SAndroid Build Coastguard Worker 178*9880d681SAndroid Build Coastguard Workerfor.body4: ; preds = %for.body4.preheader, %for.body4 179*9880d681SAndroid Build Coastguard Worker %j.03 = phi i64 [ %inc9, %for.body4 ], [ 0, %for.body4.preheader ] 180*9880d681SAndroid Build Coastguard Worker %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ] 181*9880d681SAndroid Build Coastguard Worker %mul6 = shl i64 %n1, 1 182*9880d681SAndroid Build Coastguard Worker %add = sub i64 %mul6, %j.03 183*9880d681SAndroid Build Coastguard Worker %arrayidx7 = getelementptr inbounds i32, i32* %A, i64 %add 184*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx7, align 4 185*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1 186*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %B.addr.02, align 4 187*9880d681SAndroid Build Coastguard Worker %inc9 = add nsw i64 %j.03, 1 188*9880d681SAndroid Build Coastguard Worker %exitcond6 = icmp ne i64 %inc9, %n2 189*9880d681SAndroid Build Coastguard Worker br i1 %exitcond6, label %for.body4, label %for.end10.loopexit 190*9880d681SAndroid Build Coastguard Worker 191*9880d681SAndroid Build Coastguard Workerfor.end10.loopexit: ; preds = %for.body4 192*9880d681SAndroid Build Coastguard Worker br label %for.end10 193*9880d681SAndroid Build Coastguard Worker 194*9880d681SAndroid Build Coastguard Workerfor.end10: ; preds = %for.end10.loopexit, %for.cond1.preheader 195*9880d681SAndroid Build Coastguard Worker ret void 196*9880d681SAndroid Build Coastguard Worker} 197*9880d681SAndroid Build Coastguard Worker 198*9880d681SAndroid Build Coastguard Worker 199*9880d681SAndroid Build Coastguard Worker;; for (long int i = 0; i < n1; i++) 200*9880d681SAndroid Build Coastguard Worker;; A[-i + n2] = i; 201*9880d681SAndroid Build Coastguard Worker;; for (long int j = 0; j < n2; j++) 202*9880d681SAndroid Build Coastguard Worker;; *B++ = A[j - n1]; 203*9880d681SAndroid Build Coastguard Worker 204*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv3(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp { 205*9880d681SAndroid Build Coastguard Workerentry: 206*9880d681SAndroid Build Coastguard Worker %cmp4 = icmp eq i64 %n1, 0 207*9880d681SAndroid Build Coastguard Worker br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader 208*9880d681SAndroid Build Coastguard Worker 209*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv3' 210*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 211*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 212*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 213*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 214*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 215*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 216*9880d681SAndroid Build Coastguard Worker 217*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 218*9880d681SAndroid Build Coastguard Worker br label %for.body 219*9880d681SAndroid Build Coastguard Worker 220*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit: ; preds = %for.body 221*9880d681SAndroid Build Coastguard Worker br label %for.cond1.preheader 222*9880d681SAndroid Build Coastguard Worker 223*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader: ; preds = %for.cond1.preheader.loopexit, %entry 224*9880d681SAndroid Build Coastguard Worker %cmp21 = icmp eq i64 %n2, 0 225*9880d681SAndroid Build Coastguard Worker br i1 %cmp21, label %for.end9, label %for.body4.preheader 226*9880d681SAndroid Build Coastguard Worker 227*9880d681SAndroid Build Coastguard Workerfor.body4.preheader: ; preds = %for.cond1.preheader 228*9880d681SAndroid Build Coastguard Worker br label %for.body4 229*9880d681SAndroid Build Coastguard Worker 230*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 231*9880d681SAndroid Build Coastguard Worker %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ] 232*9880d681SAndroid Build Coastguard Worker %conv = trunc i64 %i.05 to i32 233*9880d681SAndroid Build Coastguard Worker %add = sub i64 %n2, %i.05 234*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add 235*9880d681SAndroid Build Coastguard Worker store i32 %conv, i32* %arrayidx, align 4 236*9880d681SAndroid Build Coastguard Worker %inc = add nsw i64 %i.05, 1 237*9880d681SAndroid Build Coastguard Worker %exitcond = icmp ne i64 %inc, %n1 238*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit 239*9880d681SAndroid Build Coastguard Worker 240*9880d681SAndroid Build Coastguard Workerfor.body4: ; preds = %for.body4.preheader, %for.body4 241*9880d681SAndroid Build Coastguard Worker %j.03 = phi i64 [ %inc8, %for.body4 ], [ 0, %for.body4.preheader ] 242*9880d681SAndroid Build Coastguard Worker %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ] 243*9880d681SAndroid Build Coastguard Worker %sub5 = sub i64 %j.03, %n1 244*9880d681SAndroid Build Coastguard Worker %arrayidx6 = getelementptr inbounds i32, i32* %A, i64 %sub5 245*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx6, align 4 246*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1 247*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %B.addr.02, align 4 248*9880d681SAndroid Build Coastguard Worker %inc8 = add nsw i64 %j.03, 1 249*9880d681SAndroid Build Coastguard Worker %exitcond6 = icmp ne i64 %inc8, %n2 250*9880d681SAndroid Build Coastguard Worker br i1 %exitcond6, label %for.body4, label %for.end9.loopexit 251*9880d681SAndroid Build Coastguard Worker 252*9880d681SAndroid Build Coastguard Workerfor.end9.loopexit: ; preds = %for.body4 253*9880d681SAndroid Build Coastguard Worker br label %for.end9 254*9880d681SAndroid Build Coastguard Worker 255*9880d681SAndroid Build Coastguard Workerfor.end9: ; preds = %for.end9.loopexit, %for.cond1.preheader 256*9880d681SAndroid Build Coastguard Worker ret void 257*9880d681SAndroid Build Coastguard Worker} 258*9880d681SAndroid Build Coastguard Worker 259*9880d681SAndroid Build Coastguard Worker 260*9880d681SAndroid Build Coastguard Worker;; for (long int i = 0; i < n1; i++) 261*9880d681SAndroid Build Coastguard Worker;; A[-i + 2*n1] = i; 262*9880d681SAndroid Build Coastguard Worker;; for (long int j = 0; j < n2; j++) 263*9880d681SAndroid Build Coastguard Worker;; *B++ = A[-j + n1]; 264*9880d681SAndroid Build Coastguard Worker 265*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv4(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp { 266*9880d681SAndroid Build Coastguard Workerentry: 267*9880d681SAndroid Build Coastguard Worker %cmp4 = icmp eq i64 %n1, 0 268*9880d681SAndroid Build Coastguard Worker br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader 269*9880d681SAndroid Build Coastguard Worker 270*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv4' 271*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 272*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 273*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 274*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 275*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 276*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 277*9880d681SAndroid Build Coastguard Worker 278*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 279*9880d681SAndroid Build Coastguard Worker br label %for.body 280*9880d681SAndroid Build Coastguard Worker 281*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit: ; preds = %for.body 282*9880d681SAndroid Build Coastguard Worker br label %for.cond1.preheader 283*9880d681SAndroid Build Coastguard Worker 284*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader: ; preds = %for.cond1.preheader.loopexit, %entry 285*9880d681SAndroid Build Coastguard Worker %cmp21 = icmp eq i64 %n2, 0 286*9880d681SAndroid Build Coastguard Worker br i1 %cmp21, label %for.end10, label %for.body4.preheader 287*9880d681SAndroid Build Coastguard Worker 288*9880d681SAndroid Build Coastguard Workerfor.body4.preheader: ; preds = %for.cond1.preheader 289*9880d681SAndroid Build Coastguard Worker br label %for.body4 290*9880d681SAndroid Build Coastguard Worker 291*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 292*9880d681SAndroid Build Coastguard Worker %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ] 293*9880d681SAndroid Build Coastguard Worker %conv = trunc i64 %i.05 to i32 294*9880d681SAndroid Build Coastguard Worker %mul = shl i64 %n1, 1 295*9880d681SAndroid Build Coastguard Worker %add = sub i64 %mul, %i.05 296*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add 297*9880d681SAndroid Build Coastguard Worker store i32 %conv, i32* %arrayidx, align 4 298*9880d681SAndroid Build Coastguard Worker %inc = add nsw i64 %i.05, 1 299*9880d681SAndroid Build Coastguard Worker %exitcond = icmp ne i64 %inc, %n1 300*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit 301*9880d681SAndroid Build Coastguard Worker 302*9880d681SAndroid Build Coastguard Workerfor.body4: ; preds = %for.body4.preheader, %for.body4 303*9880d681SAndroid Build Coastguard Worker %j.03 = phi i64 [ %inc9, %for.body4 ], [ 0, %for.body4.preheader ] 304*9880d681SAndroid Build Coastguard Worker %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ] 305*9880d681SAndroid Build Coastguard Worker %add6 = sub i64 %n1, %j.03 306*9880d681SAndroid Build Coastguard Worker %arrayidx7 = getelementptr inbounds i32, i32* %A, i64 %add6 307*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx7, align 4 308*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1 309*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %B.addr.02, align 4 310*9880d681SAndroid Build Coastguard Worker %inc9 = add nsw i64 %j.03, 1 311*9880d681SAndroid Build Coastguard Worker %exitcond6 = icmp ne i64 %inc9, %n2 312*9880d681SAndroid Build Coastguard Worker br i1 %exitcond6, label %for.body4, label %for.end10.loopexit 313*9880d681SAndroid Build Coastguard Worker 314*9880d681SAndroid Build Coastguard Workerfor.end10.loopexit: ; preds = %for.body4 315*9880d681SAndroid Build Coastguard Worker br label %for.end10 316*9880d681SAndroid Build Coastguard Worker 317*9880d681SAndroid Build Coastguard Workerfor.end10: ; preds = %for.end10.loopexit, %for.cond1.preheader 318*9880d681SAndroid Build Coastguard Worker ret void 319*9880d681SAndroid Build Coastguard Worker} 320*9880d681SAndroid Build Coastguard Worker 321*9880d681SAndroid Build Coastguard Worker 322*9880d681SAndroid Build Coastguard Worker;; for (long int i = 0; i < n1; i++) 323*9880d681SAndroid Build Coastguard Worker;; A[-i + n2] = i; 324*9880d681SAndroid Build Coastguard Worker;; for (long int j = 0; j < n2; j++) 325*9880d681SAndroid Build Coastguard Worker;; *B++ = A[-j + 2*n2]; 326*9880d681SAndroid Build Coastguard Worker 327*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv5(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp { 328*9880d681SAndroid Build Coastguard Workerentry: 329*9880d681SAndroid Build Coastguard Worker %cmp4 = icmp eq i64 %n1, 0 330*9880d681SAndroid Build Coastguard Worker br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader 331*9880d681SAndroid Build Coastguard Worker 332*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv5' 333*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 334*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 335*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 336*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 337*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 338*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 339*9880d681SAndroid Build Coastguard Worker 340*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 341*9880d681SAndroid Build Coastguard Worker br label %for.body 342*9880d681SAndroid Build Coastguard Worker 343*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit: ; preds = %for.body 344*9880d681SAndroid Build Coastguard Worker br label %for.cond1.preheader 345*9880d681SAndroid Build Coastguard Worker 346*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader: ; preds = %for.cond1.preheader.loopexit, %entry 347*9880d681SAndroid Build Coastguard Worker %cmp21 = icmp eq i64 %n2, 0 348*9880d681SAndroid Build Coastguard Worker br i1 %cmp21, label %for.end10, label %for.body4.preheader 349*9880d681SAndroid Build Coastguard Worker 350*9880d681SAndroid Build Coastguard Workerfor.body4.preheader: ; preds = %for.cond1.preheader 351*9880d681SAndroid Build Coastguard Worker br label %for.body4 352*9880d681SAndroid Build Coastguard Worker 353*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 354*9880d681SAndroid Build Coastguard Worker %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ] 355*9880d681SAndroid Build Coastguard Worker %conv = trunc i64 %i.05 to i32 356*9880d681SAndroid Build Coastguard Worker %add = sub i64 %n2, %i.05 357*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add 358*9880d681SAndroid Build Coastguard Worker store i32 %conv, i32* %arrayidx, align 4 359*9880d681SAndroid Build Coastguard Worker %inc = add nsw i64 %i.05, 1 360*9880d681SAndroid Build Coastguard Worker %exitcond = icmp ne i64 %inc, %n1 361*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit 362*9880d681SAndroid Build Coastguard Worker 363*9880d681SAndroid Build Coastguard Workerfor.body4: ; preds = %for.body4.preheader, %for.body4 364*9880d681SAndroid Build Coastguard Worker %j.03 = phi i64 [ %inc9, %for.body4 ], [ 0, %for.body4.preheader ] 365*9880d681SAndroid Build Coastguard Worker %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ] 366*9880d681SAndroid Build Coastguard Worker %mul = shl i64 %n2, 1 367*9880d681SAndroid Build Coastguard Worker %add6 = sub i64 %mul, %j.03 368*9880d681SAndroid Build Coastguard Worker %arrayidx7 = getelementptr inbounds i32, i32* %A, i64 %add6 369*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx7, align 4 370*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1 371*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %B.addr.02, align 4 372*9880d681SAndroid Build Coastguard Worker %inc9 = add nsw i64 %j.03, 1 373*9880d681SAndroid Build Coastguard Worker %exitcond6 = icmp ne i64 %inc9, %n2 374*9880d681SAndroid Build Coastguard Worker br i1 %exitcond6, label %for.body4, label %for.end10.loopexit 375*9880d681SAndroid Build Coastguard Worker 376*9880d681SAndroid Build Coastguard Workerfor.end10.loopexit: ; preds = %for.body4 377*9880d681SAndroid Build Coastguard Worker br label %for.end10 378*9880d681SAndroid Build Coastguard Worker 379*9880d681SAndroid Build Coastguard Workerfor.end10: ; preds = %for.end10.loopexit, %for.cond1.preheader 380*9880d681SAndroid Build Coastguard Worker ret void 381*9880d681SAndroid Build Coastguard Worker} 382*9880d681SAndroid Build Coastguard Worker 383*9880d681SAndroid Build Coastguard Worker 384*9880d681SAndroid Build Coastguard Worker;; for (long int i = 0; i < n1; i++) 385*9880d681SAndroid Build Coastguard Worker;; for (long int j = 0; j < n2; j++) { 386*9880d681SAndroid Build Coastguard Worker;; A[j -i + n2] = i; 387*9880d681SAndroid Build Coastguard Worker;; *B++ = A[2*n2]; 388*9880d681SAndroid Build Coastguard Worker 389*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv6(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp { 390*9880d681SAndroid Build Coastguard Workerentry: 391*9880d681SAndroid Build Coastguard Worker %cmp4 = icmp eq i64 %n1, 0 392*9880d681SAndroid Build Coastguard Worker br i1 %cmp4, label %for.end7, label %for.cond1.preheader.preheader 393*9880d681SAndroid Build Coastguard Worker 394*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv6' 395*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - output [* *]! 396*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none! 397*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 398*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - consistent input [S S]! 399*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused! 400*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - output [* *]! 401*9880d681SAndroid Build Coastguard Worker 402*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.preheader: ; preds = %entry 403*9880d681SAndroid Build Coastguard Worker br label %for.cond1.preheader 404*9880d681SAndroid Build Coastguard Worker 405*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader: ; preds = %for.cond1.preheader.preheader, %for.inc5 406*9880d681SAndroid Build Coastguard Worker %B.addr.06 = phi i32* [ %B.addr.1.lcssa, %for.inc5 ], [ %B, %for.cond1.preheader.preheader ] 407*9880d681SAndroid Build Coastguard Worker %i.05 = phi i64 [ %inc6, %for.inc5 ], [ 0, %for.cond1.preheader.preheader ] 408*9880d681SAndroid Build Coastguard Worker %cmp21 = icmp eq i64 %n2, 0 409*9880d681SAndroid Build Coastguard Worker br i1 %cmp21, label %for.inc5, label %for.body3.preheader 410*9880d681SAndroid Build Coastguard Worker 411*9880d681SAndroid Build Coastguard Workerfor.body3.preheader: ; preds = %for.cond1.preheader 412*9880d681SAndroid Build Coastguard Worker br label %for.body3 413*9880d681SAndroid Build Coastguard Worker 414*9880d681SAndroid Build Coastguard Workerfor.body3: ; preds = %for.body3.preheader, %for.body3 415*9880d681SAndroid Build Coastguard Worker %j.03 = phi i64 [ %inc, %for.body3 ], [ 0, %for.body3.preheader ] 416*9880d681SAndroid Build Coastguard Worker %B.addr.12 = phi i32* [ %incdec.ptr, %for.body3 ], [ %B.addr.06, %for.body3.preheader ] 417*9880d681SAndroid Build Coastguard Worker %conv = trunc i64 %i.05 to i32 418*9880d681SAndroid Build Coastguard Worker %sub = sub nsw i64 %j.03, %i.05 419*9880d681SAndroid Build Coastguard Worker %add = add i64 %sub, %n2 420*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add 421*9880d681SAndroid Build Coastguard Worker store i32 %conv, i32* %arrayidx, align 4 422*9880d681SAndroid Build Coastguard Worker %mul = shl i64 %n2, 1 423*9880d681SAndroid Build Coastguard Worker %arrayidx4 = getelementptr inbounds i32, i32* %A, i64 %mul 424*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %arrayidx4, align 4 425*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.12, i64 1 426*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %B.addr.12, align 4 427*9880d681SAndroid Build Coastguard Worker %inc = add nsw i64 %j.03, 1 428*9880d681SAndroid Build Coastguard Worker %exitcond = icmp ne i64 %inc, %n2 429*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %for.body3, label %for.inc5.loopexit 430*9880d681SAndroid Build Coastguard Worker 431*9880d681SAndroid Build Coastguard Workerfor.inc5.loopexit: ; preds = %for.body3 432*9880d681SAndroid Build Coastguard Worker %scevgep = getelementptr i32, i32* %B.addr.06, i64 %n2 433*9880d681SAndroid Build Coastguard Worker br label %for.inc5 434*9880d681SAndroid Build Coastguard Worker 435*9880d681SAndroid Build Coastguard Workerfor.inc5: ; preds = %for.inc5.loopexit, %for.cond1.preheader 436*9880d681SAndroid Build Coastguard Worker %B.addr.1.lcssa = phi i32* [ %B.addr.06, %for.cond1.preheader ], [ %scevgep, %for.inc5.loopexit ] 437*9880d681SAndroid Build Coastguard Worker %inc6 = add nsw i64 %i.05, 1 438*9880d681SAndroid Build Coastguard Worker %exitcond7 = icmp ne i64 %inc6, %n1 439*9880d681SAndroid Build Coastguard Worker br i1 %exitcond7, label %for.cond1.preheader, label %for.end7.loopexit 440*9880d681SAndroid Build Coastguard Worker 441*9880d681SAndroid Build Coastguard Workerfor.end7.loopexit: ; preds = %for.inc5 442*9880d681SAndroid Build Coastguard Worker br label %for.end7 443*9880d681SAndroid Build Coastguard Worker 444*9880d681SAndroid Build Coastguard Workerfor.end7: ; preds = %for.end7.loopexit, %entry 445*9880d681SAndroid Build Coastguard Worker ret void 446*9880d681SAndroid Build Coastguard Worker} 447