scott.smith added inline comments.
================ Comment at: source/Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.cpp:530-560 + struct loader { + DYLDRendezvous::iterator I; + ModuleSP m; + std::shared_future<void> f; + }; + std::vector<loader> loaders(num_to_load); + llvm::ThreadPool load_pool( ---------------- zturner wrote: > zturner wrote: > > I'm still unclear why we're still going down this route of adding a very > > specialized instance of parallelism to this one place, that is probably > > going to be less efficient than having a global thread pool (as now you > > will have to spin up and destroy the entire thread pool every time you go > > to load shared libraries). > > > > So, rather than keep repeating the same thing over and over, I went and > > looked into this a little bit. It turns out LLD has a large library of > > parallel algorithms in `lld/Include/lld/Parallel.h`. There is almost > > nothing specific to LLD in any of these algorithms however, and they should > > probably be moved to llvm support. Upon doing so, you will be able to > > write this code as: > > > > ``` > > std::vector<ModuleSP> Modules(m_rendevous.size()); > > llvm::parallel_for_each(make_integer_range(0, m_rendevous.size()), [this, > > &Modules](int I) > > { > > auto &R = m_rendevous[I]; > > Modules[I] = LoadModuleAtAddress(R.file_spec, R.link_addr, R.base_addr, > > true); > > }); > > for (const auto &M : Modules) > > module_list.Append(M); > > ``` > > > > Please look into making this change. > Note that this is, of course, exactly why I've been saying all along that we > should not even be discussing this here. Had the discussion happened over on > the LLVM side the first time I asked about this, someone could have mentioned > this without me having to spend time looking into it. As long as those routines allow you to recursively call those routines, then great, go for it. The spinning up/tearing down of threads is not expensive, at least in my measured use case. Repository: rL LLVM https://reviews.llvm.org/D32597 _______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits