blob: ce54cd56dc98ad91c151e96ef1365814df972e7f [file] [log] [blame]
Kristofer Jonsson43ce4912020-11-20 09:42:53 +01001#
Davide Grohmanna8832cc2022-05-06 16:35:16 +02002# Copyright (c) 2020-2022 Arm Limited. All rights reserved.
Kristofer Jonsson43ce4912020-11-20 09:42:53 +01003#
4# SPDX-License-Identifier: Apache-2.0
5#
6# Licensed under the Apache License, Version 2.0 (the License); you may
7# not use this file except in compliance with the License.
8# You may obtain a copy of the License at
9#
10# www.apache.org/licenses/LICENSE-2.0
11#
12# Unless required by applicable law or agreed to in writing, software
13# distributed under the License is distributed on an AS IS BASIS, WITHOUT
14# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15# See the License for the specific language governing permissions and
16# limitations under the License.
17#
18
Kristofer Jonssonec451552021-06-04 18:02:59 +020019set(TARGET_CPU "cortex-m4" CACHE STRING "Target CPU")
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010020
21set(CMAKE_SYSTEM_NAME Generic)
22set(CMAKE_C_COMPILER "arm-none-eabi-gcc")
liodek01cbf1d6d2021-06-30 12:48:31 +030023set(CMAKE_ASM_COMPILER "arm-none-eabi-gcc")
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010024set(CMAKE_CXX_COMPILER "arm-none-eabi-g++")
25
26# Convert TARGET_CPU=Cortex-M33+nofp+nodsp into
27# - CMAKE_SYSTEM_PROCESSOR=cortex-m33
28# - TARGET_CPU_FEATURES=no-fp;no-dsp
29string(REPLACE "+" ";" TARGET_CPU_FEATURES ${TARGET_CPU})
30list(POP_FRONT TARGET_CPU_FEATURES CMAKE_SYSTEM_PROCESSOR)
31string(TOLOWER ${CMAKE_SYSTEM_PROCESSOR} CMAKE_SYSTEM_PROCESSOR)
32
33set(CMAKE_EXECUTABLE_SUFFIX ".elf")
34set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY)
35set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
36set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
37set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
38
39# Select C/C++ version
Kristofer Jonssone2776742021-11-18 16:12:46 +010040set(CMAKE_C_STANDARD 11)
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010041set(CMAKE_CXX_STANDARD 14)
42
Davide Grohmanna8832cc2022-05-06 16:35:16 +020043set(GCC_CPU "${TARGET_CPU}")
44if ("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "cortex-m85")
45 set(GCC_CPU "cortex-m55")
46 list(APPEND GCC_CPU ${TARGET_CPU_FEATURES})
47 list(JOIN GCC_CPU "+" GCC_CPU)
48endif()
49
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010050# Compile options
51add_compile_options(
Davide Grohmanna8832cc2022-05-06 16:35:16 +020052 -mcpu=${GCC_CPU}
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010053 -mthumb
Davide Grohmann03e19e22021-08-11 13:35:14 +020054 "$<$<CONFIG:DEBUG>:-gdwarf-3>"
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010055 "$<$<COMPILE_LANGUAGE:CXX>:-fno-unwind-tables;-fno-rtti;-fno-exceptions>")
56
Kristofer Jonsson1c628992021-05-26 12:02:30 +020057# Compile defines
58add_compile_definitions(
59 "$<$<NOT:$<CONFIG:DEBUG>>:NDEBUG>")
60
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010061# Link options
62add_link_options(
Davide Grohmanna8832cc2022-05-06 16:35:16 +020063 -mcpu=${GCC_CPU}
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010064 -mthumb
65 --specs=nosys.specs)
66
67# Set floating point unit
68if("${TARGET_CPU}" MATCHES "\\+fp")
69 set(FLOAT hard)
70elseif("${TARGET_CPU}" MATCHES "\\+nofp")
71 set(FLOAT soft)
72elseif("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "cortex-m33" OR
Davide Grohmanna8832cc2022-05-06 16:35:16 +020073 "${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "cortex-m55" OR
74 "${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "cortex-m85")
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010075 set(FLOAT hard)
Lior Dekel3e128622021-09-23 18:57:12 +030076elseif("${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "cortex-m4" OR
77 "${CMAKE_SYSTEM_PROCESSOR}" STREQUAL "cortex-m7")
78 set(FLOAT hard)
79 set(FPU_CONFIG "fpv4-sp-d16")
80 add_compile_options(-mfpu=${FPU_CONFIG})
81 add_link_options(-mfpu=${FPU_CONFIG})
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010082else()
83 set(FLOAT soft)
84endif()
85
86if (FLOAT)
87 add_compile_options(-mfloat-abi=${FLOAT})
88 add_link_options(-mfloat-abi=${FLOAT})
89endif()
90
91# Compilation warnings
92add_compile_options(
93 -Wall
94 -Wextra
Kristofer Jonsson29467e02021-11-26 16:10:43 +010095
96 -Wcast-align
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010097 -Wdouble-promotion
Kristofer Jonsson29467e02021-11-26 16:10:43 +010098 -Wformat
99 -Wmissing-field-initializers
100 -Wnull-dereference
Kristofer Jonsson43ce4912020-11-20 09:42:53 +0100101 -Wredundant-decls
102 -Wshadow
Kristofer Jonsson29467e02021-11-26 16:10:43 +0100103 -Wswitch
104 -Wswitch-default
105 -Wunused
106
107 -Wno-redundant-decls
Davide Grohmanndd596042022-05-10 11:18:56 +0200108
109 -Wno-psabi
Davide Grohmanna8832cc2022-05-06 16:35:16 +0200110)