Hi, As you may have noticed, I'm practically maintaining LLVM all by myself. This is a really tedious, time consuming and ungrateful task, and I'm pretty close to burnout. I'd really appreciate some help.
The problem with LLVM that it's a really huge, rapidly moving forward (and breaking things) project. It needs frequent testing as regressions happen frequently, and we have a good chance of having somebody else fix it if we report them early. At the same time, testing takes a lot of time. While ccache is pretty much a must, it doesn't help much long term as the code is changing frequently and invalidating the cache. On top of this, there's almost-overlapping release process and Gentoo slotting that's working so-so at best. After I've pushed LLVM 13.0.1 final, I've had to immediately start testing 14.x and barely managed to get some fixes in before rc1. Now 14.0.0 is expected soon, simultaneously major changes are happening on the main branch (i.e. 15.x) that also need testing and adjusting the ebuilds to. I barely manage to keep up with amd64 multilib. Other arches are likely to be broken. Some specific projects that need help are: 1. Compiler-RT (particularly sanitizers, fuzzer etc.) -- they break quite often on glibc upgrades. Miraculously, right now 13.0.1 and 14.0.0 are clean right now but I'm pretty sure we'll see a new glibc release soon and they're going to require fixing again. 2. OpenMP -- there are many test regressions on every release, and 14.x is particularly bad. I have no clue about this package, the test output is usually cryptic and I don't really have the time to look into it. Honestly, at this point I would gladly have last rited it if it hadn't had revdeps. 3. LLDB -- while it mostly works and I've managed to fix the worst of it, I still haven't managed to get the test suite fully working. What's even worse, the test runner just hangs at the very end and I have no clue why or how to debug that. Plus the generic stuff: 4. Testing LLVM 15.x periodically, bisecting, reporting bugs early. I can help triaging and reporting the bugs but at least I'd need somebody else to run the builds more often than I can. 5. Testing LLVM 14.x, 15.x on non-amd64 architectures (including x86 builds -- not all LLVM components are multilib) and reporting bugs. Unfortunately, this part may require actually providing patches. 6. Work on setting up and configuring a buildbot for Gentoo LLVM builds. This is some effort and I don't have the time to learn how to do that. You'll probably need to set up a local instance and figure out how to set our builds before submitting anything upstream; in my experience they aren't very responsive to buildbot changes, so ideally we need to flesh out any problems early. Yes, that's a lot of work. I can't do it all myself, I'm already doing too much and this is having negative impact on my health. I really need help with this. Disclaimer: I've been doing some LLDB-related paid work in the past. However, this work wasn't Gentoo-related and if anything, it required me to spend my CPU time on work and not testing LLVM for Gentoo. -- Best regards, Michał Górny