diff --git a/lld/ELF/Driver.cpp b/lld/ELF/Driver.cpp --- a/lld/ELF/Driver.cpp +++ b/lld/ELF/Driver.cpp @@ -1812,7 +1812,7 @@ // Calling sym->extract() in the loop is not safe because it may add new // symbols to the symbol table, invalidating the current iterator. SmallVector syms; - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) if (!sym->isPlaceholder() && pat->match(sym->getName())) syms.push_back(sym); @@ -1998,7 +1998,7 @@ // --no-allow-shlib-undefined diagnostics. Similarly, demote lazy symbols. static void demoteSharedAndLazySymbols() { llvm::TimeTraceScope timeScope("Demote shared and lazy symbols"); - for (Symbol *sym : symtab->symbols()) { + for (Symbol *sym : symtab->getSymbols()) { auto *s = dyn_cast(sym); if (!(s && !cast(s->file)->isNeeded) && !sym->isLazy()) continue; @@ -2045,7 +2045,7 @@ // Symbols in the dynsym could be address-significant in other executables // or DSOs, so we conservatively mark them as address-significant. - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) if (sym->includeInDynsym()) markAddrsig(sym); @@ -2255,7 +2255,7 @@ map[w.sym] = w.wrap; map[w.real] = w.sym; } - for (Symbol *sym : symtab->symbols()) { + for (Symbol *sym : symtab->getSymbols()) { // Enumerate symbols with a non-default version (foo@v1). hasVersionSuffix // filters out most symbols but is not sufficient. if (!sym->hasVersionSuffix) diff --git a/lld/ELF/ICF.cpp b/lld/ELF/ICF.cpp --- a/lld/ELF/ICF.cpp +++ b/lld/ELF/ICF.cpp @@ -460,7 +460,7 @@ // cannot be merged with the later computeIsPreemptible() pass which is used // by scanRelocations(). if (config->hasDynSymTab) - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) sym->isPreemptible = computeIsPreemptible(*sym); // Two text sections may have identical content and relocations but different @@ -558,7 +558,7 @@ d->folded = true; } }; - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) fold(sym); parallelForEach(ctx->objectFiles, [&](ELFFileBase *file) { for (Symbol *sym : file->getLocalSymbols()) diff --git a/lld/ELF/LTO.cpp b/lld/ELF/LTO.cpp --- a/lld/ELF/LTO.cpp +++ b/lld/ELF/LTO.cpp @@ -211,7 +211,7 @@ // Initialize usedStartStop. if (ctx->bitcodeFiles.empty()) return; - for (Symbol *sym : symtab->symbols()) { + for (Symbol *sym : symtab->getSymbols()) { if (sym->isPlaceholder()) continue; StringRef s = sym->getName(); diff --git a/lld/ELF/MarkLive.cpp b/lld/ELF/MarkLive.cpp --- a/lld/ELF/MarkLive.cpp +++ b/lld/ELF/MarkLive.cpp @@ -226,7 +226,7 @@ // Preserve externally-visible symbols if the symbols defined by this // file can interrupt other ELF file's symbols at runtime. - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) if (sym->includeInDynsym() && sym->partition == partition) markSymbol(sym); @@ -371,7 +371,7 @@ // If --gc-sections is not given, retain all input sections. if (!config->gcSections) { // If a DSO defines a symbol referenced in a regular object, it is needed. - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) if (auto *s = dyn_cast(sym)) if (s->isUsedInRegularObj && !s->isWeak()) cast(s->file)->isNeeded = true; diff --git a/lld/ELF/Relocations.cpp b/lld/ELF/Relocations.cpp --- a/lld/ELF/Relocations.cpp +++ b/lld/ELF/Relocations.cpp @@ -666,7 +666,7 @@ for (auto &it : map) if (name.equals_insensitive(it.first)) return it.second; - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) if (!sym->isUndefined() && name.equals_insensitive(sym->getName())) return sym; @@ -692,7 +692,7 @@ break; } if (!s) - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) if (canSuggestExternCForCXX(name, sym->getName())) { s = sym; break; @@ -1690,7 +1690,7 @@ } assert(symAux.empty()); - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) fn(*sym); // Local symbols may need the aforementioned non-preemptible ifunc and GOT diff --git a/lld/ELF/SymbolTable.h b/lld/ELF/SymbolTable.h --- a/lld/ELF/SymbolTable.h +++ b/lld/ELF/SymbolTable.h @@ -33,7 +33,7 @@ // is one add* function per symbol type. class SymbolTable { public: - ArrayRef symbols() const { return symVector; } + ArrayRef getSymbols() const { return symVector; } void wrap(Symbol *sym, Symbol *real, Symbol *wrap); diff --git a/lld/ELF/Writer.cpp b/lld/ELF/Writer.cpp --- a/lld/ELF/Writer.cpp +++ b/lld/ELF/Writer.cpp @@ -1294,7 +1294,7 @@ // We want both global and local symbols. We get the global ones from the // symbol table and iterate the object files for the local ones. - for (Symbol *sym : symtab->symbols()) + for (Symbol *sym : symtab->getSymbols()) addSym(*sym); for (ELFFileBase *file : ctx->objectFiles) @@ -1910,7 +1910,7 @@ } if (config->hasDynSymTab) { - parallelForEach(symtab->symbols(), [](Symbol *sym) { + parallelForEach(symtab->getSymbols(), [](Symbol *sym) { sym->isPreemptible = computeIsPreemptible(*sym); }); } @@ -1982,7 +1982,7 @@ llvm::TimeTraceScope timeScope("Add symbols to symtabs"); // Now that we have defined all possible global symbols including linker- // synthesized ones. Visit all symbols to give the finishing touches. - for (Symbol *sym : symtab->symbols()) { + for (Symbol *sym : symtab->getSymbols()) { if (!sym->isUsedInRegularObj || !includeInSymtab(*sym)) continue; if (!config->relocatable)