forked from OSchip/llvm-project
AsmPrinter: Avoid EmitLabelDifference() in DwarfAccelTable
Mint a new function, `AsmPrinter::emitDwarfStringOffset()`, which takes a `DwarfStringPoolEntryRef`. When DWARF is relocatable across sections, this defers to `emitSectionOffset()` and emits the `MCSymbol`; otherwise, just emit the offset directly, without using any intermediate symbols. `EmitLabelDifference()` is already optimized to emit absolute label differences cheaply when possible, so there aren't any major memory savings here (853 MB down to 851 MB, or 0.2%). However, it prepares for making the `MCSymbol`s in the `DwarfStringPool` optional. (I'm looking at `llc` memory usage on `verify-uselistorder.lto.opt.bc`; see r236629 for details.) llvm-svn: 238119
This commit is contained in:
parent
f4599942fb
commit
1e0d94e7bb
|
@ -19,6 +19,7 @@
|
|||
#include "llvm/ADT/MapVector.h"
|
||||
#include "llvm/ADT/Twine.h"
|
||||
#include "llvm/CodeGen/MachineFunctionPass.h"
|
||||
#include "llvm/CodeGen/DwarfStringPoolEntry.h"
|
||||
#include "llvm/IR/InlineAsm.h"
|
||||
#include "llvm/Support/DataTypes.h"
|
||||
#include "llvm/Support/ErrorHandling.h"
|
||||
|
@ -422,6 +423,13 @@ public:
|
|||
/// or by emitting it as an offset from a label at the start of the section.
|
||||
void emitSectionOffset(const MCSymbol *Label) const;
|
||||
|
||||
/// Emit the 4-byte offset of a string from the start of its section.
|
||||
///
|
||||
/// When possible, emit a DwarfStringPool section offset without any
|
||||
/// relocations, and without using the symbol. Otherwise, defers to \a
|
||||
/// emitSectionOffset().
|
||||
void emitDwarfStringOffset(DwarfStringPoolEntryRef S) const;
|
||||
|
||||
/// Get the value for DW_AT_APPLE_isa. Zero if no isa encoding specified.
|
||||
virtual unsigned getISAEncoding() { return 0; }
|
||||
|
||||
|
|
|
@ -181,6 +181,16 @@ void AsmPrinter::emitSectionOffset(const MCSymbol *Label) const {
|
|||
EmitLabelDifference(Label, Label->getSection().getBeginSymbol(), 4);
|
||||
}
|
||||
|
||||
void AsmPrinter::emitDwarfStringOffset(DwarfStringPoolEntryRef S) const {
|
||||
if (MAI->doesDwarfUseRelocationsAcrossSections()) {
|
||||
emitSectionOffset(S.getSymbol());
|
||||
return;
|
||||
}
|
||||
|
||||
// Just emit the offset directly; no need for symbol math.
|
||||
EmitInt32(S.getOffset());
|
||||
}
|
||||
|
||||
/// EmitDwarfRegOp - Emit dwarf register operation.
|
||||
void AsmPrinter::EmitDwarfRegOp(ByteStreamer &Streamer,
|
||||
const MachineLocation &MLoc) const {
|
||||
|
|
|
@ -216,7 +216,7 @@ void DwarfAccelTable::EmitData(AsmPrinter *Asm, DwarfDebug *D) {
|
|||
// Remember to emit the label for our offset.
|
||||
Asm->OutStreamer->EmitLabel((*HI)->Sym);
|
||||
Asm->OutStreamer->AddComment((*HI)->Str);
|
||||
Asm->emitSectionOffset((*HI)->Data.Name.getSymbol());
|
||||
Asm->emitDwarfStringOffset((*HI)->Data.Name);
|
||||
Asm->OutStreamer->AddComment("Num DIEs");
|
||||
Asm->EmitInt32((*HI)->Data.Values.size());
|
||||
for (HashDataContents *HD : (*HI)->Data.Values) {
|
||||
|
|
Loading…
Reference in New Issue