This patch re-implements a variety of debug-info maintenence functions to use DPValues instead of DbgValueInst's: supporting the "new" non-intrinsic representation of debug-info. As per [0], we need to have parallel implementations of various utilities for a time, and these are the most fundamental utilities used throughout the compiler. I've added --try-experimental-debuginfo-iterators to a variety of RUN lines: this is a flag that turns on "new debug-info" if it's built into LLVM, and not otherwise. This should ensure that we have the same behaviour for the same IR inputs, but using a different internal representation. For the most part these changes affect SROA/Mem2Reg promotion of dbg.declares into dbg.value intrinsics (now DPValues), we're leaving dbg.declares as instructions until later in the day. There's also some salvaging changes made. I believe the tests that I've added cover almost all the code being updated here. The only thing I'm not confident about is SimplifyCFG, which calls rewriteDebugUsers down a variety of code paths. Those changes can't immediately get full coverage as an additional patch is needed that updates handling of Unreachable instructions, will upload that shortly. [0] https://discourse.llvm.org/t/rfc-instruction-api-changes-needed-to-eliminate-debug-intrinsics-from-ir/68939/9
69 lines
3.9 KiB
LLVM
69 lines
3.9 KiB
LLVM
; RUN: opt -S -passes=mem2reg <%s | FileCheck %s
|
|
; RUN: opt -S -passes=mem2reg <%s --try-experimental-debuginfo-iterators | FileCheck %s
|
|
|
|
declare void @llvm.dbg.declare(metadata, metadata, metadata) nounwind readnone
|
|
|
|
declare void @foo(i32, i64, ptr)
|
|
|
|
define void @baz(i32 %a) nounwind ssp !dbg !1 {
|
|
; CHECK-LABEL: entry:
|
|
; CHECK-NEXT: %"alloca point" = bitcast i32 0 to i32{{$}}
|
|
; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 %a,{{.*}}, !dbg
|
|
; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 %a,{{.*}}, !dbg
|
|
; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 55,{{.*}}, !dbg
|
|
; CHECK-NEXT: call void @llvm.dbg.value(metadata ptr @baz,{{.*}}, !dbg
|
|
; CHECK-NEXT: call void @foo({{.*}}, !dbg
|
|
; CHECK-NEXT: br label %return, !dbg
|
|
entry:
|
|
%x_addr.i = alloca i32 ; <ptr> [#uses=2]
|
|
%y_addr.i = alloca i64 ; <ptr> [#uses=2]
|
|
%z_addr.i = alloca ptr ; <ptr> [#uses=2]
|
|
%a_addr = alloca i32 ; <ptr> [#uses=2]
|
|
%"alloca point" = bitcast i32 0 to i32 ; <i32> [#uses=0]
|
|
call void @llvm.dbg.declare(metadata ptr %a_addr, metadata !0, metadata !DIExpression()), !dbg !7
|
|
store i32 %a, ptr %a_addr
|
|
%0 = load i32, ptr %a_addr, align 4, !dbg !8 ; <i32> [#uses=1]
|
|
call void @llvm.dbg.declare(metadata ptr %x_addr.i, metadata !9, metadata !DIExpression()) nounwind, !dbg !15
|
|
store i32 %0, ptr %x_addr.i
|
|
call void @llvm.dbg.declare(metadata ptr %y_addr.i, metadata !16, metadata !DIExpression()) nounwind, !dbg !15
|
|
store i64 55, ptr %y_addr.i
|
|
call void @llvm.dbg.declare(metadata ptr %z_addr.i, metadata !17, metadata !DIExpression()) nounwind, !dbg !15
|
|
store ptr @baz, ptr %z_addr.i
|
|
%1 = load i32, ptr %x_addr.i, align 4, !dbg !18 ; <i32> [#uses=1]
|
|
%2 = load i64, ptr %y_addr.i, align 8, !dbg !18 ; <i64> [#uses=1]
|
|
%3 = load ptr, ptr %z_addr.i, align 8, !dbg !18 ; <ptr> [#uses=1]
|
|
call void @foo(i32 %1, i64 %2, ptr %3) nounwind, !dbg !18
|
|
br label %return, !dbg !19
|
|
|
|
; CHECK-LABEL: return:
|
|
; CHECK-NEXT: ret void, !dbg
|
|
return: ; preds = %entry
|
|
ret void, !dbg !19
|
|
}
|
|
|
|
!llvm.dbg.cu = !{!3}
|
|
!llvm.module.flags = !{!22}
|
|
!0 = !DILocalVariable(name: "a", line: 8, arg: 1, scope: !1, file: !2, type: !6)
|
|
!1 = distinct !DISubprogram(name: "baz", linkageName: "baz", line: 8, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: false, unit: !3, scopeLine: 8, file: !20, scope: !2, type: !4)
|
|
!2 = !DIFile(filename: "bar.c", directory: "/tmp/")
|
|
!3 = distinct !DICompileUnit(language: DW_LANG_C89, producer: "4.2.1 (Based on Apple Inc. build 5658) (LLVM build)", isOptimized: true, emissionKind: FullDebug, file: !20, enums: !21, retainedTypes: !21)
|
|
!4 = !DISubroutineType(types: !5)
|
|
!5 = !{null, !6}
|
|
!6 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
|
|
!7 = !DILocation(line: 8, scope: !1)
|
|
!8 = !DILocation(line: 9, scope: !1)
|
|
!9 = !DILocalVariable(name: "x", line: 4, arg: 1, scope: !10, file: !2, type: !6)
|
|
!10 = distinct !DISubprogram(name: "bar", linkageName: "bar", line: 4, isLocal: true, isDefinition: true, virtualIndex: 6, isOptimized: false, unit: !3, scopeLine: 4, file: !20, scope: !2, type: !11)
|
|
!11 = !DISubroutineType(types: !12)
|
|
!12 = !{null, !6, !13, !14}
|
|
!13 = !DIBasicType(tag: DW_TAG_base_type, name: "long int", size: 64, align: 64, encoding: DW_ATE_signed)
|
|
!14 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 64, align: 64, file: !20, scope: !2, baseType: null)
|
|
!15 = !DILocation(line: 4, scope: !10, inlinedAt: !8)
|
|
!16 = !DILocalVariable(name: "y", line: 4, arg: 2, scope: !10, file: !2, type: !13)
|
|
!17 = !DILocalVariable(name: "z", line: 4, arg: 3, scope: !10, file: !2, type: !14)
|
|
!18 = !DILocation(line: 5, scope: !10, inlinedAt: !8)
|
|
!19 = !DILocation(line: 10, scope: !1)
|
|
!20 = !DIFile(filename: "bar.c", directory: "/tmp/")
|
|
!21 = !{}
|
|
!22 = !{i32 1, !"Debug Info Version", i32 3}
|