-
Notifications
You must be signed in to change notification settings - Fork 52
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add option to generate an ELF file together with the bootable image #249
Comments
I'm confused because can't you already load the ELFs into GDB? E.g I'm not sure how a single ELF would work, since it would have multiple ELFs nested inside of it, how does GDB know which one to debug? |
Do you mean a single ELF for the whole system or are you looking to debug a particular component such as the loader, initial task or kernel? |
Yes, that works. However, for a larger deployment with dozens if not hundreds of components each bringing their own ELF this might not scale, especially when verifying integration or debugging problems going across protection domains.
I think one would merge the ELF files into one, which has different sections per protection domain each with code and debug symbols. I'm unsure about the specifics, tagging @moritz-meier for further input.
This. The individual ELF files all can be found already scattered across the local builddir and the |
Sure, although I'm still not quite sure how that would end up working. I don't know how GDB would be able to interpret the ELF as actually being multiple ELFs, each in a separate address space. At TS we have been working on a debugger component for GDB (https://github.com/au-ts/libgdb) and I could envision that component having system metadata/ELFs embedded so that if you didn't have access to the individual ELFs or something you could still debug the system. I am not familiar with other debuggers/tracing hardware so not sure what is needed there.
Yes. |
Why does it need to interpret as multiple ELFs? In the end, there is multiple code sections, each loaded to different addresses in physical memory, and each code section also is accompanied by individual DWARF. The fact that this could also be represented by multiple, individual ELF files should be irrelevant? I'm aware of a (unfortunately closed source, hence I can not share) example of an OS doing this, they use a small python script to generate a linker script that just links together the different binaries, each as an individual section, and each with the target load address in the metadata. With that ELF, for example in GDB or in Xilinx' |
Would be nice if the microkit tool would generate an ELF file and not a raw binary. Loading raw binaries is always a hassle because you need to specify the load and entry addresses explicitly. |
Sorry, meant to say "multiple programs". |
I've found the raw binaries to be more reliable but I can look into how difficult it would be to generate an ELF (but I guess that's a separate thing to this discussion). |
Could you explain this a little bit more? The microkit binary image consists of the binary of the loader, with all the ELFS for the different PDS unpacked and appended to the end of it. I imagine the things that you generally want to use GDB for are the PDs themselves, not the loader or the monitor, so I don't really understand what you get from emitting the loader.img file as an ELF. When the loader/monitor start, they create a bunch of VSpaces for each of the protection domains and map the relevant data for each PD into the vspace, often with conflicting virtual address (i.e. code usually starts at something like 0x200000 on AARCH64), so I don't understand how you can avoid specifically loading the ELF file of the particular PD(s) that you are interested in debugging. Edit: Unless you mean that in the process of stitching all of the ELFs together you kind of shift them around in such a way that they are loaded in non-conflicting addresses? But considering that the tool doesn't compile the PD ELFs, would it have to require that they are compiled position-independently or something? |
First, disclaimer: I might be wrong on the following, this is my (limited) understanding. Each memory segment in the ELF program header table has two fields in their metadata which are relevant, Now, for on-target (HW) debugging tools, having one ELF that contains both the different code segments and the debug information for all of them is super useful. A specific use-case would be on-chip hardware tracing; where one needs the ELF files (in particular the DWARF) to reconstruct the coverage of the execution trace. Mostly all of the above today can be achieved manually, but that is quiet tedious, and some tools don't play well with loading multiple ELFs. @moritz-meier I'd be happy for more input from your end. |
I see, I wasn't aware of GDB being able to do this. My experiments have been using the GDB remote protocol, which seems to talk about things entirely using virtual addresses. I had a look at some of the ELFs that I've been using in for example systems and it seems like the |
The ELF should contain the sections with information on target load addresses so that the ELF file and the entry point (all standard metadata supported by ELF AFAIK) can be directly loaded with a debugger (i.e. GDB's
load
). This is primarily easing work with debuggers and tracing hardware.The Binary itself can of course be trivially extracted from the respective ELF, but no the other way round.
The text was updated successfully, but these errors were encountered: