1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon < %s 2*9880d681SAndroid Build Coastguard Worker; REQUIRES: asserts 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workertarget triple = "hexagon" 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Workerdeclare i8* @llvm.hexagon.circ.ldb(i8*, i8*, i32, i32) #1 7*9880d681SAndroid Build Coastguard Workerdeclare i8* @llvm.hexagon.circ.stb(i8*, i32, i32, i32) #1 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Workerdefine zeroext i8 @circular_loop_test10(i8* %A, i8* %B, i32 %x, i32 %y, i32 %z, i32 %w) #0 { 10*9880d681SAndroid Build Coastguard Workerentry: 11*9880d681SAndroid Build Coastguard Worker %element_load0 = alloca i8, align 1 12*9880d681SAndroid Build Coastguard Worker %element_load2 = alloca i8, align 1 13*9880d681SAndroid Build Coastguard Worker %element_load3 = alloca i8, align 1 14*9880d681SAndroid Build Coastguard Worker %element_load5 = alloca i8, align 1 15*9880d681SAndroid Build Coastguard Worker %or = or i32 %x, 100663296 16*9880d681SAndroid Build Coastguard Worker %or5 = or i32 %z, 100663296 17*9880d681SAndroid Build Coastguard Worker %or7 = or i32 %w, 100663296 18*9880d681SAndroid Build Coastguard Worker br label %for.body 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body, %entry 21*9880d681SAndroid Build Coastguard Worker %p0.082 = phi i8* [ %A, %entry ], [ undef, %for.body ] 22*9880d681SAndroid Build Coastguard Worker %element_load.080 = phi i32 [ 0, %entry ], [ %add18, %for.body ] 23*9880d681SAndroid Build Coastguard Worker %p1.079 = phi i8* [ %B, %entry ], [ %1, %for.body ] 24*9880d681SAndroid Build Coastguard Worker %p2.078 = phi i8* [ undef, %entry ], [ %3, %for.body ] 25*9880d681SAndroid Build Coastguard Worker %p3.077 = phi i8* [ undef, %entry ], [ %4, %for.body ] 26*9880d681SAndroid Build Coastguard Worker %0 = call i8* @llvm.hexagon.circ.ldb(i8* %p0.082, i8* nonnull %element_load0, i32 %or, i32 2) 27*9880d681SAndroid Build Coastguard Worker %1 = call i8* @llvm.hexagon.circ.ldb(i8* %p1.079, i8* nonnull null, i32 0, i32 1) 28*9880d681SAndroid Build Coastguard Worker %2 = call i8* @llvm.hexagon.circ.ldb(i8* %p2.078, i8* nonnull %element_load2, i32 %or5, i32 3) 29*9880d681SAndroid Build Coastguard Worker %3 = call i8* @llvm.hexagon.circ.ldb(i8* %2, i8* nonnull %element_load5, i32 %or5, i32 1) 30*9880d681SAndroid Build Coastguard Worker %4 = call i8* @llvm.hexagon.circ.ldb(i8* %p3.077, i8* nonnull %element_load3, i32 %or7, i32 1) 31*9880d681SAndroid Build Coastguard Worker %5 = load i8, i8* null, align 1 32*9880d681SAndroid Build Coastguard Worker %conv = zext i8 %5 to i32 33*9880d681SAndroid Build Coastguard Worker %6 = load i8, i8* %element_load2, align 1 34*9880d681SAndroid Build Coastguard Worker %conv8 = zext i8 %6 to i32 35*9880d681SAndroid Build Coastguard Worker %7 = load i8, i8* %element_load3, align 1 36*9880d681SAndroid Build Coastguard Worker %conv9 = zext i8 %7 to i32 37*9880d681SAndroid Build Coastguard Worker %8 = load i8, i8* undef, align 1 38*9880d681SAndroid Build Coastguard Worker %conv11 = zext i8 %8 to i32 39*9880d681SAndroid Build Coastguard Worker %9 = load i8, i8* %element_load5, align 1 40*9880d681SAndroid Build Coastguard Worker %conv13 = zext i8 %9 to i32 41*9880d681SAndroid Build Coastguard Worker %10 = load i8, i8* %element_load0, align 1 42*9880d681SAndroid Build Coastguard Worker %conv15 = zext i8 %10 to i32 43*9880d681SAndroid Build Coastguard Worker %conv17 = and i32 %element_load.080, 255 44*9880d681SAndroid Build Coastguard Worker %add = add nuw nsw i32 %conv, %conv17 45*9880d681SAndroid Build Coastguard Worker %add10 = add nuw nsw i32 %add, %conv8 46*9880d681SAndroid Build Coastguard Worker %add12 = add nuw nsw i32 %add10, %conv9 47*9880d681SAndroid Build Coastguard Worker %add14 = add nuw nsw i32 %add12, %conv11 48*9880d681SAndroid Build Coastguard Worker %add16 = add nuw nsw i32 %add14, %conv13 49*9880d681SAndroid Build Coastguard Worker %add18 = add nuw nsw i32 %add16, %conv15 50*9880d681SAndroid Build Coastguard Worker %exitcond84 = icmp eq i32 undef, 200 51*9880d681SAndroid Build Coastguard Worker br i1 %exitcond84, label %for.body23, label %for.body 52*9880d681SAndroid Build Coastguard Worker 53*9880d681SAndroid Build Coastguard Workerfor.body23: ; preds = %for.body23, %for.body 54*9880d681SAndroid Build Coastguard Worker %11 = call i8* @llvm.hexagon.circ.stb(i8* undef, i32 undef, i32 %or, i32 3) 55*9880d681SAndroid Build Coastguard Worker br i1 undef, label %for.body34, label %for.body23 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Workerfor.body34: ; preds = %for.body34, %for.body23 58*9880d681SAndroid Build Coastguard Worker %element_load.173 = phi i32 [ %add38, %for.body34 ], [ %add18, %for.body23 ] 59*9880d681SAndroid Build Coastguard Worker %arrayidx35 = getelementptr inbounds i8, i8* %B, i32 0 60*9880d681SAndroid Build Coastguard Worker %12 = load i8, i8* %arrayidx35, align 1 61*9880d681SAndroid Build Coastguard Worker %conv36 = zext i8 %12 to i32 62*9880d681SAndroid Build Coastguard Worker %conv37 = and i32 %element_load.173, 255 63*9880d681SAndroid Build Coastguard Worker %add38 = add nuw nsw i32 %conv36, %conv37 64*9880d681SAndroid Build Coastguard Worker br i1 undef, label %for.end42, label %for.body34 65*9880d681SAndroid Build Coastguard Worker 66*9880d681SAndroid Build Coastguard Workerfor.end42: ; preds = %for.body34 67*9880d681SAndroid Build Coastguard Worker %conv39 = trunc i32 %add38 to i8 68*9880d681SAndroid Build Coastguard Worker ret i8 %conv39 69*9880d681SAndroid Build Coastguard Worker} 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Workerattributes #0 = { nounwind optsize } 72*9880d681SAndroid Build Coastguard Workerattributes #1 = { argmemonly nounwind } 73