115104739SStephen Tozer; RUN: llc --stop-after=hardware-loops < %s | FileCheck %s 215104739SStephen Tozer 315104739SStephen Tozer;; Tests that Hardware Loop Insertion does not insert new phi nodes after debug 415104739SStephen Tozer;; records when they appear immediately after the last existing phi node. 515104739SStephen Tozer 615104739SStephen Tozer; CHECK-LABEL: for.body: 715104739SStephen Tozer; CHECK-NEXT: = phi i32 815104739SStephen Tozer; CHECK-NEXT: = phi i32 9*09457270SStephen Tozer; CHECK-NEXT: #dbg_value 1015104739SStephen Tozer 1115104739SStephen Tozersource_filename = "repro.c" 1215104739SStephen Tozertarget datalayout = "e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64" 1315104739SStephen Tozertarget triple = "thumbv8.1m.main-arm-none-eabi" 1415104739SStephen Tozer 1515104739SStephen Tozer@z = dso_local local_unnamed_addr global i32 42, align 4, !dbg !0 1615104739SStephen Tozer@arr = dso_local local_unnamed_addr global [10 x i32] zeroinitializer, align 4, !dbg !5 1715104739SStephen Tozer 1815104739SStephen Tozerdefine dso_local void @func1() local_unnamed_addr #0 !dbg !18 { 1915104739SStephen Tozerentry: 2015104739SStephen Tozer %0 = load i32, ptr @z, align 4, !tbaa !26 2115104739SStephen Tozer br label %for.body, !dbg !30 2215104739SStephen Tozer 2315104739SStephen Tozerfor.body: ; preds = %entry, %for.body 2415104739SStephen Tozer %p1.04 = phi ptr [ @arr, %entry ], [ %incdec.ptr, %for.body ] 2515104739SStephen Tozer %i.03 = phi i32 [ 0, %entry ], [ %inc, %for.body ] 2615104739SStephen Tozer tail call void @llvm.dbg.value(metadata ptr %p1.04, metadata !23, metadata !DIExpression()), !dbg !25 2715104739SStephen Tozer store i32 %0, ptr %p1.04, align 4, !dbg !32, !tbaa !26 2815104739SStephen Tozer %inc = add nuw nsw i32 %i.03, 1, !dbg !34 2915104739SStephen Tozer %incdec.ptr = getelementptr inbounds i8, ptr %p1.04, i32 4, !dbg !35 3015104739SStephen Tozer %exitcond.not = icmp eq i32 %inc, 10, !dbg !36 3115104739SStephen Tozer br i1 %exitcond.not, label %for.end, label %for.body, !dbg !30, !llvm.loop !37 3215104739SStephen Tozer 3315104739SStephen Tozerfor.end: ; preds = %for.body 3415104739SStephen Tozer ret void, !dbg !41 3515104739SStephen Tozer} 3615104739SStephen Tozer 3715104739SStephen Tozerdeclare void @llvm.dbg.value(metadata, metadata, metadata) 3815104739SStephen Tozer 3915104739SStephen Tozer!llvm.dbg.cu = !{!2} 4015104739SStephen Tozer!llvm.module.flags = !{!11, !12, !13, !14, !15, !16} 4115104739SStephen Tozer!llvm.ident = !{!17} 4215104739SStephen Tozer 4315104739SStephen Tozer!0 = !DIGlobalVariableExpression(var: !1, expr: !DIExpression()) 4415104739SStephen Tozer!1 = distinct !DIGlobalVariable(name: "z", scope: !2, file: !3, line: 2, type: !8, isLocal: false, isDefinition: true) 4515104739SStephen Tozer!2 = distinct !DICompileUnit(language: DW_LANG_C11, file: !3, producer: "clang version 19.0.0git", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, globals: !4, splitDebugInlining: false, nameTableKind: None) 4615104739SStephen Tozer!3 = !DIFile(filename: "repro.c", directory: "/home/gbtozers/dev/upstream-llvm") 4715104739SStephen Tozer!4 = !{!0, !5} 4815104739SStephen Tozer!5 = !DIGlobalVariableExpression(var: !6, expr: !DIExpression()) 4915104739SStephen Tozer!6 = distinct !DIGlobalVariable(name: "arr", scope: !2, file: !3, line: 1, type: !7, isLocal: false, isDefinition: true) 5015104739SStephen Tozer!7 = !DICompositeType(tag: DW_TAG_array_type, baseType: !8, size: 320, elements: !9) 5115104739SStephen Tozer!8 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed) 5215104739SStephen Tozer!9 = !{!10} 5315104739SStephen Tozer!10 = !DISubrange(count: 10) 5415104739SStephen Tozer!11 = !{i32 7, !"Dwarf Version", i32 5} 5515104739SStephen Tozer!12 = !{i32 2, !"Debug Info Version", i32 3} 5615104739SStephen Tozer!13 = !{i32 1, !"wchar_size", i32 4} 5715104739SStephen Tozer!14 = !{i32 1, !"min_enum_size", i32 4} 5815104739SStephen Tozer!15 = !{i32 7, !"frame-pointer", i32 2} 5915104739SStephen Tozer!16 = !{i32 7, !"debug-info-assignment-tracking", i1 true} 6015104739SStephen Tozer!17 = !{!"clang version 19.0.0git"} 6115104739SStephen Tozer!18 = distinct !DISubprogram(name: "func1", scope: !3, file: !3, line: 4, type: !19, scopeLine: 5, flags: DIFlagPrototyped | DIFlagAllCallsDescribed, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !2, retainedNodes: !21) 6215104739SStephen Tozer!19 = !DISubroutineType(types: !20) 6315104739SStephen Tozer!20 = !{null} 6415104739SStephen Tozer!21 = !{!23} 6515104739SStephen Tozer!22 = !DILocalVariable(name: "i", scope: !18, file: !3, line: 6, type: !8) 6615104739SStephen Tozer!23 = !DILocalVariable(name: "p1", scope: !18, file: !3, line: 7, type: !24) 6715104739SStephen Tozer!24 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !8, size: 32) 6815104739SStephen Tozer!25 = !DILocation(line: 0, scope: !18) 6915104739SStephen Tozer!26 = !{!27, !27, i64 0} 7015104739SStephen Tozer!27 = !{!"int", !28, i64 0} 7115104739SStephen Tozer!28 = !{!"omnipotent char", !29, i64 0} 7215104739SStephen Tozer!29 = !{!"Simple C/C++ TBAA"} 7315104739SStephen Tozer!30 = !DILocation(line: 8, column: 3, scope: !31) 7415104739SStephen Tozer!31 = distinct !DILexicalBlock(scope: !18, file: !3, line: 8, column: 3) 7515104739SStephen Tozer!32 = !DILocation(line: 9, column: 10, scope: !33) 7615104739SStephen Tozer!33 = distinct !DILexicalBlock(scope: !31, file: !3, line: 8, column: 3) 7715104739SStephen Tozer!34 = !DILocation(line: 8, column: 27, scope: !33) 7815104739SStephen Tozer!35 = !DILocation(line: 8, column: 32, scope: !33) 7915104739SStephen Tozer!36 = !DILocation(line: 8, column: 21, scope: !33) 8015104739SStephen Tozer!37 = distinct !{!37, !30, !38, !39, !40} 8115104739SStephen Tozer!38 = !DILocation(line: 9, column: 12, scope: !31) 8215104739SStephen Tozer!39 = !{!"llvm.loop.mustprogress"} 8315104739SStephen Tozer!40 = !{!"llvm.loop.unroll.disable"} 8415104739SStephen Tozer!41 = !DILocation(line: 10, column: 1, scope: !18) 85