blob: 8d4ef5477b9fea48e8a802c62b8a386cf48c6439 [file] [log] [blame]
Yulia Garbovichf61ea352021-11-11 14:16:57 +02001#
Kristofer Jonssonac535f02022-03-10 11:08:39 +01002# Copyright (c) 2020-2022 Arm Limited.
Yulia Garbovichf61ea352021-11-11 14:16:57 +02003#
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
19if (NOT TARGET freertos_kernel)
20 message("Not building ethosu_message_dispatcher, required freertos not built.")
21 return()
22endif()
23
Kristofer Jonssona739d212022-05-05 12:11:52 +020024# Split total tensor arena equally for each NPU
25if (TARGET ethosu_core_driver AND ETHOSU_TARGET_NPU_COUNT GREATER 0)
26 set(NUM_ARENAS ${ETHOSU_TARGET_NPU_COUNT})
27else()
28 set(NUM_ARENAS 1)
29endif()
30
Davide Grohmann144b2d22022-05-31 15:24:02 +020031set(MESSAGE_HANDLER_ARENA_SIZE 2000000 CACHE STRING "Total size of all message handler tensor arenas")
Kristofer Jonssona739d212022-05-05 12:11:52 +020032math(EXPR TENSOR_ARENA_SIZE "${MESSAGE_HANDLER_ARENA_SIZE} / ${NUM_ARENAS}")
33
Davide Grohmann144b2d22022-05-31 15:24:02 +020034add_subdirectory(lib)
35
36set(MESSAGE_HANDLER_MODEL_0 "" CACHE STRING "Path to built in model 0")
37set(MESSAGE_HANDLER_MODEL_1 "" CACHE STRING "Path to built in model 1")
38set(MESSAGE_HANDLER_MODEL_2 "" CACHE STRING "Path to built in model 2")
39set(MESSAGE_HANDLER_MODEL_3 "" CACHE STRING "Path to built in model 3")
40
41ethosu_add_executable(message_handler
42 SOURCES
43 main.cpp
44 LIBRARIES
45 message_handler_lib
46 freertos_kernel)
47
48target_include_directories(message_handler PRIVATE
49 indexed_networks
50 ${LINUX_DRIVER_STACK_PATH}/kernel)
51
Yulia Garbovichf61ea352021-11-11 14:16:57 +020052target_compile_definitions(message_handler PRIVATE
Kristofer Jonssona739d212022-05-05 12:11:52 +020053 TENSOR_ARENA_SIZE=${TENSOR_ARENA_SIZE}
Kristofer Jonsson585ce692022-03-08 13:28:05 +010054 $<$<BOOL:${MESSAGE_HANDLER_MODEL_0}>:MODEL_0=${MESSAGE_HANDLER_MODEL_0}>
55 $<$<BOOL:${MESSAGE_HANDLER_MODEL_1}>:MODEL_1=${MESSAGE_HANDLER_MODEL_1}>
56 $<$<BOOL:${MESSAGE_HANDLER_MODEL_2}>:MODEL_2=${MESSAGE_HANDLER_MODEL_2}>
57 $<$<BOOL:${MESSAGE_HANDLER_MODEL_3}>:MODEL_3=${MESSAGE_HANDLER_MODEL_3}>)
Per Åstrand2c76ec72022-04-26 09:57:20 +020058
59install(FILES $<TARGET_FILE:message_handler>
60 DESTINATION "lib/firmware"
61 RENAME "arm-${ETHOSU_TARGET_NPU_CONFIG}.fw"
62)