]> granicus.if.org Git - llvm/commit
[DWARF][RISCV] Add support for RISC-V relocations needed for debug info
authorAlex Bradbury <asb@lowrisc.org>
Thu, 18 Jul 2019 05:22:55 +0000 (05:22 +0000)
committerAlex Bradbury <asb@lowrisc.org>
Thu, 18 Jul 2019 05:22:55 +0000 (05:22 +0000)
commitbfd93491623369eb8bbea2f6012935f9a12b9f49
treeeea8b89d6c588c5740287768fa178b044c1400ad
parent133be34ede2020fe0955dd2557e60f132f00a445
[DWARF][RISCV] Add support for RISC-V relocations needed for debug info

When code relaxation is enabled many RISC-V fixups are not resolved but
instead relocations are emitted. This happens even for DWARF debug
sections. Therefore, to properly support the parsing of DWARF debug info
we need to be able to resolve RISC-V relocations. This patch adds:

* Support for RISC-V relocations in RelocationResolver
* DWARF support for two relocations per object file offset
* DWARF changes to support relocations in more DIE fields

The two relocations per offset change is needed because some RISC-V
relocations (used for label differences) come in pairs.

Relocations can also be emitted for DWARF fields where relocations were
not yet evaluated. Adding relocation support for some of these fields is
essencial. On the other hand, LLVM currently emits RISC-V relocations
for fixups that could be safely evaluated, since they can never be
affected by code relaxations. This patch also adds relocation support
for the fields affected by those extraneous relocations (the DWARF unit
entry Length, and the DWARF debug line entry TotalLength and
PrologueLength), for testing purposes.

Differential Revision: https://reviews.llvm.org/D62062
Patch by Luís Marques.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@366402 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/DebugInfo/DWARF/DWARFRelocMap.h
lib/DebugInfo/DWARF/DWARFContext.cpp
lib/DebugInfo/DWARF/DWARFDataExtractor.cpp
lib/DebugInfo/DWARF/DWARFDebugLine.cpp
lib/DebugInfo/DWARF/DWARFFormValue.cpp
lib/DebugInfo/DWARF/DWARFListTable.cpp
lib/DebugInfo/DWARF/DWARFUnit.cpp
lib/Object/RelocationResolver.cpp
test/DebugInfo/RISCV/dwarf-riscv-relocs.ll [new file with mode: 0644]