Wink Saville via llvm-dev
2016-Sep-06 21:54 UTC
[llvm-dev] Recommended computer resources to build llvm
I've got a i7 with 12 logical cores and 16GB of RAM I successfully built RELEASE_390/final but for the last 100 or so files I'd to use "ninja -j2" so as not to keep from swapping in the best case and and in the worst case the build kills itself without completing because apparently its run out of memory. For the first 3200 files or so it was doing just fine with "ninja" which is probably "ninja -j12" but as I said for the last 100 or so files I had to use "ninja -j2" to get it to complete. So what is the recommended computer resources, and I guess RAM size in particular, for building llvm "quickly"? -- wink
Alexandre Isoard via llvm-dev
2016-Sep-06 22:05 UTC
[llvm-dev] Recommended computer resources to build llvm
I build llvm with -j 4 without swapping with 16 GB of RAM. I build it with LLVM_ENABLE_DYLIB and LLVM_LINK_DYLIB which is probably helping. The amount of RAM consumed is proportional to the number of parallel build process. Also swapping does not necessarily slow down compilation: the OS can swap slow process to use more RAM as a file cache if beneficial. Swapping with -j 12 should be faster than not swapping with -j 2 as you are guaranteed to max out the usage of RAM. On Tue, Sep 6, 2016 at 10:54 PM, Wink Saville via llvm-dev < llvm-dev at lists.llvm.org> wrote:> I've got a i7 with 12 logical cores and 16GB of RAM I successfully > built RELEASE_390/final but for the last 100 or so files I'd to use > "ninja -j2" so as not to keep from swapping in the best case and and > in the worst case the build kills itself without completing because > apparently its run out of memory. > > For the first 3200 files or so it was doing just fine with "ninja" > which is probably "ninja -j12" but as I said for the last 100 or so > files I had to use "ninja -j2" to get it to complete. > > So what is the recommended computer resources, and I guess RAM size in > particular, for building llvm "quickly"? > > -- wink > _______________________________________________ > LLVM Developers mailing list > llvm-dev at lists.llvm.org > http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >-- *Alexandre Isoard* -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20160906/0f8be3c2/attachment.html>
Bruce Hoult via llvm-dev
2016-Sep-06 22:06 UTC
[llvm-dev] Recommended computer resources to build llvm
That's a reasonably well resourced machine, though the last couple of years I've been spec'ing quad core (plus HT) machines with 32 GB rather than 16 GB, and you've got 50% more cores. Still that should be plenty for 12 compiler instances. I suspect the problem is something else, such as link steps. I haven't looked at the actual ninja rules, but you can specify a smaller "-j" setting for particular kinds of build steps. See: https://ninja-build.org/manual.html#ref_pool I have no idea whether the llvm ninja rules currently include something like that. On Wed, Sep 7, 2016 at 9:54 AM, Wink Saville via llvm-dev < llvm-dev at lists.llvm.org> wrote:> I've got a i7 with 12 logical cores and 16GB of RAM I successfully > built RELEASE_390/final but for the last 100 or so files I'd to use > "ninja -j2" so as not to keep from swapping in the best case and and > in the worst case the build kills itself without completing because > apparently its run out of memory. > > For the first 3200 files or so it was doing just fine with "ninja" > which is probably "ninja -j12" but as I said for the last 100 or so > files I had to use "ninja -j2" to get it to complete. > > So what is the recommended computer resources, and I guess RAM size in > particular, for building llvm "quickly"? > > -- wink > _______________________________________________ > LLVM Developers mailing list > llvm-dev at lists.llvm.org > http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20160907/c2dc5a8a/attachment.html>
Wink Saville via llvm-dev
2016-Sep-06 22:21 UTC
[llvm-dev] Recommended computer resources to build llvm
Yes, it did appear to be in the linking steps and initially I had only a 240MB swap on my SSD and the build failed and my chromium browser tabs all died, probably because of CPU starvation. I then added a 16GB swap file on a HD and computer still got very slow as the resources got used up and it was tough to do anything on the computer even control C took a minute or more to abort the compilation. I tried -j8 more or less the same thing so I then dropped to -j2 and finally it succeeded. So it sounds like for 12 CPU's I should bump up the RAM size. And the tip about changing -j for linker might also bear some fruit. Thanks. On Tue, Sep 6, 2016 at 3:06 PM, Bruce Hoult <bruce at hoult.org> wrote:> That's a reasonably well resourced machine, though the last couple of years > I've been spec'ing quad core (plus HT) machines with 32 GB rather than 16 > GB, and you've got 50% more cores. > > Still that should be plenty for 12 compiler instances. I suspect the problem > is something else, such as link steps. > > I haven't looked at the actual ninja rules, but you can specify a smaller > "-j" setting for particular kinds of build steps. See: > > https://ninja-build.org/manual.html#ref_pool > > I have no idea whether the llvm ninja rules currently include something like > that. > > > On Wed, Sep 7, 2016 at 9:54 AM, Wink Saville via llvm-dev > <llvm-dev at lists.llvm.org> wrote: >> >> I've got a i7 with 12 logical cores and 16GB of RAM I successfully >> built RELEASE_390/final but for the last 100 or so files I'd to use >> "ninja -j2" so as not to keep from swapping in the best case and and >> in the worst case the build kills itself without completing because >> apparently its run out of memory. >> >> For the first 3200 files or so it was doing just fine with "ninja" >> which is probably "ninja -j12" but as I said for the last 100 or so >> files I had to use "ninja -j2" to get it to complete. >> >> So what is the recommended computer resources, and I guess RAM size in >> particular, for building llvm "quickly"? >> >> -- wink >> _______________________________________________ >> LLVM Developers mailing list >> llvm-dev at lists.llvm.org >> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev > >
Wink Saville via llvm-dev
2016-Sep-06 22:22 UTC
[llvm-dev] Recommended computer resources to build llvm
I'll try with the *_DYLIB on, txs. On Tue, Sep 6, 2016 at 3:05 PM, Alexandre Isoard <alexandre.isoard at gmail.com> wrote:> I build llvm with -j 4 without swapping with 16 GB of RAM. I build it with > LLVM_ENABLE_DYLIB and LLVM_LINK_DYLIB which is probably helping. > > The amount of RAM consumed is proportional to the number of parallel build > process. Also swapping does not necessarily slow down compilation: the OS > can swap slow process to use more RAM as a file cache if beneficial. > Swapping with -j 12 should be faster than not swapping with -j 2 as you are > guaranteed to max out the usage of RAM. > > On Tue, Sep 6, 2016 at 10:54 PM, Wink Saville via llvm-dev > <llvm-dev at lists.llvm.org> wrote: >> >> I've got a i7 with 12 logical cores and 16GB of RAM I successfully >> built RELEASE_390/final but for the last 100 or so files I'd to use >> "ninja -j2" so as not to keep from swapping in the best case and and >> in the worst case the build kills itself without completing because >> apparently its run out of memory. >> >> For the first 3200 files or so it was doing just fine with "ninja" >> which is probably "ninja -j12" but as I said for the last 100 or so >> files I had to use "ninja -j2" to get it to complete. >> >> So what is the recommended computer resources, and I guess RAM size in >> particular, for building llvm "quickly"? >> >> -- wink >> _______________________________________________ >> LLVM Developers mailing list >> llvm-dev at lists.llvm.org >> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev > > > > > -- > Alexandre Isoard
Justin Bogner via llvm-dev
2016-Sep-06 22:23 UTC
[llvm-dev] Recommended computer resources to build llvm
You can use the ninja pool stuff with -DLLVM_PARALLEL_LINK_JOBS=4 (or 2, or whatever) on the cmake invocation. Bruce Hoult via llvm-dev <llvm-dev at lists.llvm.org> writes:> That's a reasonably well resourced machine, though the last couple of years > I've been spec'ing quad core (plus HT) machines with 32 GB rather than 16 > GB, and you've got 50% more cores. > > Still that should be plenty for 12 compiler instances. I suspect the > problem is something else, such as link steps. > > I haven't looked at the actual ninja rules, but you can specify a smaller > "-j" setting for particular kinds of build steps. See: > > https://ninja-build.org/manual.html#ref_pool > > I have no idea whether the llvm ninja rules currently include something > like that. > > > On Wed, Sep 7, 2016 at 9:54 AM, Wink Saville via llvm-dev < > llvm-dev at lists.llvm.org> wrote: > >> I've got a i7 with 12 logical cores and 16GB of RAM I successfully >> built RELEASE_390/final but for the last 100 or so files I'd to use >> "ninja -j2" so as not to keep from swapping in the best case and and >> in the worst case the build kills itself without completing because >> apparently its run out of memory. >> >> For the first 3200 files or so it was doing just fine with "ninja" >> which is probably "ninja -j12" but as I said for the last 100 or so >> files I had to use "ninja -j2" to get it to complete. >> >> So what is the recommended computer resources, and I guess RAM size in >> particular, for building llvm "quickly"? >> >> -- wink >> _______________________________________________ >> LLVM Developers mailing list >> llvm-dev at lists.llvm.org >> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >> > _______________________________________________ > LLVM Developers mailing list > llvm-dev at lists.llvm.org > http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev
Wink Saville via llvm-dev
2016-Sep-06 22:31 UTC
[llvm-dev] Recommended computer resources to build llvm
On Tue, Sep 6, 2016 at 3:05 PM, Alexandre Isoard <alexandre.isoard at gmail.com> wrote:> LLVM_ENABLE_DYLIBWhere/when/how do you specify LLVM_ENABLE_DYLIB and LLVM_LINK_DYLIB? I tried the following on the cmake command line: $ cmake -G Ninja .. -DCMAKE_INSTALL_PREFIX=/home/wink/opt/llvm -DLLVM_ENABLE_DYLIB=true -DLLVM_LINK_DYLIB=true And got: ... -- Performing Test CXX_SUPPORTS_NO_NESTED_ANON_TYPES_FLAG - Failed -- Configuring done -- Generating done CMake Warning: Manually-specified variables were not used by the project: LLVM_ENABLE_DYLIB LLVM_LINK_DYLIB -- Build files have been written to: /home/wink/foss/llvm.3.9.0/build
David Jones via llvm-dev
2016-Sep-06 22:35 UTC
[llvm-dev] Recommended computer resources to build llvm
Are you building with debug symbols? If so, then be aware that linking libLLVM and libLLDB will require 3-5GB of memory, just for the link step. On my 8GB machine, I cannot use -j2 to compile LLVM with debug symbols, as I will page to death during linking. On Tue, Sep 6, 2016 at 5:54 PM, Wink Saville via llvm-dev < llvm-dev at lists.llvm.org> wrote:> I've got a i7 with 12 logical cores and 16GB of RAM I successfully > built RELEASE_390/final but for the last 100 or so files I'd to use > "ninja -j2" so as not to keep from swapping in the best case and and > in the worst case the build kills itself without completing because > apparently its run out of memory. > > For the first 3200 files or so it was doing just fine with "ninja" > which is probably "ninja -j12" but as I said for the last 100 or so > files I had to use "ninja -j2" to get it to complete. > > So what is the recommended computer resources, and I guess RAM size in > particular, for building llvm "quickly"? > > -- wink > _______________________________________________ > LLVM Developers mailing list > llvm-dev at lists.llvm.org > http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20160906/e87b2e7f/attachment.html>
Wink Saville via llvm-dev
2016-Sep-06 22:49 UTC
[llvm-dev] Recommended computer resources to build llvm
@djones, I'm not specifying debug just going with the default, is that debug or release? How do I specify it? On Tue, Sep 6, 2016 at 3:35 PM, David Jones <djones at xtreme-eda.com> wrote:> Are you building with debug symbols? > > If so, then be aware that linking libLLVM and libLLDB will require 3-5GB of > memory, just for the link step. > > On my 8GB machine, I cannot use -j2 to compile LLVM with debug symbols, as I > will page to death during linking. > > On Tue, Sep 6, 2016 at 5:54 PM, Wink Saville via llvm-dev > <llvm-dev at lists.llvm.org> wrote: >> >> I've got a i7 with 12 logical cores and 16GB of RAM I successfully >> built RELEASE_390/final but for the last 100 or so files I'd to use >> "ninja -j2" so as not to keep from swapping in the best case and and >> in the worst case the build kills itself without completing because >> apparently its run out of memory. >> >> For the first 3200 files or so it was doing just fine with "ninja" >> which is probably "ninja -j12" but as I said for the last 100 or so >> files I had to use "ninja -j2" to get it to complete. >> >> So what is the recommended computer resources, and I guess RAM size in >> particular, for building llvm "quickly"? >> >> -- wink >> _______________________________________________ >> LLVM Developers mailing list >> llvm-dev at lists.llvm.org >> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev > >
Pranith Kumar via llvm-dev
2016-Sep-07 03:39 UTC
[llvm-dev] Recommended computer resources to build llvm
On Tue, Sep 6, 2016 at 5:54 PM, Wink Saville via llvm-dev <llvm-dev at lists.llvm.org> wrote:> I've got a i7 with 12 logical cores and 16GB of RAM I successfully > built RELEASE_390/final but for the last 100 or so files I'd to use > "ninja -j2" so as not to keep from swapping in the best case and and > in the worst case the build kills itself without completing because > apparently its run out of memory. >Can you try the latest master branch? That has thinLTO enabled and does not need more than 6 GB. -- Pranith
Mehdi Amini via llvm-dev
2016-Sep-07 04:05 UTC
[llvm-dev] Recommended computer resources to build llvm
> On Sep 6, 2016, at 8:39 PM, Pranith Kumar via llvm-dev <llvm-dev at lists.llvm.org> wrote: > > On Tue, Sep 6, 2016 at 5:54 PM, Wink Saville via llvm-dev > <llvm-dev at lists.llvm.org> wrote: >> I've got a i7 with 12 logical cores and 16GB of RAM I successfully >> built RELEASE_390/final but for the last 100 or so files I'd to use >> "ninja -j2" so as not to keep from swapping in the best case and and >> in the worst case the build kills itself without completing because >> apparently its run out of memory. >> > > Can you try the latest master branch? That has thinLTO enabled and > does not need more than 6 GB.I’m not sure why ThinLTO would be a solution here: the original post does not even mention LTO and I’d expect ThinLTO to consume strictly more memory than a non-LTO build. Also ThinLTO is not enabled by default for -flto. In general, LLVM builds a lot of binaries from the same intermediate object files, which is not a favorable use-case for ThinLTO. Using Gold and reducing the number of parallel link is probably more promising. — Mehdi
Apparently Analagous Threads
- Recommended computer resources to build llvm
- Recommended computer resources to build llvm
- D16945: LLVM overhaul to avoid linking LLVM component libraries with libLLVM
- D16945: LLVM overhaul to avoid linking LLVM component libraries with libLLVM
- LLD and LLVM_LINK_LLVM_DYLIB