diff --git a/compiler-rt/cmake/Modules/AllSupportedArchDefs.cmake b/compiler-rt/cmake/Modules/AllSupportedArchDefs.cmake --- a/compiler-rt/cmake/Modules/AllSupportedArchDefs.cmake +++ b/compiler-rt/cmake/Modules/AllSupportedArchDefs.cmake @@ -29,6 +29,7 @@ set(ALL_ASAN_SUPPORTED_ARCH ${X86} ${X86_64} ${ARM32} ${ARM64} ${RISCV64} ${MIPS32} ${MIPS64} ${PPC64} ${S390X} ${SPARC} ${SPARCV9} ${HEXAGON} ${LOONGARCH64}) +set(ALL_ASAN_ABI_SUPPORTED_ARCH ${X86_64} ${ARM64}) set(ALL_DFSAN_SUPPORTED_ARCH ${X86_64} ${MIPS64} ${ARM64}) if(ANDROID) diff --git a/compiler-rt/cmake/config-ix.cmake b/compiler-rt/cmake/config-ix.cmake --- a/compiler-rt/cmake/config-ix.cmake +++ b/compiler-rt/cmake/config-ix.cmake @@ -590,6 +590,7 @@ ) set(LSAN_COMMON_SUPPORTED_ARCH ${SANITIZER_COMMON_SUPPORTED_ARCH}) set(UBSAN_COMMON_SUPPORTED_ARCH ${SANITIZER_COMMON_SUPPORTED_ARCH}) + set(ASAN_ABI_SUPPORTED_ARCH ${ALL_ASAN_ABI_SUPPORTED_ARCH}) list_intersect(ASAN_SUPPORTED_ARCH ALL_ASAN_SUPPORTED_ARCH SANITIZER_COMMON_SUPPORTED_ARCH) diff --git a/compiler-rt/lib/asan_abi/CMakeLists.txt b/compiler-rt/lib/asan_abi/CMakeLists.txt --- a/compiler-rt/lib/asan_abi/CMakeLists.txt +++ b/compiler-rt/lib/asan_abi/CMakeLists.txt @@ -15,11 +15,10 @@ if (APPLE) # TODO: set in config-ix.cmake set(ASAN_ABI_SUPPORTED_OS osx) - set(ASAN_ABI_SUPPORTED_ARCHS ${X86_64} ${ARM64}) # Compile Stable API sources into an object library. add_compiler_rt_object_libraries(RTASAN_ABI OS ${ASAN_ABI_SUPPORTED_OS} - ARCHS ${ASAN_ABI_SUPPORTED_ARCHS} + ARCHS ${ASAN_ABI_SUPPORTED_ARCH} SOURCES ${ASAN_ABI_SOURCES} ADDITIONAL_HEADERS ${ASAN_ABI_HEADERS} CFLAGS ${SANITIZER_COMMON_CFLAGS}) @@ -27,7 +26,7 @@ add_compiler_rt_runtime(clang_rt.asan_abi STATIC OS ${ASAN_ABI_SUPPORTED_OS} - ARCHS ${ASAN_ABI_SUPPORTED_ARCHS} + ARCHS ${ASAN_ABI_SUPPORTED_ARCH} OBJECT_LIBS RTASAN_ABI CFLAGS ${SANITIZER_COMMON_CFLAGS} LINK_FLAGS ${WEAK_SYMBOL_LINK_FLAGS} diff --git a/compiler-rt/test/asan_abi/CMakeLists.txt b/compiler-rt/test/asan_abi/CMakeLists.txt --- a/compiler-rt/test/asan_abi/CMakeLists.txt +++ b/compiler-rt/test/asan_abi/CMakeLists.txt @@ -3,7 +3,7 @@ set(ASAN_ABI_TESTSUITES) macro(get_bits_for_arch arch bits) - if (${arch} MATCHES "arm64") + if (${arch} MATCHES "arm64|x86_64") set(${bits} 64) else() message(FATAL_ERROR "Unknown target architecture: ${arch}") @@ -16,7 +16,10 @@ endif() set(ASAN_ABI_DYNAMIC_TEST_DEPS ${ASAN_ABI_TEST_DEPS}) -set(ASAN_ABI_TEST_ARCH arm64) +set(ASAN_ABI_TEST_ARCH ${ASAN_ABI_SUPPORTED_ARCH}) +if(APPLE) + darwin_filter_host_archs(ASAN_ABI_SUPPORTED_ARCH ASAN_ABI_TEST_ARCH) +endif() foreach(arch ${ASAN_ABI_TEST_ARCH}) set(ASAN_ABI_TEST_TARGET_ARCH ${arch})