<div dir="ltr"><div>I just wanted to publicly say thanks to Xing for the hard work on this. Whilst there are still some elements that aren't quite done yet, I think the overall work he has been doing has been great, and since it has been in the form of lots of incremental improvements, I've already been able to make use of what he has done.<br></div><div><br></div><div>Xing, best of luck for the future, and I look forward to continuing to work with you!</div><div><br></div><div>James<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sun, 30 Aug 2020 at 18:05, Xing GUO <<a href="mailto:higuoxing@gmail.com">higuoxing@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi folks,<br>
<br>
The GSoC'20 comes to an end. My project is adding DWARF support to<br>
yaml2obj. Now, the usability of yaml2obj is improved. Some of the<br>
outstanding improvements are listed below:<br>
<br>
* The Length fields of DWARF sections are replaced with Format and Length.<br>
<br>
At first, we have to hardcode the TotalLength and TotalLength64 fields<br>
to instruct the tool to emit a proper DWARF32 or a DWARF64 section,<br>
e.g.,<br>
<br>
```<br>
## To handcraft a DWARF32 debug_aranges section.<br>
debug_aranges:<br>
  - Length:<br>
      TotalLength: 0x1234<br>
    Version: 2<br>
    ...<br>
<br>
## To handcraft a DWARF64 debug_aranges section.<br>
debug_aranges:<br>
  - Length:<br>
      TotalLength: 0xffffffff<br>
      TotalLength64: 0x1234<br>
    Version: 2<br>
    ...<br>
```<br>
<br>
Now, yaml2obj emits DWARF32 sections by default and the Length field<br>
can be omitted, yaml2obj will calculate it for us (Patches that<br>
address this issue: <a href="https://reviews.llvm.org/D82622" rel="noreferrer" target="_blank">https://reviews.llvm.org/D82622</a> ,<br>
<a href="https://reviews.llvm.org/D85880" rel="noreferrer" target="_blank">https://reviews.llvm.org/D85880</a> , <a href="https://reviews.llvm.org/D81063" rel="noreferrer" target="_blank">https://reviews.llvm.org/D81063</a> ,<br>
<a href="https://reviews.llvm.org/D84008" rel="noreferrer" target="_blank">https://reviews.llvm.org/D84008</a> , <a href="https://reviews.llvm.org/D86590" rel="noreferrer" target="_blank">https://reviews.llvm.org/D86590</a> ,<br>
<a href="https://reviews.llvm.org/D84911" rel="noreferrer" target="_blank">https://reviews.llvm.org/D84911</a> ).<br>
<br>
* yaml2obj supports emitting multiple abbrev tables.<br>
<br>
yaml2obj only supported emitting a single abbrev table and multiple<br>
compilation units had to share the same abbrev table before<br>
<a href="https://reviews.llvm.org/D86194" rel="noreferrer" target="_blank">https://reviews.llvm.org/D86194</a> and <a href="https://reviews.llvm.org/D83116" rel="noreferrer" target="_blank">https://reviews.llvm.org/D83116</a> .<br>
Now, yaml2obj is able to emit multiple abbrev tables and compilation<br>
units can be linked to any one of them. We add an optional field ID to<br>
abbrev tables and an optional field AbbrevTableID to compilation<br>
units. Compilation units can use AbbrevTableID to link the abbrev<br>
table with the same ID. Besides, the AbbrOffset field of compilation<br>
units which corresponds to the debug_abbrev_offset field doesn't need<br>
to be specified anymore. yaml2obj is able to calculate it for us after<br>
<a href="https://reviews.llvm.org/D86614" rel="noreferrer" target="_blank">https://reviews.llvm.org/D86614</a> .<br>
<br>
```<br>
debug_abbrev:<br>
  - ID: 0<br>
    Table:<br>
      ...<br>
  - ID: 1<br>
    Table:<br>
      ...<br>
debug_info:<br>
  - ...<br>
    AbbrevTableID: 1 ## Reference the second abbrev table.<br>
    ## AbbrOffset: ... yaml2obj will take care of it.<br>
  - ...<br>
    AbbrevTableID: 0 ## Reference the first abbrev table.<br>
    ## AbbrOffset: ... yaml2obj will take care of it.<br>
```<br>
<br>
* The debug_str_offsets, debug_addr, debug_rnglists and debug_loclists<br>
are supported in yaml2obj.<br>
<br>
Check out <a href="https://reviews.llvm.org/D83624" rel="noreferrer" target="_blank">https://reviews.llvm.org/D83624</a> ,<br>
<a href="https://reviews.llvm.org/D84234" rel="noreferrer" target="_blank">https://reviews.llvm.org/D84234</a> , <a href="https://reviews.llvm.org/D81541" rel="noreferrer" target="_blank">https://reviews.llvm.org/D81541</a> and<br>
<a href="https://reviews.llvm.org/D83853" rel="noreferrer" target="_blank">https://reviews.llvm.org/D83853</a> for more information!<br>
<br>
* The DWARF support is added to elf2yaml and improved in macho2yaml.<br>
<br>
At first, the output of macho2yaml is noisy. It dumps the DWARF<br>
sections twice, one in the Sections: entry and one in the DWARF:<br>
entry, e.g.,<br>
<br>
```<br>
## The content of the debug_str section is dumped twice!<br>
Sections:<br>
  - sectname: __debug_str<br>
    ...<br>
    content: 6D61696E00 ## "main\0"<br>
DWARF:<br>
  debug_str:<br>
    - main<br>
```<br>
<br>
After <a href="https://reviews.llvm.org/D85506" rel="noreferrer" target="_blank">https://reviews.llvm.org/D85506</a> , if the DWARF parser fails to<br>
parse the DWARF sections into the DWARF: entry, obj2yaml will dump<br>
them as raw content sections, otherwise, they will be presented as<br>
structured DWARF sections in the DWARF: entry. Besides,<br>
<a href="https://reviews.llvm.org/D85094" rel="noreferrer" target="_blank">https://reviews.llvm.org/D85094</a> adds DWARF support to elf2yaml.<br>
Although it only supports dumping the debug_aranges section, we can<br>
easily extend it in the future.<br>
<br>
==========================================================<br>
<br>
Unfinished tasks are listed below. I’m not going to leave the<br>
community and I will improve them in the future.<br>
<br>
* Allow users to describe DIEs at a high level.<br>
In my original proposal, we plan to make yaml2obj support describing<br>
DIEs at a high level. However, yaml2obj didn’t support emitting<br>
multiple abbrev tables at that time and I spent some time on enabling<br>
it to emit multiple abbrev tables and link compilation units with<br>
them.<br>
<br>
==========================================================<br>
<br>
My username on Phabricator is @Higuoxing<br>
(<a href="https://reviews.llvm.org/p/Higuoxing/" rel="noreferrer" target="_blank">https://reviews.llvm.org/p/Higuoxing/</a>). Please feel free to ping me<br>
if you have trouble in or encountering bugs in crafting DWARF test<br>
cases in YAML. I’m very happy to help.<br>
<br>
Last but not least, I would love to express my sincere gratitude to<br>
James Henderson for mentoring me during this project. Besides, I would<br>
like to thank George Rimar, Fangrui Song, Pavel Labath, David Blaikie,<br>
Adrian Prantl and Paul Robinson for reviewing my patches, patiently<br>
answering my questions and leaving comments to my proposal!<br>
<br>
==========================================================<br>
<br>
My original proposal:<br>
<a href="https://docs.google.com/document/d/13wNr4JbXtzaOly-UsFt7vxI3LKXzik_lVU58ICqslWM/edit?usp=sharing" rel="noreferrer" target="_blank">https://docs.google.com/document/d/13wNr4JbXtzaOly-UsFt7vxI3LKXzik_lVU58ICqslWM/edit?usp=sharing</a><br>
<br>
<br>
Best Regards,<br>
Xing<br>
</blockquote></div>