Andrew Kelley via llvm-dev
2018-Dec-03 20:34 UTC
[llvm-dev] workaround to force LLD to make dwarf info sections mappable/loadable?
Context: bugs.llvm.org/show_bug.cgi?id=39862 I'm trying to enable stack traces in an OS kernel. To do that the kernel needs access to its own debug info. I have this in my linker script: .debug_info : { __debug_info_start = .; KEEP(*(.debug_info)) __debug_info_end = .; } .debug_abbrev : { __debug_abbrev_start = .; KEEP(*(.debug_abbrev)) __debug_abbrev_end = .; } .debug_str : { __debug_str_start = .; KEEP(*(.debug_str)) __debug_str_end = .; } .debug_line : { __debug_line_start = .; KEEP(*(.debug_line)) __debug_line_end = .; } .debug_ranges : { __debug_ranges_start = .; KEEP(*(.debug_ranges)) __debug_ranges_end = .; } But LLD maps these sections to address 0: 00000000000003ac g .debug_abbrev 0000000000000000 __debug_abbrev_end 0000000000000000 g .debug_abbrev 0000000000000000 __debug_abbrev_start 0000000000009da5 g .debug_info 0000000000000000 __debug_info_end 0000000000000000 g .debug_info 0000000000000000 __debug_info_start 0000000000006aba g .debug_line 0000000000000000 __debug_line_end 0000000000000000 g .debug_line 0000000000000000 __debug_line_start 0000000000001bf0 g .debug_ranges 0000000000000000 __debug_ranges_end 0000000000000000 g .debug_ranges 0000000000000000 __debug_ranges_start 000000000000399f g .debug_str 0000000000000000 __debug_str_end 0000000000000000 g .debug_str 0000000000000000 __debug_str_start is there a workaround to force LLD to make these sections mappable/loadable so that the executable can access them? Regards, Andrew -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 833 bytes Desc: OpenPGP digital signature URL: <lists.llvm.org/pipermail/llvm-dev/attachments/20181203/511a078e/attachment.sig>
Friedman, Eli via llvm-dev
2018-Dec-03 22:05 UTC
[llvm-dev] workaround to force LLD to make dwarf info sections mappable/loadable?
On 12/3/2018 12:34 PM, Andrew Kelley via llvm-dev wrote:> Context: bugs.llvm.org/show_bug.cgi?id=39862 > > I'm trying to enable stack traces in an OS kernel. To do that the kernel > needs access to its own debug info.Unwind info is usually emitted into an allocatable section, so you can compute a stack trace without looking at debug info. Of course, that doesn't include any symbol information, but you can compute the corresponding symbols offline. IIRC the Linux kernel uses a custom format for symbol information; the build system post-processes the object files to compute the relevant information, and uses objcopy to insert the information into an allocatable section. -Eli -- Employee of Qualcomm Innovation Center, Inc. Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project
Rui Ueyama via llvm-dev
2018-Dec-03 22:10 UTC
[llvm-dev] workaround to force LLD to make dwarf info sections mappable/loadable?
I think Eli made a good point. In addition to that, if you are writing a OS kernel, I guess you are also writing a loader, so you can map anything as you want, no? On Mon, Dec 3, 2018 at 2:06 PM Friedman, Eli via llvm-dev < llvm-dev at lists.llvm.org> wrote:> On 12/3/2018 12:34 PM, Andrew Kelley via llvm-dev wrote: > > Context: bugs.llvm.org/show_bug.cgi?id=39862 > > > > I'm trying to enable stack traces in an OS kernel. To do that the kernel > > needs access to its own debug info. > > Unwind info is usually emitted into an allocatable section, so you can > compute a stack trace without looking at debug info. Of course, that > doesn't include any symbol information, but you can compute the > corresponding symbols offline. > > IIRC the Linux kernel uses a custom format for symbol information; the > build system post-processes the object files to compute the relevant > information, and uses objcopy to insert the information into an > allocatable section. > > -Eli > > -- > Employee of Qualcomm Innovation Center, Inc. > Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux > Foundation Collaborative Project > > _______________________________________________ > LLVM Developers mailing list > llvm-dev at lists.llvm.org > lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >-------------- next part -------------- An HTML attachment was scrubbed... URL: <lists.llvm.org/pipermail/llvm-dev/attachments/20181203/ab0cc1fe/attachment.html>
Apparently Analagous Threads
- workaround to force LLD to make dwarf info sections mappable/loadable?
- [PATCH] drm/nouveau: Add a MM for mappable VRAM that isn't usable as scanout.
- RFC: Add DWARF support for yaml2obj
- Externally loadable Alias Analysis pass
- [LLVMdev] data exchange between loadable pass and backend