# SPDX-License-Identifier: Apache-2.0 # Determines what argument to give to -mcpu= based on the # KConfig'uration and sets this to GCC_M_CPU if("${ARCH}" STREQUAL "arm") if (CONFIG_CPU_CORTEX_M0) set(GCC_M_CPU cortex-m0) elseif(CONFIG_CPU_CORTEX_M0PLUS) set(GCC_M_CPU cortex-m0plus) elseif(CONFIG_CPU_CORTEX_M1) set(GCC_M_CPU cortex-m1) elseif(CONFIG_CPU_CORTEX_M3) set(GCC_M_CPU cortex-m3) elseif(CONFIG_CPU_CORTEX_M4) set(GCC_M_CPU cortex-m4) elseif(CONFIG_CPU_CORTEX_M7) set(GCC_M_CPU cortex-m7) elseif(CONFIG_CPU_CORTEX_M23) set(GCC_M_CPU cortex-m23) elseif(CONFIG_CPU_CORTEX_M33) if (CONFIG_ARMV8_M_DSP) set(GCC_M_CPU cortex-m33) else() set(GCC_M_CPU cortex-m33+nodsp) endif() elseif(CONFIG_CPU_CORTEX_M55) if (CONFIG_ARMV8_1_M_MVEF) set(GCC_M_CPU cortex-m55) elseif(CONFIG_ARMV8_1_M_MVEI) set(GCC_M_CPU cortex-m55+nomve.fp) elseif(CONFIG_ARMV8_M_DSP) set(GCC_M_CPU cortex-m55+nomve) else() set(GCC_M_CPU cortex-m55+nodsp) endif() elseif(CONFIG_CPU_CORTEX_M85) if (CONFIG_ARMV8_1_M_MVEF) set(GCC_M_CPU cortex-m85) elseif(CONFIG_ARMV8_1_M_MVEI) set(GCC_M_CPU cortex-m85+nomve.fp) elseif(CONFIG_ARMV8_M_DSP) set(GCC_M_CPU cortex-m85+nomve) else() set(GCC_M_CPU cortex-m85+nodsp) endif() elseif(CONFIG_CPU_CORTEX_R4) if(CONFIG_FPU AND CONFIG_CPU_HAS_VFP) set(GCC_M_CPU cortex-r4f) else() set(GCC_M_CPU cortex-r4) endif() elseif(CONFIG_CPU_CORTEX_R5) set(GCC_M_CPU cortex-r5) if(CONFIG_FPU AND CONFIG_CPU_HAS_VFP) if(NOT CONFIG_VFP_FEATURE_DOUBLE_PRECISION) set(GCC_M_CPU ${GCC_M_CPU}+nofp.dp) endif() else() set(GCC_M_CPU ${GCC_M_CPU}+nofp) endif() elseif(CONFIG_CPU_CORTEX_R7) set(GCC_M_CPU cortex-r7) if(CONFIG_FPU AND CONFIG_CPU_HAS_VFP) if(NOT CONFIG_VFP_FEATURE_DOUBLE_PRECISION) set(GCC_M_CPU ${GCC_M_CPU}+nofp.dp) endif() else() set(GCC_M_CPU ${GCC_M_CPU}+nofp) endif() elseif(CONFIG_CPU_CORTEX_R52) set(GCC_M_CPU cortex-r52) if(CONFIG_FPU AND CONFIG_CPU_HAS_VFP) if(NOT CONFIG_VFP_FEATURE_DOUBLE_PRECISION) set(GCC_M_CPU ${GCC_M_CPU}+nofp.dp) endif() endif() elseif(CONFIG_CPU_CORTEX_A9) set(GCC_M_CPU cortex-a9) else() message(FATAL_ERROR "Expected CONFIG_CPU_CORTEX_x to be defined") endif() elseif("${ARCH}" STREQUAL "arm64") if(CONFIG_CPU_CORTEX_A53) set(GCC_M_CPU cortex-a53) elseif(CONFIG_CPU_CORTEX_A55) set(GCC_M_CPU cortex-a55) elseif(CONFIG_CPU_CORTEX_A76) set(GCC_M_CPU cortex-a76) elseif(CONFIG_CPU_CORTEX_A76_A55) set(GCC_M_CPU cortex-a76) set(GCC_M_TUNE cortex-a76.cortex-a55) elseif(CONFIG_CPU_CORTEX_A72) set(GCC_M_CPU cortex-a72) elseif(CONFIG_CPU_CORTEX_R82) set(GCC_M_CPU cortex-r82) endif() elseif("${ARCH}" STREQUAL "arc") if(CONFIG_CPU_EM4_FPUS) set(GCC_M_CPU em4_fpus) elseif(CONFIG_CPU_EM4_DMIPS) set(GCC_M_CPU em4_dmips) elseif(CONFIG_CPU_EM4_FPUDA) set(GCC_M_CPU em4_fpuda) elseif(CONFIG_CPU_HS3X) set(GCC_M_CPU archs) elseif(CONFIG_CPU_HS4X) set(GCC_M_CPU hs4x) elseif(CONFIG_CPU_HS5X) set(GCC_M_CPU hs5x) elseif(CONFIG_CPU_HS6X) set(GCC_M_CPU hs6x) elseif(CONFIG_CPU_EM4) set(GCC_M_CPU arcem) elseif(CONFIG_CPU_EM6) set(GCC_M_CPU arcem) endif() endif()