blob: 11c57d08ef903485d18df48042f398074defde34 [file] [log] [blame]
Kristofer Jonsson43ce4912020-11-20 09:42:53 +01001#
Anton Mobergfa3e51b2021-03-31 11:05:02 +02002# Copyright (c) 2020-2021 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
114function(ethosu_add_test target)
115 if(NOT BUILD_TESTING)
116 return()
117 endif()
118
119 cmake_parse_arguments(ARGS "" "NAME" "COMMAND" ${ARGN})
120
121 if (NOT ARGS_COMMAND)
122 set(ARGS_COMMAND ${ETHOSU_COMMAND_DEFAULT})
123 endif()
124
125 if (NOT ARGS_NAME)
126 set(ARGS_NAME ${target})
127 endif()
128
129 add_test(NAME ${ARGS_NAME}
130 COMMAND ${ARGS_COMMAND} $<TARGET_FILE:${target}>)
131endfunction()
132
133#############################################################################
134# Executable and test
135#############################################################################
136
137function(ethosu_add_executable_test target)
138 ethosu_add_executable(${target} ${ARGN})
139 ethosu_add_test(${target} ${ARGN})
140endfunction()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100141
142#############################################################################
143# Generate binaries
144#############################################################################
145
146function(ethosu_add_binaries target)
Kristofer Jonssonec451552021-06-04 18:02:59 +0200147 set(SCRIPTS_DIR ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../scripts)
148
Per Åstrand0954a8a2021-03-26 09:52:07 +0100149 add_custom_command(TARGET ${target} POST_BUILD
Kristofer Jonsson89487042021-11-16 16:26:41 +0100150 COMMAND ${SCRIPTS_DIR}/generate_binaries.py --output ./fw $<TARGET_FILE:${target}> -d ${target}.d
151 DEPFILE ${CMAKE_CURRENT_BINARY_DIR}/${target}.d
Per Åstrand0954a8a2021-03-26 09:52:07 +0100152 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
153 COMMENT "Generate binaries for ${target}")
Kristofer Jonssonec451552021-06-04 18:02:59 +0200154endfunction()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100155
Kristofer Jonssonec451552021-06-04 18:02:59 +0200156#############################################################################
157# Ethos-U NPU configuration
158#############################################################################
159
160function(ethosu_get_architecture config)
161 string(TOLOWER ${config} config)
Kristofer Jonssona2f95d42021-06-30 13:07:35 +0200162
163 if(${config} STREQUAL "none")
164 set(ETHOSU_ARCH "none" PARENT_SCOPE)
165 set(ETHOSU_NUM_MACS 0 PARENT_SCOPE)
166 elseif(${config} MATCHES "^ethos-(u[0-9]+|uz)-([0-9]+$)")
Kristofer Jonssonec451552021-06-04 18:02:59 +0200167 set(ETHOSU_ARCH ${CMAKE_MATCH_1} PARENT_SCOPE)
168 set(ETHOSU_NUM_MACS ${CMAKE_MATCH_2} PARENT_SCOPE)
169 else()
170 message(FATAL_ERROR "Unknown NPU config ${config}")
171 endif()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100172endfunction()