blob: b150b8528b0b095d7df06bc79ccd879cd8bc8174 [file] [log] [blame]
Gyorgy Szing49091802020-11-24 00:33:09 +01001#-------------------------------------------------------------------------------
Julian Hall6e02acf2022-02-22 16:25:03 +00002# Copyright (c) 2020-2022, Arm Limited and Contributors. All rights reserved.
Gyorgy Szing49091802020-11-24 00:33:09 +01003#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
Gyorgy Szing34aaf212022-10-20 07:26:23 +02008# Since we append to default compilation flags stop multiple inclusion to avoid
9# flags being added multiple times.
10include_guard(GLOBAL)
11
Gyorgy Szing49091802020-11-24 00:33:09 +010012#GNUARM v8 and v9 compilers use a different triplet.
Gyorgy Szingd80f8562021-02-11 19:31:43 +010013if(NOT CROSS_COMPILE AND NOT DEFINED ENV{CROSS_COMPILE})
Gyorgy Szingdaf2efd2021-03-09 07:30:34 +010014 set(CROSS_COMPILE "aarch64-elf-;aarch64-none-elf-;aarch64-linux-gnu-;aarch64-none-linux-gnu-" CACHE STRING "List of GCC prefix triplets to use.")
Gyorgy Szing49091802020-11-24 00:33:09 +010015endif()
16
17set(CMAKE_CROSSCOMPILING True)
18set(CMAKE_SYSTEM_NAME Generic)
19set(CMAKE_SYSTEM_PROCESSOR arm)
20set(CMAKE_POSITION_INDEPENDENT_CODE True)
21
Gyorgy Szing34aaf212022-10-20 07:26:23 +020022set(TS_DEBUG_INFO_FLAGS "-fdiagnostics-show-option -gdwarf-2" CACHE STRING "Compiler flags to add debug information.")
Balint Dobszay550ce872022-12-15 15:28:40 +010023set(TS_MANDATORY_AARCH_FLAGS "-fpic -mstrict-align -march=armv8-a+crc" CACHE STRING "Compiler flags configuring architecture specific ")
Gabor Toth983264f2024-01-23 09:16:24 +010024set(TS_WARNING_FLAGS "-Wall -Werror" CACHE STRING "Compiler flags affecting generating warning messages.")
Gyorgy Szing34aaf212022-10-20 07:26:23 +020025set(TS_MANDATORY_LINKER_FLAGS "-pie -Wl,--as-needed -Wl,--sort-section=alignment -zmax-page-size=4096"
26 CACHE STRING "Linker flags needed for correct builds.")
27
Gabor Toth350452a2024-06-19 12:35:08 +020028# branch-protection enables bti/pac while compile force-bti tells the linker to
29# warn if some object files lack the .note.gnu.property section with the BTI
30# flag, and to turn on the BTI flag in the output anyway.
31set(BRANCH_PROTECTION unset CACHE STRING "Enable branch protection")
32set_property(CACHE BRANCH_PROTECTION PROPERTY STRINGS unset 0 1 2 3 4)
Gabor Tothb446a1e2024-05-10 10:42:20 +020033
Gabor Toth350452a2024-06-19 12:35:08 +020034if(BRANCH_PROTECTION STREQUAL "0")
35 set(TS_MANDATORY_AARCH_FLAGS "${TS_MANDATORY_AARCH_FLAGS} -mbranch-protection=none")
36elseif(BRANCH_PROTECTION STREQUAL "1")
37 set(TS_MANDATORY_AARCH_FLAGS "${TS_MANDATORY_AARCH_FLAGS} -mbranch-protection=standard")
38 set(TS_MANDATORY_LINKER_FLAGS "${TS_MANDATORY_LINKER_FLAGS} -zforce-bti")
39 add_compile_definitions("BTI_ENABLED")
40elseif(BRANCH_PROTECTION STREQUAL "2")
41 set(TS_MANDATORY_AARCH_FLAGS "${TS_MANDATORY_AARCH_FLAGS} -mbranch-protection=pac-ret")
42elseif(BRANCH_PROTECTION STREQUAL "3")
43 set(TS_MANDATORY_AARCH_FLAGS "${TS_MANDATORY_AARCH_FLAGS} -mbranch-protection=pac-ret+leaf")
44elseif(BRANCH_PROTECTION STREQUAL "4")
Gabor Tothb446a1e2024-05-10 10:42:20 +020045 set(TS_MANDATORY_AARCH_FLAGS "${TS_MANDATORY_AARCH_FLAGS} -mbranch-protection=bti")
46 set(TS_MANDATORY_LINKER_FLAGS "${TS_MANDATORY_LINKER_FLAGS} -zforce-bti")
Gabor Tothc9d54f62024-06-06 14:09:14 +020047 add_compile_definitions("BTI_ENABLED")
Gabor Tothb446a1e2024-05-10 10:42:20 +020048endif()
49
Gyorgy Szing34aaf212022-10-20 07:26:23 +020050# Set flags affecting all build types
Gabor Toth22d04d62024-06-25 12:42:34 +020051string(APPEND CMAKE_C_FLAGS_INIT " ${TS_MANDATORY_AARCH_FLAGS}")
52string(APPEND CMAKE_CXX_FLAGS_INIT " ${TS_MANDATORY_AARCH_FLAGS}")
53string(APPEND CMAKE_EXE_LINKER_FLAGS_INIT " ${TS_MANDATORY_LINKER_FLAGS}")
54if(DEFINED TS_ROOT)
55 # Flags not to be used with external components.
56 string(APPEND CMAKE_C_FLAGS_INIT " ${TS_WARNING_FLAGS}")
57 string(APPEND CMAKE_CXX_FLAGS_INIT " ${TS_WARNING_FLAGS}")
58endif()
Gyorgy Szing34aaf212022-10-20 07:26:23 +020059
60# Set flags affecting all build types supporting debugging.
61foreach(_b_type IN ITEMS DEBUG RELWITHDEBINFO MINSIZWITHDEBINFO)
62 string(APPEND CMAKE_C_FLAGS_${_b_type}_INIT " ${TS_DEBUG_INFO_FLAGS}")
63 string(APPEND CMAKE_CXX_FLAGS_${_b_type}_INIT " ${TS_DEBUG_INFO_FLAGS}")
64endforeach()
65
66# Build type specific flags
67string(APPEND CMAKE_C_FLAGS_DEBUG_INIT " -O0")
68string(APPEND CMAKE_C_FLAGS_MINSIZEREL_INIT " -Os")
69string(APPEND CMAKE_C_FLAGS_MINSIZWITHDEBINFO_INIT " -Os")
70string(APPEND CMAKE_C_FLAGS_RELEASE_INIT " -O2")
71string(APPEND CMAKE_C_FLAGS_RELWITHDEBINFO_INIT " -O2")
72string(APPEND CMAKE_CXX_FLAGS_DEBUG_INIT " -O0")
73string(APPEND CMAKE_CXX_FLAGS_MINSIZEREL_INIT " -Os")
74string(APPEND CMAKE_CXX_FLAGS_MINSIZWITHDEBINFO_INIT " -Os")
75string(APPEND CMAKE_CXX_FLAGS_RELEASE_INIT " -O2")
76string(APPEND CMAKE_CXX_FLAGS_RELWITHDEBINFO_INIT " -O2")
77
Gyorgy Szing49091802020-11-24 00:33:09 +010078include($ENV{TS_ROOT}/tools/cmake/compiler/GCC.cmake REQUIRED)
Julian Hall0051ed12021-07-22 13:59:24 +010079include($ENV{TS_ROOT}/tools/cmake/compiler/config_iface.cmake REQUIRED)