Lior Dekel | 489e40b | 2021-08-02 12:03:55 +0300 | [diff] [blame] | 1 | # |
Mikael Olsson | ad5b6f2 | 2024-01-22 14:48:28 +0100 | [diff] [blame] | 2 | # SPDX-FileCopyrightText: Copyright 2021-2022, 2024 Arm Limited and/or its affiliates <open-source-office@arm.com> |
Lior Dekel | 489e40b | 2021-08-02 12:03:55 +0300 | [diff] [blame] | 3 | # |
| 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 | |
Ledion Daja | 05dd24d | 2022-08-15 11:49:22 +0200 | [diff] [blame] | 19 | # Exclude this app if ThreadX target does not exist or if NPU configuration is not H128 |
Mikael Olsson | f44f8b2 | 2024-01-24 13:33:34 +0100 | [diff] [blame^] | 20 | if (NOT TARGET threadx OR NOT TARGET ethosu_core_driver OR NOT ETHOSU_TARGET_NPU_CONFIG STREQUAL "ethos-u55-128" OR NOT ETHOSU_TARGET STREQUAL "corstone-300") |
Lior Dekel | 489e40b | 2021-08-02 12:03:55 +0300 | [diff] [blame] | 21 | message("Skipping ThreadX application") |
| 22 | return() |
| 23 | endif() |
| 24 | |
| 25 | ethosu_add_executable_test(threadx_demo PRIVATE |
| 26 | SOURCES main.cpp |
Kristofer Jonsson | 8f813b3 | 2022-11-23 13:05:47 +0100 | [diff] [blame] | 27 | LIBRARIES inference_process threadx) |
Lior Dekel | 489e40b | 2021-08-02 12:03:55 +0300 | [diff] [blame] | 28 | target_include_directories(threadx_demo PRIVATE models/mobilenet_v2) |
| 29 | |
Mikael Olsson | ad5b6f2 | 2024-01-22 14:48:28 +0100 | [diff] [blame] | 30 | # Make ThreadX's HardFault_Handler a weak symbol to use the platform target's handler instead |
| 31 | add_custom_command(TARGET threadx_demo PRE_LINK |
| 32 | COMMAND ${CMAKE_OBJCOPY} -W HardFault_Handler $<TARGET_FILE:threadx> |
| 33 | DEPENDS threadx |
| 34 | ) |
| 35 | |
Lior Dekel | 489e40b | 2021-08-02 12:03:55 +0300 | [diff] [blame] | 36 | # Use the fast memory to support both 11.12.57 and 11.13.x release |
| 37 | # of the FVP |
| 38 | # The size is defined to force the .bss.tensor_arena to be placed in DDR |
Kristofer Jonsson | 9317581 | 2022-04-21 19:27:11 +0200 | [diff] [blame] | 39 | target_compile_options(threadx_demo PRIVATE |
| 40 | -UETHOSU_FAST_MEMORY_SIZE -DETHOSU_FAST_MEMORY_SIZE=0xa0000 |
| 41 | -UETHOSU_ARENA -DETHOSU_ARENA=1 |
| 42 | -UETHOSU_MODEL -DETHOSU_MODEL=1) |