blob: c12f4270214792842b33d956ff74fc66536aaaf2 [file] [log] [blame]
Kristofer Jonsson43ce4912020-11-20 09:42:53 +01001#
Per Åstrand9de1b742022-02-03 19:35:35 +01002# 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 Jonssonf62c3d72021-01-21 17:39:03 +010019# Add .elf to all executables
20set(CMAKE_EXECUTABLE_SUFFIX ".elf")
21
22#############################################################################
23# Link options
24#############################################################################
25
26function(ethosu_target_link_options target scope)
27 cmake_parse_arguments(ARG "" "LINK_FILE;ENTRY" "" ${ARGN})
28
29 # Store the link file in a property to be evaluated by the executable.
Kristofer Jonssonec451552021-06-04 18:02:59 +020030 get_filename_component(LINK_FILE_PATH ${ARG_LINK_FILE} ABSOLUTE)
31 set_property(GLOBAL PROPERTY ETHOSU_TARGET_LINK_FILE ${LINK_FILE_PATH})
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +010032
33 if (ARG_ENTRY)
34 target_link_options(${target} ${scope} --entry Reset_Handler)
35 endif()
36endfunction()
37
38function(ethosu_eval_link_options target)
39 # Get the link file from the cache
40 get_property(LINK_FILE GLOBAL PROPERTY ETHOSU_TARGET_LINK_FILE)
41
42 set(prop "$<TARGET_PROPERTY:${target},COMPILE_DEFINITIONS>")
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010043
44 if (CMAKE_CXX_COMPILER_ID STREQUAL "ARMClang")
Jonas Ohlssonf821c612021-06-04 14:58:34 +020045 set(LINK_FILE_EXT scatter)
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010046 set(LINK_FILE_OPTION "--scatter")
Jonas Ohlssonf821c612021-06-04 14:58:34 +020047 # Note: the -mcpu flag is added to avoid warnings caused when using the default cpu/arch.
48 set(COMPILER_PREPROCESSOR_OPTIONS -mcpu=${CMAKE_SYSTEM_PROCESSOR} --target=arm-arm-none-eabi -E -x c -P)
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010049 elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
Jonas Ohlssonf821c612021-06-04 14:58:34 +020050 set(LINK_FILE_EXT ld)
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010051 set(LINK_FILE_OPTION "-T")
Jonas Ohlssonf821c612021-06-04 14:58:34 +020052 set(COMPILER_PREPROCESSOR_OPTIONS -E -x c -P)
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010053 endif()
54
Kristofer Jonssonec451552021-06-04 18:02:59 +020055 if (EXISTS ${LINK_FILE})
56 set(LINK_FILE_IN ${LINK_FILE})
57 else()
58 set(LINK_FILE_IN ${LINK_FILE}.${LINK_FILE_EXT})
59 endif()
60
Jonas Ohlssonf821c612021-06-04 14:58:34 +020061 get_filename_component(LINK_FILE_OUT_BASE ${LINK_FILE} NAME)
62 set(LINK_FILE_OUT ${CMAKE_CURRENT_BINARY_DIR}/${LINK_FILE_OUT_BASE}-${target}.${LINK_FILE_EXT})
63
64 add_custom_command(
65 OUTPUT ${LINK_FILE_OUT}
66 DEPENDS ${LINK_FILE_IN}
Jonas Ohlssonf821c612021-06-04 14:58:34 +020067 COMMAND ${CMAKE_C_COMPILER} ${COMPILER_PREPROCESSOR_OPTIONS} -o ${LINK_FILE_OUT} ${LINK_FILE_IN}
68 COMMAND_EXPAND_LISTS "-D$<JOIN:${prop},;-D>"
69 COMMAND_EXPAND_LISTS "-I$<JOIN:$<TARGET_PROPERTY:${target},INCLUDE_DIRECTORIES>,;-I>"
70 COMMENT "Preprocessing and generating linker script"
71 VERBATIM)
72 add_custom_target(${target}-linker-script
73 DEPENDS ${LINK_FILE_OUT}
74 VERBATIM)
75 add_dependencies(${target} ${target}-linker-script)
76
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +010077 target_link_options(${target} PUBLIC ${LINK_FILE_OPTION} ${LINK_FILE_OUT})
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010078 set_target_properties(${target} PROPERTIES LINK_DEPENDS ${LINK_FILE_OUT})
79endfunction()
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +010080
81#############################################################################
82# Executable
83#############################################################################
84
85function(ethosu_add_executable target)
86 cmake_parse_arguments(ARGS "" "TARGET_LIBRARY" "SOURCES;LIBRARIES" ${ARGN})
87 add_executable(${target})
88
89 target_sources(${target} PRIVATE
90 ${ARGS_SOURCES})
91
92 if(NOT ARGS_TARGET_LIBRARY)
93 set(ARGS_TARGET_LIBRARY ethosu_target_init)
94 endif()
95
96 target_link_libraries(${target} PRIVATE
97 ${ARGS_TARGET_LIBRARY} ethosu_core ${ARGS_LIBRARIES})
98
99 ethosu_eval_link_options(${target})
Per Åstrand0954a8a2021-03-26 09:52:07 +0100100
Per Åstrand6440bba2021-03-29 15:58:16 +0200101 if (CMAKE_CXX_COMPILER_ID STREQUAL "ARMClang")
102 target_link_options(${target} PRIVATE --map --list=${target}.map)
103 elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
104 target_link_options(${target} PRIVATE -Xlinker -Map=${target}.map)
105 endif()
106
Per Åstrand0954a8a2021-03-26 09:52:07 +0100107 ethosu_add_binaries(${target})
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +0100108endfunction()
109
110#############################################################################
111# Test
112#############################################################################
113
Per Åstrand9de1b742022-02-03 19:35:35 +0100114set(ETHOSU_CTEST_TARMAC_TRACE OFF CACHE BOOL "Enable to generate tarmac trace files when running ctest")
115
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +0100116function(ethosu_add_test target)
117 if(NOT BUILD_TESTING)
118 return()
119 endif()
120
121 cmake_parse_arguments(ARGS "" "NAME" "COMMAND" ${ARGN})
122
123 if (NOT ARGS_COMMAND)
124 set(ARGS_COMMAND ${ETHOSU_COMMAND_DEFAULT})
125 endif()
126
127 if (NOT ARGS_NAME)
128 set(ARGS_NAME ${target})
129 endif()
130
131 add_test(NAME ${ARGS_NAME}
132 COMMAND ${ARGS_COMMAND} $<TARGET_FILE:${target}>)
133endfunction()
134
135#############################################################################
136# Executable and test
137#############################################################################
138
139function(ethosu_add_executable_test target)
140 ethosu_add_executable(${target} ${ARGN})
141 ethosu_add_test(${target} ${ARGN})
142endfunction()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100143
144#############################################################################
145# Generate binaries
146#############################################################################
147
Kristofer Jonssond3874052021-11-25 13:07:27 +0100148set(Python3_FIND_STRATEGY LOCATION)
149find_package(Python3 COMPONENTS Interpreter)
150
Per Åstrand0954a8a2021-03-26 09:52:07 +0100151function(ethosu_add_binaries target)
Kristofer Jonssonec451552021-06-04 18:02:59 +0200152 set(SCRIPTS_DIR ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../scripts)
153
Per Åstrand0954a8a2021-03-26 09:52:07 +0100154 add_custom_command(TARGET ${target} POST_BUILD
Kristofer Jonssond3874052021-11-25 13:07:27 +0100155 COMMAND ${Python3_EXECUTABLE} ${SCRIPTS_DIR}/generate_binaries.py --output ./fw $<TARGET_FILE:${target}> -d ${target}.d
Kristofer Jonsson89487042021-11-16 16:26:41 +0100156 DEPFILE ${CMAKE_CURRENT_BINARY_DIR}/${target}.d
Per Åstrand0954a8a2021-03-26 09:52:07 +0100157 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
158 COMMENT "Generate binaries for ${target}")
Kristofer Jonssonec451552021-06-04 18:02:59 +0200159endfunction()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100160
Kristofer Jonssonec451552021-06-04 18:02:59 +0200161#############################################################################
162# Ethos-U NPU configuration
163#############################################################################
164
165function(ethosu_get_architecture config)
166 string(TOLOWER ${config} config)
Kristofer Jonssona2f95d42021-06-30 13:07:35 +0200167
168 if(${config} STREQUAL "none")
169 set(ETHOSU_ARCH "none" PARENT_SCOPE)
170 set(ETHOSU_NUM_MACS 0 PARENT_SCOPE)
171 elseif(${config} MATCHES "^ethos-(u[0-9]+|uz)-([0-9]+$)")
Kristofer Jonssonec451552021-06-04 18:02:59 +0200172 set(ETHOSU_ARCH ${CMAKE_MATCH_1} PARENT_SCOPE)
173 set(ETHOSU_NUM_MACS ${CMAKE_MATCH_2} PARENT_SCOPE)
174 else()
175 message(FATAL_ERROR "Unknown NPU config ${config}")
176 endif()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100177endfunction()