1*9880d681SAndroid Build Coastguard Worker; RUN: opt -S < %s -loop-unroll -unroll-count=4 | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; 3*9880d681SAndroid Build Coastguard Worker; Test induction variable simplify after loop unrolling. It should 4*9880d681SAndroid Build Coastguard Worker; expose nice opportunities for GVN. 5*9880d681SAndroid Build Coastguard Worker; 6*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: while.body also ensures that loop unrolling (with SCEV) 7*9880d681SAndroid Build Coastguard Worker; removes unrolled loop exits given that 128 is a multiple of 4. 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f80:128:128-v64:64:64-v128:128:128-a0:0:64-f80:32:32-n8:16:32" 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker; PR10534: LoopUnroll not keeping canonical induction variable... 12*9880d681SAndroid Build Coastguard Worker; CHECK: while.body: 13*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: while.body.1: 14*9880d681SAndroid Build Coastguard Worker; CHECK: %shr.1 = lshr i32 %bit_addr.addr.01, 5 15*9880d681SAndroid Build Coastguard Worker; CHECK: %arrayidx.1 = getelementptr inbounds i32, i32* %bitmap, i32 %shr.1 16*9880d681SAndroid Build Coastguard Worker; CHECK: %shr.2 = lshr i32 %bit_addr.addr.01, 5 17*9880d681SAndroid Build Coastguard Worker; CHECK: %arrayidx.2 = getelementptr inbounds i32, i32* %bitmap, i32 %shr.2 18*9880d681SAndroid Build Coastguard Worker; CHECK: %shr.3 = lshr i32 %bit_addr.addr.01, 5 19*9880d681SAndroid Build Coastguard Worker; CHECK: %arrayidx.3 = getelementptr inbounds i32, i32* %bitmap, i32 %shr.3 20*9880d681SAndroid Build Coastguard Workerdefine void @FlipBit(i32* nocapture %bitmap, i32 %bit_addr, i32 %nbits) nounwind { 21*9880d681SAndroid Build Coastguard Workerentry: 22*9880d681SAndroid Build Coastguard Worker br label %while.body 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Workerwhile.body: 25*9880d681SAndroid Build Coastguard Worker %nbits.addr.02 = phi i32 [ 128, %entry ], [ %dec, %while.body ] 26*9880d681SAndroid Build Coastguard Worker %bit_addr.addr.01 = phi i32 [ 0, %entry ], [ %inc, %while.body ] 27*9880d681SAndroid Build Coastguard Worker %dec = add i32 %nbits.addr.02, -1 28*9880d681SAndroid Build Coastguard Worker %shr = lshr i32 %bit_addr.addr.01, 5 29*9880d681SAndroid Build Coastguard Worker %rem = and i32 %bit_addr.addr.01, 31 30*9880d681SAndroid Build Coastguard Worker %shl = shl i32 1, %rem 31*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %bitmap, i32 %shr 32*9880d681SAndroid Build Coastguard Worker %tmp6 = load i32, i32* %arrayidx, align 4 33*9880d681SAndroid Build Coastguard Worker %xor = xor i32 %tmp6, %shl 34*9880d681SAndroid Build Coastguard Worker store i32 %xor, i32* %arrayidx, align 4 35*9880d681SAndroid Build Coastguard Worker %inc = add i32 %bit_addr.addr.01, 1 36*9880d681SAndroid Build Coastguard Worker %tobool = icmp eq i32 %dec, 0 37*9880d681SAndroid Build Coastguard Worker br i1 %tobool, label %while.end, label %while.body 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Workerwhile.end: 40*9880d681SAndroid Build Coastguard Worker ret void 41*9880d681SAndroid Build Coastguard Worker} 42