blob: da954c06848af2bd9f5c1caabf2533b16eb482a0 [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.
30 set_property(GLOBAL PROPERTY ETHOSU_TARGET_LINK_FILE ${CMAKE_CURRENT_SOURCE_DIR}/${ARG_LINK_FILE})
31
32 if (ARG_ENTRY)
33 target_link_options(${target} ${scope} --entry Reset_Handler)
34 endif()
35endfunction()
36
37function(ethosu_eval_link_options target)
38 # Get the link file from the cache
39 get_property(LINK_FILE GLOBAL PROPERTY ETHOSU_TARGET_LINK_FILE)
40
41 set(prop "$<TARGET_PROPERTY:${target},COMPILE_DEFINITIONS>")
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010042
43 if (CMAKE_CXX_COMPILER_ID STREQUAL "ARMClang")
Jonas Ohlssonf821c612021-06-04 14:58:34 +020044 set(LINK_FILE_EXT scatter)
45 set(LINK_FILE_IN ${LINK_FILE}.${LINK_FILE_EXT})
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)
51 set(LINK_FILE_IN ${LINK_FILE}.${LINK_FILE_EXT})
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010052 set(LINK_FILE_OPTION "-T")
Jonas Ohlssonf821c612021-06-04 14:58:34 +020053 set(COMPILER_PREPROCESSOR_OPTIONS -E -x c -P)
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010054 endif()
55
Jonas Ohlssonf821c612021-06-04 14:58:34 +020056 get_filename_component(LINK_FILE_OUT_BASE ${LINK_FILE} NAME)
57 set(LINK_FILE_OUT ${CMAKE_CURRENT_BINARY_DIR}/${LINK_FILE_OUT_BASE}-${target}.${LINK_FILE_EXT})
58
59 add_custom_command(
60 OUTPUT ${LINK_FILE_OUT}
61 DEPENDS ${LINK_FILE_IN}
62 BYPRODUCTS ${LINK_FILE_OUT}
63 COMMAND ${CMAKE_C_COMPILER} ${COMPILER_PREPROCESSOR_OPTIONS} -o ${LINK_FILE_OUT} ${LINK_FILE_IN}
64 COMMAND_EXPAND_LISTS "-D$<JOIN:${prop},;-D>"
65 COMMAND_EXPAND_LISTS "-I$<JOIN:$<TARGET_PROPERTY:${target},INCLUDE_DIRECTORIES>,;-I>"
66 COMMENT "Preprocessing and generating linker script"
67 VERBATIM)
68 add_custom_target(${target}-linker-script
69 DEPENDS ${LINK_FILE_OUT}
70 VERBATIM)
71 add_dependencies(${target} ${target}-linker-script)
72
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +010073 target_link_options(${target} PUBLIC ${LINK_FILE_OPTION} ${LINK_FILE_OUT})
Kristofer Jonsson43ce4912020-11-20 09:42:53 +010074 set_target_properties(${target} PROPERTIES LINK_DEPENDS ${LINK_FILE_OUT})
75endfunction()
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +010076
77#############################################################################
78# Executable
79#############################################################################
80
81function(ethosu_add_executable target)
82 cmake_parse_arguments(ARGS "" "TARGET_LIBRARY" "SOURCES;LIBRARIES" ${ARGN})
83 add_executable(${target})
84
85 target_sources(${target} PRIVATE
86 ${ARGS_SOURCES})
87
88 if(NOT ARGS_TARGET_LIBRARY)
89 set(ARGS_TARGET_LIBRARY ethosu_target_init)
90 endif()
91
92 target_link_libraries(${target} PRIVATE
93 ${ARGS_TARGET_LIBRARY} ethosu_core ${ARGS_LIBRARIES})
94
95 ethosu_eval_link_options(${target})
Per Åstrand0954a8a2021-03-26 09:52:07 +010096
Per Åstrand6440bba2021-03-29 15:58:16 +020097 if (CMAKE_CXX_COMPILER_ID STREQUAL "ARMClang")
98 target_link_options(${target} PRIVATE --map --list=${target}.map)
99 elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
100 target_link_options(${target} PRIVATE -Xlinker -Map=${target}.map)
101 endif()
102
Per Åstrand0954a8a2021-03-26 09:52:07 +0100103 ethosu_add_binaries(${target})
Kristofer Jonssonf62c3d72021-01-21 17:39:03 +0100104endfunction()
105
106#############################################################################
107# Test
108#############################################################################
109
110function(ethosu_add_test target)
111 if(NOT BUILD_TESTING)
112 return()
113 endif()
114
115 cmake_parse_arguments(ARGS "" "NAME" "COMMAND" ${ARGN})
116
117 if (NOT ARGS_COMMAND)
118 set(ARGS_COMMAND ${ETHOSU_COMMAND_DEFAULT})
119 endif()
120
121 if (NOT ARGS_NAME)
122 set(ARGS_NAME ${target})
123 endif()
124
125 add_test(NAME ${ARGS_NAME}
126 COMMAND ${ARGS_COMMAND} $<TARGET_FILE:${target}>)
127endfunction()
128
129#############################################################################
130# Executable and test
131#############################################################################
132
133function(ethosu_add_executable_test target)
134 ethosu_add_executable(${target} ${ARGN})
135 ethosu_add_test(${target} ${ARGN})
136endfunction()
Per Åstrand0954a8a2021-03-26 09:52:07 +0100137
138#############################################################################
139# Generate binaries
140#############################################################################
141
142function(ethosu_add_binaries target)
143 add_custom_command(TARGET ${target} POST_BUILD
144 COMMAND ${SCRIPTS_DIR}/generate_binaries.py --output ./fw $<TARGET_FILE:${target}>
145 BYPRODUCTS ${CMAKE_CURRENT_BINARY_DIR}/fw/*
146 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
147 COMMENT "Generate binaries for ${target}")
148
149endfunction()