This variable is separate from LLVM_DEFAULT_TARGET_TRIPLE and
LLVM_TARGET_TRIPLE and is used to as per-target directory path.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
runtimes/CMakeLists.txt | ||
---|---|---|
157 | Shouldn't it be a CACHE variable? |
runtimes/CMakeLists.txt | ||
---|---|---|
155–156 | We were previously setting LLVM_DEFAULT_TARGET_TRIPLE as part of our configure, so this CACHE setting would never take effect. We'll now set it to the host triple, which seems potentially undesirable? |
LGTM. I didn't realize the LLVM_TARGET_TRIPLE variable already existed and you were just making use of it in more places earlier.
runtimes/CMakeLists.txt | ||
---|---|---|
156 | Should we error if this isn't set, instead of defaulting to the host triple? All call sites from the runtimes build should be setting a value, right? |
runtimes/CMakeLists.txt | ||
---|---|---|
155–156 | Great point, after thinking about this a bit more, I think it'd be best to drop LLVM_DEFAULT_TARGET_TRIPLE altogether and replace it with LLVM_TARGET_TRIPLE. |
This patch seem to do a bit more than it's description implies. It makes LLVM_DEFAULT_TARGET_TRIPLE no longer an valid option on the runtimes path:
CMake Warning: Manually-specified variables were not used by the project: LLVM_DEFAULT_TARGET_TRIPLE
Is this intended? Currently LLVM_DEFAULT_TARGET_TRIPLE is the only option we actually document for changing the target triple (https://llvm.org/docs/CMake.html), so now the support options seem kind of inconsistent (though I don't fully grok the intended distinction between LLVM_DEFAULT_TARGET_TRIPLE and LLVM_TARGET_TRIPLE, which may be part of the problem).
LLVM_DEFAULT_TARGET_TRIPLE is the default value that's used by tools like clang or llc when you don't explicitly specify --target or --triple. LLVM_TARGET_TRIPLE is the target triple we're building for. LLVM_DEFAULT_TARGET_TRIPLE is used as a the default value for LLVM_TARGET_TRIPLE but they're independent.
I couldn't come up with a use case for LLVM_DEFAULT_TARGET_TRIPLE in the runtimes build which is why I dropped it, but I'm open to revisiting that if you have other suggestions. I can also update the documentation to make sure this difference is covered.
I think the point that @daltenty raises, is that if you're currently building the runtimes (by manually invoking cmake on the llvm-project/runtimes directory), you might be setting LLVM_DEFAULT_TARGET_TRIPLE which previously worked for setting it, but after this patch no longer works. My branch for llvm-mingw to make it use the per-target directory does exactly that: https://github.com/mstorsjo/llvm-mingw/commit/2cf53146bb94e0cd56b36b4c71ef09753143389f
I tried setting LLVM_TARGET_TRIPLE instead of LLVM_DEFAULT_TARGET_TRIPLE here, but that doesn't seem to work - with current git main, the only way of setting the triple for the purposes of the per-target runtime directories, is to set LLVM_DEFAULT_TARGET_TRIPLE. So in that respect, it's a public interface, and it'd at least be courteous to keep the old one working for some transition time while switching to a different way of setting it.
Curiously, for compiler-rt, it seems to infer it from CMAKE_C_COMPILER_TARGET, while libcxx/libunwind/libcxxabi seem to require it to be set via LLVM_DEFAULT_TARGET_TRIPLE.
This should be addressed in the latest version. I plan on landing this change today unless there are any concerns as a prerequisite for D140925.
Ok, so this now retains LLVM_DEFAULT_TARGET_TRIPLE as the external user-settable cache variable that controls this, while the internal code is refactored to use LLVM_RUNTIME_TARGET instead? And I guess it's possible to build this by just setting LLVM_RUNTIME_TARGET directly too, even if that's not a cache variable?
That seems reasonable to me. Would the next steps after that be to do an actual deprecation cycle - warning users if they're setting the old variable name and making LLVM_RUNTIME_TARGET a cache variable as well? And then after the next release (or later?), remove handling of the old variable name here?
Yes, that's correct.
That seems reasonable to me. Would the next steps after that be to do an actual deprecation cycle - warning users if they're setting the old variable name and making LLVM_RUNTIME_TARGET a cache variable as well? And then after the next release (or later?), remove handling of the old variable name here?
That was my plan assuming we don't want to keep support for LLVM_DEFAULT_TARGET_TRIPLE which would be my preference.
That sounds very good to me, if given a reasonable deprecation cycle (one major release with both setups working, with warnings suggesting moving from old to new).
We were previously setting LLVM_DEFAULT_TARGET_TRIPLE as part of our configure, so this CACHE setting would never take effect. We'll now set it to the host triple, which seems potentially undesirable?