-
Notifications
You must be signed in to change notification settings - Fork 1.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support LLVM flang #12306
Comments
Ah yes, and according to meson, flang cannot handle |
In terms of feasibility, I'm happy to note that with a hacked-up version of meson (roughly according to what I'm describing in the OP), I managed to build scipy with meson & flang. :) So if someone tells me how an acceptable PR for flang-support would roughly look like, I'm happy to give it a shot! This landed now as llvm/llvm-project@6403287, but I realised one thing: we probably don't need to add |
IIRC the reason we add this isn't for when you build and link with the Fortran compiler, but rather when you build with the Fortran compiler and link with a different compiler as part of a multi-language target. Usually the C++ compiler. |
Roughly speaking, I think we want to insert naming bikeshed add a compilers/fortran.py class defining the flang-new compiler that does whatever is needed, and indicates itself as compilers/detect.py is also going to want to be able to tell based on running There's a list of possible command names for searching for a compiler when |
Thanks for the feedback!
It's going to be flang. There was a long discussion that ultimately got resolved together with LLVM's BDFL; see particularly point 3. here (note also the relatively subdued reception for the proposed intermediate name The only question is how long things will take. There's already an RFC however which proposes to do exactly what's been agreed upon as the final criterion to do the rename, but whether that'll be LLVM 18 or 19 (or later still), who knows. I get the feeling it's not too far off though - in most cases the new lowering already outperforms the old one, and they're just hunting down any remaining perf regressions. |
I only want to make sure you're aware: AFAICT, the thing you consider landed was reverted pretty quickly (https://reviews.llvm.org/D154869#4652255) -- I don't know if a fixed version has landed in the meantime. |
Yeah, I'm following along. It's pretty standard for big PRs in LLVM to get involved because the merge breaks something somewhere unforeseen. The issue with this one is that the person driving that change has apparently moved on already. In any case, it shouldn't concern the meson setup too much, as I mentioned above, the driver should already add the right linkage to the runtime libs by itself. |
Yes, this is exactly what these are for. If the final link is done with a different language (c, c++, rust, etc) these are the flags we need to add manually because normally the native compiler would do this for us |
What's the upstream status on this? |
You have good timing, I just started working on this again yesterday 😅
Neither the rename nor the runtime lib refactor has happened yet. So far I was working on hacking enough on meson to get SciPy to compile with flang 18 (which got a lot stricter and will simply fail on unknown flags). However, I haven't yet looked into how to distinguish If it helps, I can open a WIP PR, but it's going to be in a very rough state. |
Well, technically meson doesn't really care what the binary is named except inasmuch as we need to know what to run to try to check for a compiler. There are e.g. environments where There's also more boring reasons why a simple name check doesn't work, such as the complexity of handling x86_64-pc-linux-gnu-gcc-12 or musl-gcc, the fact that /usr/bin/cc is traditionally a symlink to whichever of GCC/clang are the system default... As long as meson can tell the difference between classic flang and new flang by parsing the output of --help / --version (I assume checking the version number is good enough given classic flang isn't really based on llvm 18?) we are good to go because that's what we'll base identification off of, not the executable name. |
@h-vetinari please open a WIP PR with your patches. I was also looking into this and I'd like to help if possible. I can test on linux/windows, too. |
I've opened a pull request now: #13323 It's even less functional than I'd want to - i.e. I cannot even build SciPy with it and flang 18 (v17 worked with a prior set of the patches, haven't tested the updated version yet). But perhaps it gives people something to discuss. I'm also building a flang from the upstream |
As a quick update: #13323 + the in-progress flang 19 can build SciPy (and pass the test suite). Unfortunately flang 18 is not usable, and the regression fix won't be backported. Otherwise, this should now slowly be approaching something like usability! |
The preliminary support has now been merged to git master. Let's discuss what else we need to get this polished. |
I was about to close this and open a follow-up issue, but after your comment I edited the OP instead with the open points I'm aware of for improvements. And of course, testing this on various platforms would be very helpful! |
@h-vetinari Wanted to say you a big-big thanks for this amazing work! After finding a workaround for this issue, we were able to build SciPy using LLVM 20 on Amazon Linux (Fedora-based) w/ no extra patches to either SciPy or LLVM nor too much configuration.
BTW, transition to flang-new from gfortran reduced our scipy buildtime from 7-10 minutes to 1-2. CC: @BwL1289 |
Awesome!
I'll note that this was probably due to a hot cache, different build settings, or something like that. Not that much time is spent compiling or linking Fortran code, the heaviest components are C++. |
@rgommers yeah, I have the similar feeling. It's not so huge amount of Fortran code in SciPy. Probably, this is something related to that flang better interoperates with LLVM ecosystem than gfortran (even if everything else is built with LLVM in both cases), but it's only my hypothesis. |
thanks @rgommers! |
The rename from flang-new to flang finally landed in LLVM 20: llvm/llvm-project@06eb10d 🥳 |
Also, the runtime libs refactor is progressing and almost there |
Support in other compilers for this flag is quite patchy, leading to build errors and requiring workarounds in distros - see for example: - scipy#19447 - mesonbuild/meson#12306 - https://github.com/conda-forge/scipy-feedstock/blob/1a8ff378bebd3f0b0bc6a2d1662a77d194ac59a1/recipe/bld.bat#L25 - https://github.com/spack/spack/blob/73316c3e286d548b22dc65667810e4631479c3ea/var/spack/repos/builtin/packages/py-scipy/package.py#L235-L238 Compilers that do not support it include at least Flang and AOCC (the AMD Fortran compiler). This should be fixed upstream in Meson by not passing the flag for compilers that don't support it, and then we can revert this change. But for now it's very useful to avoid bothering users of these compilers with having to override that flag manually. This does give the following warning with `gfortran` now, but that can't be helped unfortunately: ``` WARNING: Consider using the built-in option for language standard version instead of using "-std=legacy". ```
Update, now that #13323 has been merged, I'm turning this into a list of further improvements, as opening a follow-up issue was deemed not necessary.
Blocked on upstream
flang-new
toflang
for LLVM 20: llvm/llvm-project@06eb10d-fvisibility=
: [flang][driver] support symbol visibility flag llvm/llvm-project#92459-MD
,-MQ
,-MF
: Flang driver compiler options request llvm/llvm-project#89888-fdiagnostics-color=
: Flang driver compiler options request llvm/llvm-project#89888Improvements
fortran_std=legacy
(workaround is usingfortran_std=none
)-Wall
, which is not supported upstream yet, but currently set as the default in mesonmeson/mesonbuild/compilers/fortran.py
Line 612 in f0851c9
For reference, in SciPy I currently use the following:
Note that
-fms-runtime-lib
is only supported since flang 18 (llvm/llvm-project@cf1e342)Correctly handle non-functional versions
-flang-experimental-exec
flag to compile things, and before flang 15/16, it cannot actually do any code generation itself, but relies on an external compiler, c.f. here. Realistically, not much before flang 17 is going to be functional (though apparently some people managed to build SciPy with flang 16).-shared
with builds that require linking toFortran_main
(SciPy falls into this category); if it's possible to diagnose this and error out that would be great, or perhaps there are work-arounds to suppress/modify the linkage somehow.Expand testing
Previously:
This is a continuation of #10839, which got closed without any changes.
Flang has a long history, the relevant bits of which are that there's nowadays a "classic" flang, and a new LLVM-based flang (called f18 before it got merged into LLVM). Though they share a name, and developed largely by the same people, they're essentially completely different compilers.
As of LLVM 17, flang is starting to become useable (no more experimental flag necessary to generate executable), however, the naming still has not fully settled, and llvm-flang is currently still using
flang-new
as the name of the binary until some planned refactoring work is done.One of the main differences that appeared pretty much immediately when testing this in conda-forge, is that llvm-flang does not use the PGI-style
-Minform=inform
and will throw an error upon that.Furthermore, it doesn't support
-module
, but requires-module-dir
. Finally, the runtime libs that need to be linked are different:The runtime libs are due for a relatively large overhaul, so in addition with the binary name, supporting flang probably means:
fortran.py
Finally, using llvm-flang also runs into #10778, and into some rsp-limitations resp. path mangling issues (for now worked around by raising
MESON_RSP_THRESHOLD
to ridiculous levels).The text was updated successfully, but these errors were encountered: