blob: 5e95bdd8024f99435c91abc525a7fb29b5951400 [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
Davide Grohmannffb8ccd2022-08-24 11:16:21 +020019if(NOT TARGET freertos_kernel)
20 message("Skipping message handler")
Yulia Garbovichf61ea352021-11-11 14:16:57 +020021 return()
22endif()
23
Kristofer Jonssona739d212022-05-05 12:11:52 +020024# Split total tensor arena equally for each NPU
Davide Grohmannffb8ccd2022-08-24 11:16:21 +020025if(TARGET ethosu_core_driver AND ETHOSU_TARGET_NPU_COUNT GREATER 0)
Kristofer Jonssona739d212022-05-05 12:11:52 +020026 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)
Davide Grohmannec72e9b2022-08-08 17:30:28 +020035add_subdirectory(test)
Davide Grohmann144b2d22022-05-31 15:24:02 +020036
37set(MESSAGE_HANDLER_MODEL_0 "" CACHE STRING "Path to built in model 0")
38set(MESSAGE_HANDLER_MODEL_1 "" CACHE STRING "Path to built in model 1")
39set(MESSAGE_HANDLER_MODEL_2 "" CACHE STRING "Path to built in model 2")
40set(MESSAGE_HANDLER_MODEL_3 "" CACHE STRING "Path to built in model 3")
41
42ethosu_add_executable(message_handler
43 SOURCES
Davide Grohmannffb8ccd2022-08-24 11:16:21 +020044 main.cpp
Davide Grohmann144b2d22022-05-31 15:24:02 +020045 LIBRARIES
Davide Grohmannffb8ccd2022-08-24 11:16:21 +020046 message_handler_lib
47 freertos_kernel)
Davide Grohmann144b2d22022-05-31 15:24:02 +020048
49target_include_directories(message_handler PRIVATE
50 indexed_networks
51 ${LINUX_DRIVER_STACK_PATH}/kernel)
52
Yulia Garbovichf61ea352021-11-11 14:16:57 +020053target_compile_definitions(message_handler PRIVATE
Kristofer Jonssona739d212022-05-05 12:11:52 +020054 TENSOR_ARENA_SIZE=${TENSOR_ARENA_SIZE}
Kristofer Jonsson585ce692022-03-08 13:28:05 +010055 $<$<BOOL:${MESSAGE_HANDLER_MODEL_0}>:MODEL_0=${MESSAGE_HANDLER_MODEL_0}>
56 $<$<BOOL:${MESSAGE_HANDLER_MODEL_1}>:MODEL_1=${MESSAGE_HANDLER_MODEL_1}>
57 $<$<BOOL:${MESSAGE_HANDLER_MODEL_2}>:MODEL_2=${MESSAGE_HANDLER_MODEL_2}>
58 $<$<BOOL:${MESSAGE_HANDLER_MODEL_3}>:MODEL_3=${MESSAGE_HANDLER_MODEL_3}>)
Per Åstrand2c76ec72022-04-26 09:57:20 +020059
60install(FILES $<TARGET_FILE:message_handler>
61 DESTINATION "lib/firmware"
62 RENAME "arm-${ETHOSU_TARGET_NPU_CONFIG}.fw"
63)