blob: 3444e6447197268ae66ec48296fa817c1811c973 [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}
67 BYPRODUCTS ${LINK_FILE_OUT}
68 COMMAND ${CMAKE_C_COMPILER} ${COMPILER_PREPROCESSOR_OPTIONS} -o ${LINK_FILE_OUT} ${LINK_FILE_IN}
69 COMMAND_EXPAND_LISTS "-D$<JOIN:${prop},;-D>"
70 COMMAND_EXPAND_LISTS "-I$<JOIN:$<TARGET_PROPERTY:${target},INCLUDE_DIRECTORIES>,;-I>"
71 COMMENT "Preprocessing and generating linker script"
72 VERBATIM)
73 add_custom_target(${target}-linker-script
74 DEPENDS ${LINK_FILE_OUT}
75 VERBATIM)
76 add_dependencies(${target} ${target}-linker-script)
77
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +010078 target_link_options(${target} PUBLIC ${LINK_FILE_OPTION} ${LINK_FILE_OUT})
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010079 set_target_properties(${target} PROPERTIES LINK_DEPENDS ${LINK_FILE_OUT})
80endfunction()
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +010081
82#############################################################################
83# Executable
84#############################################################################
85
86function(ethosu_add_executable target)
87 cmake_parse_arguments(ARGS "" "TARGET_LIBRARY" "SOURCES;LIBRARIES" ${ARGN})
88 add_executable(${target})
89
90 target_sources(${target} PRIVATE
91 ${ARGS_SOURCES})
92
93 if(NOT ARGS_TARGET_LIBRARY)
94 set(ARGS_TARGET_LIBRARY ethosu_target_init)
95 endif()
96
97 target_link_libraries(${target} PRIVATE
98 ${ARGS_TARGET_LIBRARY} ethosu_core ${ARGS_LIBRARIES})
99
100 ethosu_eval_link_options(${target})
Per Åstrand0954a8a2021-03-26 09:52:07 +0100101
Per Åstrand6440bba2021-03-29 15:58:16 +0200102 if (CMAKE_CXX_COMPILER_ID STREQUAL "ARMClang")
103 target_link_options(${target} PRIVATE --map --list=${target}.map)
104 elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
105 target_link_options(${target} PRIVATE -Xlinker -Map=${target}.map)
106 endif()
107
Per Åstrand0954a8a2021-03-26 09:52:07 +0100108 ethosu_add_binaries(${target})
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +0100109endfunction()
110
111#############################################################################
112# Test
113#############################################################################
114
115function(ethosu_add_test target)
116 if(NOT BUILD_TESTING)
117 return()
118 endif()
119
120 cmake_parse_arguments(ARGS "" "NAME" "COMMAND" ${ARGN})
121
122 if (NOT ARGS_COMMAND)
123 set(ARGS_COMMAND ${ETHOSU_COMMAND_DEFAULT})
124 endif()
125
126 if (NOT ARGS_NAME)
127 set(ARGS_NAME ${target})
128 endif()
129
130 add_test(NAME ${ARGS_NAME}
131 COMMAND ${ARGS_COMMAND} $<TARGET_FILE:${target}>)
132endfunction()
133
134#############################################################################
135# Executable and test
136#############################################################################
137
138function(ethosu_add_executable_test target)
139 ethosu_add_executable(${target} ${ARGN})
140 ethosu_add_test(${target} ${ARGN})
141endfunction()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100142
143#############################################################################
144# Generate binaries
145#############################################################################
146
147function(ethosu_add_binaries target)
Kristofer Jonssonec451552021-06-04 18:02:59 +0200148 set(SCRIPTS_DIR ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../scripts)
149
Per Åstrand0954a8a2021-03-26 09:52:07 +0100150 add_custom_command(TARGET ${target} POST_BUILD
151 COMMAND ${SCRIPTS_DIR}/generate_binaries.py --output ./fw $<TARGET_FILE:${target}>
152 BYPRODUCTS ${CMAKE_CURRENT_BINARY_DIR}/fw/*
153 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
154 COMMENT "Generate binaries for ${target}")
Kristofer Jonssonec451552021-06-04 18:02:59 +0200155endfunction()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100156
Kristofer Jonssonec451552021-06-04 18:02:59 +0200157#############################################################################
158# Ethos-U NPU configuration
159#############################################################################
160
161function(ethosu_get_architecture config)
162 string(TOLOWER ${config} config)
163 if(${config} MATCHES "^ethos-(u[0-9]+|uz)-([0-9]+$)")
164 set(ETHOSU_ARCH ${CMAKE_MATCH_1} PARENT_SCOPE)
165 set(ETHOSU_NUM_MACS ${CMAKE_MATCH_2} PARENT_SCOPE)
166 else()
167 message(FATAL_ERROR "Unknown NPU config ${config}")
168 endif()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100169endfunction()