[Lldb-commits] [lldb] r367441 - Don't crash when pass by value struct has no definition.
Pavel Labath via lldb-commits
lldb-commits at lists.llvm.org
Mon Aug 5 11:54:19 PDT 2019
On 05/08/2019 20:20, Greg Clayton via lldb-commits wrote:
>
>
>> On Aug 5, 2019, at 11:11 AM, <paul.robinson at sony.com> <paul.robinson at sony.com> wrote:
>>
>>> I also tried to obj2yaml the good DWARF and change it, but once you
>>> add bytes all of the section sizes and offsets are off so that was
>>> not very fruitful, so I ran into errors when trying to convert the
>>> yaml back to and ELF file.
>>>
>>> Greg
>>
>> Yet another case where a "DWARF assembler" would be useful.
>
> Yeah, that is why I made the DWARFGenerator class in llvm/unittests/DebugInfo/DWARF/DwarfGenerator.cpp so I can hand craft DWARF where I can change offsets and move stuff around. It doesn't create an ELF file with section contents for .text or anything though.
>
While it definitely leaves a lot to be desired, I have found it
relatively easy to take the output of "clang -S", and then tweak the
generated dwarf assembly to produce the kind of output I need for
testing various edge cases.
This case also does not sound particularly hard. I'd probably do it by
taking one of the existing DWARF .s test files and modify it to trigger
this situation. My first candidate would be
lit/SymbolFile/DWARF/forward-declarations.s -- it already has a struct
with a DW_AT_declaration attribute, so probably all that's needed is to
add a DW_AT_calling_convention to it. The assembly is already updated to
use symbolic addresses, so no manual fixups of offsets should be needed.
pl
More information about the lldb-commits
mailing list