[compiler-rt] 8887c63 - Adapt "cross compile?" check for Apple Silicon
    Julian Lettner via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Wed Apr 13 15:26:20 PDT 2022
    
    
  
Author: Julian Lettner
Date: 2022-04-13T15:26:14-07:00
New Revision: 8887c63e327fb726b502b3b2fad44e50de60d5aa
URL: https://github.com/llvm/llvm-project/commit/8887c63e327fb726b502b3b2fad44e50de60d5aa
DIFF: https://github.com/llvm/llvm-project/commit/8887c63e327fb726b502b3b2fad44e50de60d5aa.diff
LOG: Adapt "cross compile?" check for Apple Silicon
This piece of code tries to implement the semantics "cross compile?" to
determine CFLAGS used for test binary compilation.
```
if(ANDROID OR ${arch} MATCHES "arm|aarch64|riscv32|riscv64")
```
Since Apple Silicon, macOS runs on arm64e, so we take the wrong branch
when compiling and running tests locally "on the host" on an AS machine.
Furthermore, for Apple code, we use the separate
`get_test_cflags_for_apple_platform` function to determine these test
compiliation flags and `get_test_cc_for_arch` is only ever used in the
"compile & run on host" case, so we can short-curcuit the "cross
compile?" check here.
rdar://91446703
Differential Revision: https://reviews.llvm.org/D123633
Added: 
    
Modified: 
    compiler-rt/cmake/config-ix.cmake
Removed: 
    
################################################################################
diff  --git a/compiler-rt/cmake/config-ix.cmake b/compiler-rt/cmake/config-ix.cmake
index 729809f55690c..ba84f0bfb53df 100644
--- a/compiler-rt/cmake/config-ix.cmake
+++ b/compiler-rt/cmake/config-ix.cmake
@@ -244,7 +244,7 @@ endfunction()
 # specific architecture.  When cross-compiling, this is controled via
 # COMPILER_RT_TEST_COMPILER and COMPILER_RT_TEST_COMPILER_CFLAGS.
 macro(get_test_cc_for_arch arch cc_out cflags_out)
-  if(ANDROID OR ${arch} MATCHES "arm|aarch64|riscv32|riscv64")
+  if(ANDROID OR (NOT APPLE AND ${arch} MATCHES "arm|aarch64|riscv32|riscv64"))
     # This is only true if we are cross-compiling.
     # Build all tests with host compiler and use host tools.
     set(${cc_out} ${COMPILER_RT_TEST_COMPILER})
        
    
    
More information about the llvm-commits
mailing list