[lld] r283367 - Store the hash in SectionPiece.
Rafael Espindola via llvm-commits
llvm-commits at lists.llvm.org
Wed Oct 5 12:36:03 PDT 2016
Author: rafael
Date: Wed Oct 5 14:36:02 2016
New Revision: 283367
URL: http://llvm.org/viewvc/llvm-project?rev=283367&view=rev
Log:
Store the hash in SectionPiece.
This spreads out computing the hash and using it in a hash table. The
speedups are:
firefox
master 6.811232891
patch 6.559280249 1.03841162939x faster
chromium
master 4.369323666
patch 4.33171853 1.00868134338x faster
chromium fast
master 1.856679971
patch 1.850617741 1.00327578725x faster
the gold plugin
master 0.32917962
patch 0.325711944 1.01064645023x faster
clang
master 0.558015452
patch 0.550284165 1.01404962652x faster
llvm-as
master 0.032563515
patch 0.032152077 1.01279662275x faster
the gold plugin fsds
master 0.356221362
patch 0.352772162 1.00977741549x faster
clang fsds
master 0.635096494
patch 0.627249229 1.01251060127x faster
llvm-as fsds
master 0.030183188
patch 0.029889544 1.00982430511x faster
scylla
master 3.071448906
patch 2.938484138 1.04524944215x faster
This seems to be because we don't stall as much. When linking firefox
stalled-cycles-frontend goes from 57.56% to 55.55%.
With -O2 the difference is even more significant since we avoid
recomputing the hash. For firefox we go from 9.990295265 to
9.149627521 seconds (1.09x faster).
Modified:
lld/trunk/ELF/InputSection.cpp
lld/trunk/ELF/InputSection.h
lld/trunk/ELF/OutputSections.cpp
lld/trunk/ELF/OutputSections.h
Modified: lld/trunk/ELF/InputSection.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/InputSection.cpp?rev=283367&r1=283366&r2=283367&view=diff
==============================================================================
--- lld/trunk/ELF/InputSection.cpp (original)
+++ lld/trunk/ELF/InputSection.cpp Wed Oct 5 14:36:02 2016
@@ -644,7 +644,8 @@ template <class ELFT> void MergeInputSe
auto *OutSec = static_cast<MergeOutputSection<ELFT> *>(this->OutSec);
ArrayRef<uint8_t> D = this->getData(Piece);
StringRef S((const char *)D.data(), D.size());
- Piece.OutputOff = OutSec->getOffset(S);
+ CachedHashString V(S, Piece.Hash);
+ Piece.OutputOff = OutSec->getOffset(V);
}
OffsetMap[Piece.InputOff] = Piece.OutputOff;
}
Modified: lld/trunk/ELF/InputSection.h
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/InputSection.h?rev=283367&r1=283366&r2=283367&view=diff
==============================================================================
--- lld/trunk/ELF/InputSection.h (original)
+++ lld/trunk/ELF/InputSection.h Wed Oct 5 14:36:02 2016
@@ -124,14 +124,19 @@ template <class ELFT> InputSectionBase<E
// SectionPiece represents a piece of splittable section contents.
struct SectionPiece {
+ SectionPiece(size_t Off, ArrayRef<uint8_t> Data, uint32_t Hash, bool Live)
+ : InputOff(Off), Hash(Hash), Size(Data.size()),
+ Live(Live || !Config->GcSections) {}
SectionPiece(size_t Off, ArrayRef<uint8_t> Data, bool Live = false)
- : InputOff(Off), Size(Data.size()), Live(Live || !Config->GcSections) {}
+ : SectionPiece(Off, Data, hash_value(Data), Live) {}
size_t size() const { return Size; }
size_t InputOff;
size_t OutputOff = -1;
+ uint32_t Hash;
+
private:
// We use bitfields because SplitInputSection is accessed by
// std::upper_bound very often.
@@ -181,7 +186,7 @@ private:
struct EhSectionPiece : public SectionPiece {
EhSectionPiece(size_t Off, ArrayRef<uint8_t> Data, unsigned FirstRelocation)
- : SectionPiece(Off, Data), Data(Data.data()),
+ : SectionPiece(Off, Data, 0, false), Data(Data.data()),
FirstRelocation(FirstRelocation) {}
const uint8_t *Data;
ArrayRef<uint8_t> data() { return {Data, size()}; }
Modified: lld/trunk/ELF/OutputSections.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/OutputSections.cpp?rev=283367&r1=283366&r2=283367&view=diff
==============================================================================
--- lld/trunk/ELF/OutputSections.cpp (original)
+++ lld/trunk/ELF/OutputSections.cpp Wed Oct 5 14:36:02 2016
@@ -1244,14 +1244,16 @@ void MergeOutputSection<ELFT>::addSectio
for (SectionPiece &Piece : Sec->Pieces) {
if (!Piece.Live)
continue;
- uintX_t OutputOffset = Builder.add(toStringRef(Sec->getData(Piece)));
+ StringRef Data = toStringRef(Sec->getData(Piece));
+ CachedHashString V(Data, Piece.Hash);
+ uintX_t OutputOffset = Builder.add(V);
if (!shouldTailMerge())
Piece.OutputOff = OutputOffset;
}
}
template <class ELFT>
-unsigned MergeOutputSection<ELFT>::getOffset(StringRef Val) {
+unsigned MergeOutputSection<ELFT>::getOffset(CachedHashString Val) {
return Builder.getOffset(Val);
}
Modified: lld/trunk/ELF/OutputSections.h
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/OutputSections.h?rev=283367&r1=283366&r2=283367&view=diff
==============================================================================
--- lld/trunk/ELF/OutputSections.h (original)
+++ lld/trunk/ELF/OutputSections.h Wed Oct 5 14:36:02 2016
@@ -427,7 +427,7 @@ public:
uintX_t Alignment);
void addSection(InputSectionBase<ELFT> *S) override;
void writeTo(uint8_t *Buf) override;
- unsigned getOffset(StringRef Val);
+ unsigned getOffset(llvm::CachedHashString Val);
void finalize() override;
void finalizePieces() override;
bool shouldTailMerge() const;
More information about the llvm-commits
mailing list