johannes updated this revision to Diff 234795. johannes edited the summary of this revision. johannes added a comment.
check if the function's section is executable Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D71487/new/ https://reviews.llvm.org/D71487 Files: lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp lldb/test/Shell/SymbolFile/DWARF/inline-function-address-shared.test lldb/test/Shell/SymbolFile/DWARF/inline-function-address.ll Index: lldb/test/Shell/SymbolFile/DWARF/inline-function-address.ll =================================================================== --- /dev/null +++ lldb/test/Shell/SymbolFile/DWARF/inline-function-address.ll @@ -0,0 +1,28 @@ +; REQUIRES: lld +; RUN: llc %s -filetype=obj -o %t.o +; RUN: ld.lld %t.o %t.o -o %t +; "foo" is defined in both compilation units, but there should be only one meaningful debuginfo entry +; RUN: lldb-test symbols --find=function --name=foo --function-flags=full %t | FileCheck %s +; CHECK: Function: {{.*}} "foo" +; CHECK-NOT: Function: {{.*}} "foo" + +$foo = comdat any +define void @foo() comdat !dbg !6 { +entry: + ret void +} + +!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !2, isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !{}, imports: !{}, splitDebugInlining: false, nameTableKind: None) +!1 = !DIFile(filename: "inline-function-address.h", directory: "") +!2 = !DIFile(filename: "inline-function-address.c", directory: "") +!3 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed) +!4 = !DISubroutineType(types: !{}) +!5 = !DISubprogram(name: "foo", file: !1, line: 12, type: !4, flags: DIFlagPrototyped, spFlags: 0) +!6 = distinct !DISubprogram(name: "foo", file: !1, line: 12, type: !4, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition, unit: !0, declaration: !5) + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!7, !8, !9} +!llvm.ident = !{} +!7 = !{i32 7, !"Dwarf Version", i32 4} +!8 = !{i32 2, !"Debug Info Version", i32 3} +!9 = !{i32 1, !"wchar_size", i32 4} Index: lldb/test/Shell/SymbolFile/DWARF/inline-function-address-shared.test =================================================================== --- /dev/null +++ lldb/test/Shell/SymbolFile/DWARF/inline-function-address-shared.test @@ -0,0 +1,6 @@ +# REQUIRES: lld +; RUN: llc %S/inline-function-address.ll -filetype=obj -o %t.o +; RUN: ld.lld %t.o %t.o -o %t -shared +; RUN: lldb-test symbols --find=function --name=foo --function-flags=full %t | FileCheck %s +; CHECK: Function: {{.*}} "foo" +; CHECK-NOT: Function: {{.*}} "foo" Index: lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp =================================================================== --- lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp +++ lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp @@ -2282,9 +2282,12 @@ addr = sc.function->GetAddressRange().GetBaseAddress(); } - if (addr.IsValid()) { - sc_list.Append(sc); - return true; + + if (auto section_sp = addr.GetSection()) { + if (section_sp->GetPermissions() & ePermissionsExecutable) { + sc_list.Append(sc); + return true; + } } }
Index: lldb/test/Shell/SymbolFile/DWARF/inline-function-address.ll =================================================================== --- /dev/null +++ lldb/test/Shell/SymbolFile/DWARF/inline-function-address.ll @@ -0,0 +1,28 @@ +; REQUIRES: lld +; RUN: llc %s -filetype=obj -o %t.o +; RUN: ld.lld %t.o %t.o -o %t +; "foo" is defined in both compilation units, but there should be only one meaningful debuginfo entry +; RUN: lldb-test symbols --find=function --name=foo --function-flags=full %t | FileCheck %s +; CHECK: Function: {{.*}} "foo" +; CHECK-NOT: Function: {{.*}} "foo" + +$foo = comdat any +define void @foo() comdat !dbg !6 { +entry: + ret void +} + +!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !2, isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !{}, imports: !{}, splitDebugInlining: false, nameTableKind: None) +!1 = !DIFile(filename: "inline-function-address.h", directory: "") +!2 = !DIFile(filename: "inline-function-address.c", directory: "") +!3 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed) +!4 = !DISubroutineType(types: !{}) +!5 = !DISubprogram(name: "foo", file: !1, line: 12, type: !4, flags: DIFlagPrototyped, spFlags: 0) +!6 = distinct !DISubprogram(name: "foo", file: !1, line: 12, type: !4, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition, unit: !0, declaration: !5) + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!7, !8, !9} +!llvm.ident = !{} +!7 = !{i32 7, !"Dwarf Version", i32 4} +!8 = !{i32 2, !"Debug Info Version", i32 3} +!9 = !{i32 1, !"wchar_size", i32 4} Index: lldb/test/Shell/SymbolFile/DWARF/inline-function-address-shared.test =================================================================== --- /dev/null +++ lldb/test/Shell/SymbolFile/DWARF/inline-function-address-shared.test @@ -0,0 +1,6 @@ +# REQUIRES: lld +; RUN: llc %S/inline-function-address.ll -filetype=obj -o %t.o +; RUN: ld.lld %t.o %t.o -o %t -shared +; RUN: lldb-test symbols --find=function --name=foo --function-flags=full %t | FileCheck %s +; CHECK: Function: {{.*}} "foo" +; CHECK-NOT: Function: {{.*}} "foo" Index: lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp =================================================================== --- lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp +++ lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp @@ -2282,9 +2282,12 @@ addr = sc.function->GetAddressRange().GetBaseAddress(); } - if (addr.IsValid()) { - sc_list.Append(sc); - return true; + + if (auto section_sp = addr.GetSection()) { + if (section_sp->GetPermissions() & ePermissionsExecutable) { + sc_list.Append(sc); + return true; + } } }
_______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits