mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-18 11:24:01 +00:00
The iteration order over a std::set<Module*> depends on the addresses of the
modules. Avoid that to make the order the linker sees the modules deterministic. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@148676 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -140,7 +140,7 @@ Linker::LinkInArchive(const sys::Path &Filename, bool &is_native) {
|
||||
// Find the modules we need to link into the target module. Note that arch
|
||||
// keeps ownership of these modules and may return the same Module* from a
|
||||
// subsequent call.
|
||||
std::set<Module*> Modules;
|
||||
SmallVector<Module*, 16> Modules;
|
||||
if (!arch->findModulesDefiningSymbols(UndefinedSymbols, Modules, &ErrMsg))
|
||||
return error("Cannot find symbols in '" + Filename.str() +
|
||||
"': " + ErrMsg);
|
||||
@ -157,7 +157,7 @@ Linker::LinkInArchive(const sys::Path &Filename, bool &is_native) {
|
||||
UndefinedSymbols.end());
|
||||
|
||||
// Loop over all the Modules that we got back from the archive
|
||||
for (std::set<Module*>::iterator I=Modules.begin(), E=Modules.end();
|
||||
for (SmallVectorImpl<Module*>::iterator I=Modules.begin(), E=Modules.end();
|
||||
I != E; ++I) {
|
||||
|
||||
// Get the module we must link in.
|
||||
|
Reference in New Issue
Block a user