1*9880d681SAndroid Build Coastguard Worker; RUN: llc %s -march arm64 -o - | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker@a = common global i32* null, align 8 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Workerdefine void @test(i32 %i, i32 %j) nounwind ssp { 6*9880d681SAndroid Build Coastguard Workerentry: 7*9880d681SAndroid Build Coastguard Worker ; CHECK: @test 8*9880d681SAndroid Build Coastguard Worker %j.addr = alloca i32, align 4 9*9880d681SAndroid Build Coastguard Worker store i32 %j, i32* %j.addr, align 4, !tbaa !0 10*9880d681SAndroid Build Coastguard Worker %tmp = bitcast i32* %j.addr to i8* 11*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pldl1strm 12*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 0, i32 1) 13*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pldl3keep 14*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 1, i32 1) 15*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pldl2keep 16*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 2, i32 1) 17*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pldl1keep 18*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 3, i32 1) 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum plil1strm 21*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 0, i32 0) 22*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum plil3keep 23*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 1, i32 0) 24*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum plil2keep 25*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 2, i32 0) 26*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum plil1keep 27*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 0, i32 3, i32 0) 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pstl1strm 30*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 1, i32 0, i32 1) 31*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pstl3keep 32*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 1, i32 1, i32 1) 33*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pstl2keep 34*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 1, i32 2, i32 1) 35*9880d681SAndroid Build Coastguard Worker ; CHECK: prfum pstl1keep 36*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp, i32 1, i32 3, i32 1) 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker %tmp1 = load i32, i32* %j.addr, align 4, !tbaa !0 39*9880d681SAndroid Build Coastguard Worker %add = add nsw i32 %tmp1, %i 40*9880d681SAndroid Build Coastguard Worker %idxprom = sext i32 %add to i64 41*9880d681SAndroid Build Coastguard Worker %tmp2 = load i32*, i32** @a, align 8, !tbaa !3 42*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds i32, i32* %tmp2, i64 %idxprom 43*9880d681SAndroid Build Coastguard Worker %tmp3 = bitcast i32* %arrayidx to i8* 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pldl1strm 46*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp3, i32 0, i32 0, i32 1) 47*9880d681SAndroid Build Coastguard Worker %tmp4 = load i32*, i32** @a, align 8, !tbaa !3 48*9880d681SAndroid Build Coastguard Worker %arrayidx3 = getelementptr inbounds i32, i32* %tmp4, i64 %idxprom 49*9880d681SAndroid Build Coastguard Worker %tmp5 = bitcast i32* %arrayidx3 to i8* 50*9880d681SAndroid Build Coastguard Worker 51*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pldl3keep 52*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp5, i32 0, i32 1, i32 1) 53*9880d681SAndroid Build Coastguard Worker %tmp6 = load i32*, i32** @a, align 8, !tbaa !3 54*9880d681SAndroid Build Coastguard Worker %arrayidx6 = getelementptr inbounds i32, i32* %tmp6, i64 %idxprom 55*9880d681SAndroid Build Coastguard Worker %tmp7 = bitcast i32* %arrayidx6 to i8* 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pldl2keep 58*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp7, i32 0, i32 2, i32 1) 59*9880d681SAndroid Build Coastguard Worker %tmp8 = load i32*, i32** @a, align 8, !tbaa !3 60*9880d681SAndroid Build Coastguard Worker %arrayidx9 = getelementptr inbounds i32, i32* %tmp8, i64 %idxprom 61*9880d681SAndroid Build Coastguard Worker %tmp9 = bitcast i32* %arrayidx9 to i8* 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pldl1keep 64*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp9, i32 0, i32 3, i32 1) 65*9880d681SAndroid Build Coastguard Worker %tmp10 = load i32*, i32** @a, align 8, !tbaa !3 66*9880d681SAndroid Build Coastguard Worker %arrayidx12 = getelementptr inbounds i32, i32* %tmp10, i64 %idxprom 67*9880d681SAndroid Build Coastguard Worker %tmp11 = bitcast i32* %arrayidx12 to i8* 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm plil1strm 71*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp11, i32 0, i32 0, i32 0) 72*9880d681SAndroid Build Coastguard Worker %tmp12 = load i32*, i32** @a, align 8, !tbaa !3 73*9880d681SAndroid Build Coastguard Worker %arrayidx15 = getelementptr inbounds i32, i32* %tmp12, i64 %idxprom 74*9880d681SAndroid Build Coastguard Worker %tmp13 = bitcast i32* %arrayidx3 to i8* 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm plil3keep 77*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp13, i32 0, i32 1, i32 0) 78*9880d681SAndroid Build Coastguard Worker %tmp14 = load i32*, i32** @a, align 8, !tbaa !3 79*9880d681SAndroid Build Coastguard Worker %arrayidx18 = getelementptr inbounds i32, i32* %tmp14, i64 %idxprom 80*9880d681SAndroid Build Coastguard Worker %tmp15 = bitcast i32* %arrayidx6 to i8* 81*9880d681SAndroid Build Coastguard Worker 82*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm plil2keep 83*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp15, i32 0, i32 2, i32 0) 84*9880d681SAndroid Build Coastguard Worker %tmp16 = load i32*, i32** @a, align 8, !tbaa !3 85*9880d681SAndroid Build Coastguard Worker %arrayidx21 = getelementptr inbounds i32, i32* %tmp16, i64 %idxprom 86*9880d681SAndroid Build Coastguard Worker %tmp17 = bitcast i32* %arrayidx9 to i8* 87*9880d681SAndroid Build Coastguard Worker 88*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm plil1keep 89*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp17, i32 0, i32 3, i32 0) 90*9880d681SAndroid Build Coastguard Worker %tmp18 = load i32*, i32** @a, align 8, !tbaa !3 91*9880d681SAndroid Build Coastguard Worker %arrayidx24 = getelementptr inbounds i32, i32* %tmp18, i64 %idxprom 92*9880d681SAndroid Build Coastguard Worker %tmp19 = bitcast i32* %arrayidx12 to i8* 93*9880d681SAndroid Build Coastguard Worker 94*9880d681SAndroid Build Coastguard Worker 95*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pstl1strm 96*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp19, i32 1, i32 0, i32 1) 97*9880d681SAndroid Build Coastguard Worker %tmp20 = load i32*, i32** @a, align 8, !tbaa !3 98*9880d681SAndroid Build Coastguard Worker %arrayidx27 = getelementptr inbounds i32, i32* %tmp20, i64 %idxprom 99*9880d681SAndroid Build Coastguard Worker %tmp21 = bitcast i32* %arrayidx15 to i8* 100*9880d681SAndroid Build Coastguard Worker 101*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pstl3keep 102*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp21, i32 1, i32 1, i32 1) 103*9880d681SAndroid Build Coastguard Worker %tmp22 = load i32*, i32** @a, align 8, !tbaa !3 104*9880d681SAndroid Build Coastguard Worker %arrayidx30 = getelementptr inbounds i32, i32* %tmp22, i64 %idxprom 105*9880d681SAndroid Build Coastguard Worker %tmp23 = bitcast i32* %arrayidx18 to i8* 106*9880d681SAndroid Build Coastguard Worker 107*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pstl2keep 108*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp23, i32 1, i32 2, i32 1) 109*9880d681SAndroid Build Coastguard Worker %tmp24 = load i32*, i32** @a, align 8, !tbaa !3 110*9880d681SAndroid Build Coastguard Worker %arrayidx33 = getelementptr inbounds i32, i32* %tmp24, i64 %idxprom 111*9880d681SAndroid Build Coastguard Worker %tmp25 = bitcast i32* %arrayidx21 to i8* 112*9880d681SAndroid Build Coastguard Worker 113*9880d681SAndroid Build Coastguard Worker ; CHECK: prfm pstl1keep 114*9880d681SAndroid Build Coastguard Worker call void @llvm.prefetch(i8* %tmp25, i32 1, i32 3, i32 1) 115*9880d681SAndroid Build Coastguard Worker ret void 116*9880d681SAndroid Build Coastguard Worker} 117*9880d681SAndroid Build Coastguard Worker 118*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.prefetch(i8* nocapture, i32, i32, i32) nounwind 119*9880d681SAndroid Build Coastguard Worker 120*9880d681SAndroid Build Coastguard Worker!0 = !{!"int", !1} 121*9880d681SAndroid Build Coastguard Worker!1 = !{!"omnipotent char", !2} 122*9880d681SAndroid Build Coastguard Worker!2 = !{!"Simple C/C++ TBAA"} 123*9880d681SAndroid Build Coastguard Worker!3 = !{!"any pointer", !1} 124