mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-04-03 05:32:24 +00:00
[ELF] - Replace parallelForEach with ranged form.
Makes code a bit more convinent to write/read. Differential revision: https://reviews.llvm.org/D36089 llvm-svn: 310040
This commit is contained in:
parent
6ea444e671
commit
a9b071482d
@ -2218,15 +2218,14 @@ size_t MergeSyntheticSection::getSize() const { return Builder.getSize(); }
|
||||
void elf::decompressAndMergeSections() {
|
||||
// splitIntoPieces needs to be called on each MergeInputSection before calling
|
||||
// finalizeContents(). Do that first.
|
||||
parallelForEach(InputSections.begin(), InputSections.end(),
|
||||
[](InputSectionBase *S) {
|
||||
if (!S->Live)
|
||||
return;
|
||||
if (Decompressor::isCompressedELFSection(S->Flags, S->Name))
|
||||
S->uncompress();
|
||||
if (auto *MS = dyn_cast<MergeInputSection>(S))
|
||||
MS->splitIntoPieces();
|
||||
});
|
||||
parallelForEach(InputSections, [](InputSectionBase *S) {
|
||||
if (!S->Live)
|
||||
return;
|
||||
if (Decompressor::isCompressedELFSection(S->Flags, S->Name))
|
||||
S->uncompress();
|
||||
if (auto *MS = dyn_cast<MergeInputSection>(S))
|
||||
MS->splitIntoPieces();
|
||||
});
|
||||
|
||||
std::vector<MergeSyntheticSection *> MergeSections;
|
||||
for (InputSectionBase *&S : InputSections) {
|
||||
|
@ -67,12 +67,11 @@
|
||||
namespace lld {
|
||||
namespace elf {
|
||||
|
||||
template <class IterTy, class FuncTy>
|
||||
void parallelForEach(IterTy Begin, IterTy End, FuncTy Fn) {
|
||||
template <typename R, class FuncTy> void parallelForEach(R &&Range, FuncTy Fn) {
|
||||
if (Config->Threads)
|
||||
for_each(llvm::parallel::par, Begin, End, Fn);
|
||||
for_each(llvm::parallel::par, std::begin(Range), std::end(Range), Fn);
|
||||
else
|
||||
for_each(llvm::parallel::seq, Begin, End, Fn);
|
||||
for_each(llvm::parallel::seq, std::begin(Range), std::end(Range), Fn);
|
||||
}
|
||||
|
||||
inline void parallelForEachN(size_t Begin, size_t End,
|
||||
|
@ -199,7 +199,7 @@ template <class ELFT> void Writer<ELFT>::run() {
|
||||
// If -compressed-debug-sections is specified, we need to compress
|
||||
// .debug_* sections. Do it right now because it changes the size of
|
||||
// output sections.
|
||||
parallelForEach(OutputSections.begin(), OutputSections.end(),
|
||||
parallelForEach(OutputSections,
|
||||
[](OutputSection *Sec) { Sec->maybeCompress<ELFT>(); });
|
||||
|
||||
Script->assignAddresses();
|
||||
|
Loading…
x
Reference in New Issue
Block a user