The triple must be parsed in base-config-ix.cmake.
Otherwise, the cmake variable ANDROID won't be set and this
will confuse cmake to build unsupported targets targeted for
android.
Details
Diff Detail
Event Timeline
For most of the targets android and linux variants have the same components supported. For aarch64-android this is not the case
We need someone with a little more build experience in RT... I'll try to add a few folks.
This seems like just a code move.
Can you quickly explain what was before and what it now, and why the move "fixes" whatever was broken?
The cmake variable ANDROID is set based on triple specified for build. With the base-config-ix restructure, the usage of ANDROID is before we parse the triple. With this problem, even for an android triple all the components that are available for linux are built for android too. This holds well for matured targets like X64, ARM but for AArch64 fails.
This code may need to go into the base-config-ix so that it is exposed to the builtin build too.
I don't really have a problem with this approach, and I don't really understand the Android build path well enough to be an authority here, but I'm a little skeptical about Android needing a build path that is separate from other Linux based platforms.
Darwin is separate largely because we generate multi-architecture builds, and that special snowflake kinda needs to die. I really hope we can find ways to reduce the number of different ways we configure compiler-rt.
I agree. I will move the code to base-config (not going to change the behavior but will keep the flow intact)
I don't really have a problem with this approach, and I don't really understand the Android build path well enough to be an authority here, but I'm a little skeptical about Android needing a build path that is separate from other Linux based platforms.
Here is the existing code in compiler-rt that demonstrates the differentiation between linux and android runtime components
if(ANDROID)
set(OS_NAME "Android")
else()
set(OS_NAME "${CMAKE_SYSTEM_NAME}")
endif()
if (COMPILER_RT_HAS_SANITIZER_COMMON AND DFSAN_SUPPORTED_ARCH AND
OS_NAME MATCHES "Linux") set(COMPILER_RT_HAS_DFSAN TRUE)
else()
set(COMPILER_RT_HAS_DFSAN FALSE)
endif()
I believe that the comments from @beanz have been addressed. The change itself looks fine.
cmake/base-config-ix.cmake | ||
---|---|---|
75 ↗ | (On Diff #61974) | This isn't really your fault, but this is really rather fragile. It looks like it would break if I do something like: armv7-unknown-linux-androideabi It would parse linux as the ABI rather than eabi. Also, the last component androideabi is the environment, not the ABI. |
There is actually a problem with this patch that I didn't spot earlier. It depends on TARGET_TRIPLE being set. That comes from LLVM, so this actually can't be in base-config-ix.cmake because that file needs to work without dependencies on the LLVM build tree.
I'm a little unsure about this patch in general though. The premise seems to be that ANDROID needs to be defined before base-config-ix because it is used there, but it isn't. The only reference to ANDROID in base-config-ix is in the test_targets macro, which shouldn't be evaluated at include time, so I don't understand the problem.
I also still don't fundamentally understand why Android's target detection is different from Linux's. @sgundapa, your comment with the listed differences between Android and Linux is incomplete. The root of this patch is based around the fact that Android and Linux's target detection is different. I still don't fundamentally understand that. Simply put, I don't understand why base-config.ix has any use of the ANDROID variable.
I think I can explain the bit on why Android is a special snowflake here. Android isn't an OS, but an environment. The OS is Linux, the environment is Android rather than GNU or musl or uclibc (yes, you can have armv7-unknown-linux-uclibceabihf!) So, the target needs to be processed specially to determine if the environment is android and if so, behave differently. Im not saying that this is pretty or good, merely what the current state of affairs are.
I have reverted your patch in r273956, and put in the fix I suggested in r273957. Please ensure this meets your needs.
-Chris
@beanz The change is very disruptive I believe.
set(COMPILER_RT_OS_SUFFIX "-android")
Right now I am building both linux and android components and one way to differentiate them is through "-android" prefix.
Also, there is the usage of
if(ANDROID)
in base-config-ix.cmake and ANDROID variable is set later.
Realized that ANDROID usage is inside a macro in base-config. Thanks to @beanz
r274030 fixed the OS suffix change.