; RUN: llc -march=hexagon -hexagon-initial-cfg-cleanup=0 < %s | FileCheck %s ; Check for successful compilation. ; CHECK: vmem target triple = "hexagon" ; Function Attrs: nounwind define dso_local void @f0(ptr %a0, ptr %a1) local_unnamed_addr #0 { b0: br label %b1 b1: ; preds = %b1, %b0 %v0 = phi i32 [ %v18, %b1 ], [ 0, %b0 ] %v1 = getelementptr inbounds i8, ptr %a1, i32 %v0 %v2 = load <64 x i8>, ptr undef, align 1, !tbaa !0, !alias.scope !3 %v3 = add <64 x i8> zeroinitializer, %v2 %v4 = getelementptr inbounds i8, ptr %a0, i32 undef %v5 = getelementptr inbounds i8, ptr %a0, i32 undef %v6 = getelementptr inbounds i8, ptr %a0, i32 undef store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v7 = extractelement <64 x i8> %v3, i32 12 store i8 %v7, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 undef, ptr %v4, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr %v5, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v8 = extractelement <64 x i8> %v3, i32 36 store i8 %v8, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v9 = extractelement <64 x i8> %v3, i32 38 store i8 %v9, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v10 = extractelement <64 x i8> %v3, i32 41 store i8 %v10, ptr %v6, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 undef, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v11 = extractelement <64 x i8> %v3, i32 55 store i8 %v11, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v12 = extractelement <64 x i8> %v3, i32 58 store i8 %v12, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 store i8 0, ptr undef, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v14 = load <64 x i8>, ptr %v1, align 1, !tbaa !0, !alias.scope !3 %v15 = add <64 x i8> zeroinitializer, %v14 %v16 = getelementptr inbounds i8, ptr %a0, i32 undef %v17 = extractelement <64 x i8> %v15, i32 23 store i8 %v17, ptr %v16, align 1, !tbaa !0, !alias.scope !6, !noalias !8 %v18 = add i32 %v0, 64 br label %b1 } attributes #0 = { nounwind "target-cpu"="hexagonv60" "target-features"="+hvx-length64b,+hvxv60" } !0 = !{!1, !1, i64 0} !1 = !{!"omnipotent char", !2, i64 0} !2 = !{!"Simple C/C++ TBAA"} !3 = !{!4} !4 = distinct !{!4, !5} !5 = distinct !{!5, !"LVerDomain"} !6 = !{!7} !7 = distinct !{!7, !5} !8 = !{!4, !9, !10, !11} !9 = distinct !{!9, !5} !10 = distinct !{!10, !5} !11 = distinct !{!11, !5}