blob: 80f41f151dce58deb9df8419c65a7bed03ef5ed5 [file] [log] [blame]
Kristofer Jonsson18239302020-04-17 08:45:38 +02001#
2# Copyright (c) 2019-2020 Arm Limited. All rights reserved.
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
19include(ProcessorCount)
20ProcessorCount(J)
21
Per Åstrand3f6e07a2020-05-12 13:16:37 +020022if (CMAKE_CXX_COMPILER_ID STREQUAL "ARMClang")
Måns Nilsson1aa56dd2020-09-17 15:38:58 +020023 set(TFLU_TOOLCHAIN "armclang")
Per Åstrand3f6e07a2020-05-12 13:16:37 +020024elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
Måns Nilsson1aa56dd2020-09-17 15:38:58 +020025 set(TFLU_TOOLCHAIN "gcc")
Per Åstrand3f6e07a2020-05-12 13:16:37 +020026else ()
27 message(FATAL_ERROR "No compiler ID is set")
28endif()
Kristofer Jonsson18239302020-04-17 08:45:38 +020029
Måns Nilsson1aa56dd2020-09-17 15:38:58 +020030
31get_filename_component(TFLU_TARGET_TOOLCHAIN_ROOT ${CMAKE_C_COMPILER} DIRECTORY)
32
33set(TFLU_TARGET_TOOLCHAIN_ROOT "${TFLU_TARGET_TOOLCHAIN_ROOT}/")
Kristofer Jonsson18239302020-04-17 08:45:38 +020034set(TFLU_PATH "${TENSORFLOW_PATH}/tensorflow/lite/micro")
35set(TFLU_GENDIR ${CMAKE_CURRENT_BINARY_DIR}/tensorflow/)
Måns Nilsson1aa56dd2020-09-17 15:38:58 +020036set(TFLU_TARGET "cortex_m_generic")
Kristofer Jonsson18239302020-04-17 08:45:38 +020037set(TFLU_TARGET_ARCH ${CMAKE_SYSTEM_PROCESSOR}${CPU_FEATURES})
Henrik Hoglind3598ef82020-05-28 12:09:04 +020038set(TFLU_BUILD_TYPE "release" CACHE STRING "Tensorflow Lite Mirco build type, can be release or debug")
Jonas Skog101ccef2020-09-10 08:58:16 +020039set(TFLU_OPTIMIZATION_LEVEL CACHE STRING "Tensorflow Lite Micro optimization level")
Kristofer Jonsson18239302020-04-17 08:45:38 +020040
Per Åstrand94ca3552020-06-30 10:33:58 +020041if(CORE_SOFTWARE_ACCELERATOR STREQUAL NPU)
42 set(TFLU_ETHOSU_LIBS $<TARGET_FILE:ethosu_core_driver>)
Måns Nilsson98e379c2020-09-14 16:30:56 +020043 # Set preference for ethos-u over cmsis-nn
44 list(APPEND TFLU_TAGS "cmsis-nn")
Henrik Hoglind43fd4de2020-05-08 14:18:26 +020045 list(APPEND TFLU_TAGS "ethos-u")
Per Åstrand94ca3552020-06-30 10:33:58 +020046elseif(CORE_SOFTWARE_ACCELERATOR STREQUAL CMSIS-NN)
47 list(APPEND TFLU_TAGS "cmsis-nn")
Kristofer Jonsson18239302020-04-17 08:45:38 +020048endif()
49
50string(JOIN TFLU_TAGS " " TFLU_TAGS)
51
52# Command and target
53add_custom_target(tflu_gen ALL
Kristofer Jonssond273d8e2020-10-13 09:35:55 +020054 COMMAND make -j${J} -f ${TFLU_PATH}/tools/make/Makefile microlite
Måns Nilsson1aa56dd2020-09-17 15:38:58 +020055 TARGET_TOOLCHAIN_ROOT=${TFLU_TARGET_TOOLCHAIN_ROOT}
56 TOOLCHAIN=${TFLU_TOOLCHAIN}
Kristofer Jonssond273d8e2020-10-13 09:35:55 +020057 GENDIR=${TFLU_GENDIR}
58 TARGET=${TFLU_TARGET}
59 TARGET_ARCH=${TFLU_TARGET_ARCH}
60 TAGS="${TFLU_TAGS}"
Kristofer Jonssond273d8e2020-10-13 09:35:55 +020061 $<$<BOOL:${FLOAT}>:FLOAT=${FLOAT}>
62 BUILD_TYPE=${TFLU_BUILD_TYPE}
63 $<$<BOOL:${TFLU_OPTIMIZATION_LEVEL}>:OPTIMIZATION_LEVEL=${TFLU_OPTIMIZATION_LEVEL}>
64 CMSIS_PATH=${CMSIS_PATH}
65 ETHOSU_DRIVER_PATH=${CORE_DRIVER_PATH}
66 ETHOSU_DRIVER_LIBS=${TFLU_ETHOSU_LIBS}
Per Åstrand69c6aa92020-10-12 10:55:52 +020067 BYPRODUCTS ${CMAKE_CURRENT_SOURCE_DIR}/tensorflow/tensorflow/lite/micro/tools/make/downloads
Kristofer Jonsson18239302020-04-17 08:45:38 +020068 WORKING_DIRECTORY ${TENSORFLOW_PATH})
69
70# Create library and link library to custom target
71add_library(tflu STATIC IMPORTED)
72set_property(TARGET tflu PROPERTY IMPORTED_LOCATION ${TFLU_GENDIR}/lib/libtensorflow-microlite.a)
73add_dependencies(tflu tflu_gen)
74target_include_directories(tflu INTERFACE ${TENSORFLOW_PATH})
Kristofer Jonsson641c0912020-08-31 11:34:14 +020075target_compile_definitions(tflu INTERFACE TF_LITE_STATIC_MEMORY)
Bhavik Patel50aa51d2020-07-27 17:23:31 +020076
Henrik Hoglind78f7f942020-10-29 10:12:15 +010077if(CORE_SOFTWARE_ACCELERATOR STREQUAL NPU)
78 target_link_libraries(tflu INTERFACE ethosu_core_driver)
79endif()
80
Bhavik Patel50aa51d2020-07-27 17:23:31 +020081# Install libraries and header files
82get_target_property(TFLU_IMPORTED_LOCATION tflu IMPORTED_LOCATION)
83install(FILES ${TFLU_IMPORTED_LOCATION} DESTINATION "lib")