1*9880d681SAndroid Build Coastguard Worker; RUN: opt -basicaa -loop-idiom < %s -S | FileCheck %s 2*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" 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; CHECK @.memset_pattern = private unnamed_addr constant [4 x i32] [i32 2, i32 2, i32 2, i32 2], align 16 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-darwin10.0.0" 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker;void test(int *f, unsigned n) { 9*9880d681SAndroid Build Coastguard Worker; for (unsigned i = 0; i < 2 * n; i += 2) { 10*9880d681SAndroid Build Coastguard Worker; f[i] = 0; 11*9880d681SAndroid Build Coastguard Worker; f[i+1] = 0; 12*9880d681SAndroid Build Coastguard Worker; } 13*9880d681SAndroid Build Coastguard Worker;} 14*9880d681SAndroid Build Coastguard Workerdefine void @test(i32* %f, i32 %n) nounwind ssp { 15*9880d681SAndroid Build Coastguard Workerentry: 16*9880d681SAndroid Build Coastguard Worker %mul = shl i32 %n, 1 17*9880d681SAndroid Build Coastguard Worker %cmp1 = icmp eq i32 %mul, 0 18*9880d681SAndroid Build Coastguard Worker br i1 %cmp1, label %for.end, label %for.body.preheader 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 21*9880d681SAndroid Build Coastguard Worker %0 = zext i32 %mul to i64 22*9880d681SAndroid Build Coastguard Worker br label %for.body 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 25*9880d681SAndroid Build Coastguard Worker %indvars.iv = phi i64 [ 0, %for.body.preheader ], [ %indvars.iv.next, %for.body ] 26*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %f, i64 %indvars.iv 27*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %arrayidx, align 4 28*9880d681SAndroid Build Coastguard Worker %1 = or i64 %indvars.iv, 1 29*9880d681SAndroid Build Coastguard Worker %arrayidx2 = getelementptr inbounds i32, i32* %f, i64 %1 30*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %arrayidx2, align 4 31*9880d681SAndroid Build Coastguard Worker %indvars.iv.next = add nuw nsw i64 %indvars.iv, 2 32*9880d681SAndroid Build Coastguard Worker %cmp = icmp ult i64 %indvars.iv.next, %0 33*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %for.body, label %for.end.loopexit 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Workerfor.end.loopexit: ; preds = %for.body 36*9880d681SAndroid Build Coastguard Worker br label %for.end 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Workerfor.end: ; preds = %for.end.loopexit, %entry 39*9880d681SAndroid Build Coastguard Worker ret void 40*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test( 41*9880d681SAndroid Build Coastguard Worker; CHECK: call void @llvm.memset 42*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: store 43*9880d681SAndroid Build Coastguard Worker} 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker;void test_pattern(int *f, unsigned n) { 46*9880d681SAndroid Build Coastguard Worker; for (unsigned i = 0; i < 2 * n; i += 2) { 47*9880d681SAndroid Build Coastguard Worker; f[i] = 2; 48*9880d681SAndroid Build Coastguard Worker; f[i+1] = 2; 49*9880d681SAndroid Build Coastguard Worker; } 50*9880d681SAndroid Build Coastguard Worker;} 51*9880d681SAndroid Build Coastguard Workerdefine void @test_pattern(i32* %f, i32 %n) nounwind ssp { 52*9880d681SAndroid Build Coastguard Workerentry: 53*9880d681SAndroid Build Coastguard Worker %mul = shl i32 %n, 1 54*9880d681SAndroid Build Coastguard Worker %cmp1 = icmp eq i32 %mul, 0 55*9880d681SAndroid Build Coastguard Worker br i1 %cmp1, label %for.end, label %for.body.preheader 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 58*9880d681SAndroid Build Coastguard Worker %0 = zext i32 %mul to i64 59*9880d681SAndroid Build Coastguard Worker br label %for.body 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body.preheader, %for.body 62*9880d681SAndroid Build Coastguard Worker %indvars.iv = phi i64 [ 0, %for.body.preheader ], [ %indvars.iv.next, %for.body ] 63*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %f, i64 %indvars.iv 64*9880d681SAndroid Build Coastguard Worker store i32 2, i32* %arrayidx, align 4 65*9880d681SAndroid Build Coastguard Worker %1 = or i64 %indvars.iv, 1 66*9880d681SAndroid Build Coastguard Worker %arrayidx2 = getelementptr inbounds i32, i32* %f, i64 %1 67*9880d681SAndroid Build Coastguard Worker store i32 2, i32* %arrayidx2, align 4 68*9880d681SAndroid Build Coastguard Worker %indvars.iv.next = add nuw nsw i64 %indvars.iv, 2 69*9880d681SAndroid Build Coastguard Worker %cmp = icmp ult i64 %indvars.iv.next, %0 70*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %for.body, label %for.end.loopexit 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Workerfor.end.loopexit: ; preds = %for.body 73*9880d681SAndroid Build Coastguard Worker br label %for.end 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Workerfor.end: ; preds = %for.end.loopexit, %entry 76*9880d681SAndroid Build Coastguard Worker ret void 77*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test_pattern( 78*9880d681SAndroid Build Coastguard Worker; CHECK: call void @memset_pattern16 79*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: store 80*9880d681SAndroid Build Coastguard Worker} 81