blob: 089a1c9422c8f7de90a8284eae2b81c38ad9afbc [file] [log] [blame]
Kristofer Jonsson18239302020-04-17 08:45:38 +02001#
Anton Moberge348f8f2021-03-31 11:08:58 +02002# Copyright (c) 2019-2021 Arm Limited. All rights reserved.
Kristofer Jonsson18239302020-04-17 08:45:38 +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
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 +020030get_filename_component(TFLU_TARGET_TOOLCHAIN_ROOT ${CMAKE_C_COMPILER} DIRECTORY)
31
Jonas Ohlsson7f3c1c92021-05-05 10:48:03 +020032set(TFLU_TARGET_TOOLCHAIN_ROOT "'${TFLU_TARGET_TOOLCHAIN_ROOT}'/")
Kristofer Jonsson18239302020-04-17 08:45:38 +020033set(TFLU_PATH "${TENSORFLOW_PATH}/tensorflow/lite/micro")
Jonas Ohlsson7f3c1c92021-05-05 10:48:03 +020034set(TFLU_GENDIR "${CMAKE_CURRENT_BINARY_DIR}/tensorflow/")
Måns Nilsson1aa56dd2020-09-17 15:38:58 +020035set(TFLU_TARGET "cortex_m_generic")
Bhavik Patelf946f6f2020-12-11 09:45:40 +010036set(TFLU_TARGET_ARCH ${CMAKE_SYSTEM_PROCESSOR}${CPU_FEATURES}
37 CACHE STRING "Tensorflow Lite for Microcontrollers target architecture")
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
Kristofer Jonsson18239302020-04-17 08:45:38 +020041
Jonas Ohlsson7f3c1c92021-05-05 10:48:03 +020042if (TFLU_PREBUILT_LIBRARY_PATH)
43 set(TFLU_IMPORTED_LIB_PATH "${TFLU_PREBUILT_LIBRARY_PATH}")
44 message(STATUS "Using a prebuilt TensorFlow Lite for Microcontrollers library: ${TFLU_IMPORTED_LIB_PATH}")
45else()
46 if(CORE_SOFTWARE_ACCELERATOR STREQUAL NPU)
47 set(TFLU_ETHOSU_LIBS $<TARGET_FILE:ethosu_core_driver>)
48 # Set preference for ethos-u over cmsis-nn
49 set(TFLU_OPTIMIZED_KERNEL_DIR "cmsis_nn")
50 set(TFLU_CO_PROCESSOR "ethos_u")
51 elseif(CORE_SOFTWARE_ACCELERATOR STREQUAL CMSIS-NN)
52 set(TFLU_OPTIMIZED_KERNEL_DIR "cmsis_nn")
53 endif()
54
55 # Windows: change to relative paths.
56 if (CMAKE_HOST_SYSTEM_NAME STREQUAL Windows)
57 file(RELATIVE_PATH CMSIS_PATH ${TENSORFLOW_PATH} ${CMSIS_PATH})
58 file(RELATIVE_PATH CORE_DRIVER_PATH ${TENSORFLOW_PATH} ${CORE_DRIVER_PATH})
59 endif()
60
61 # Command and target
62 add_custom_target(tflu_gen ALL
Kristofer Jonssond273d8e2020-10-13 09:35:55 +020063 COMMAND make -j${J} -f ${TFLU_PATH}/tools/make/Makefile microlite
Måns Nilsson1aa56dd2020-09-17 15:38:58 +020064 TARGET_TOOLCHAIN_ROOT=${TFLU_TARGET_TOOLCHAIN_ROOT}
65 TOOLCHAIN=${TFLU_TOOLCHAIN}
Kristofer Jonssond273d8e2020-10-13 09:35:55 +020066 GENDIR=${TFLU_GENDIR}
67 TARGET=${TFLU_TARGET}
68 TARGET_ARCH=${TFLU_TARGET_ARCH}
Måns Nilsson844d57d2021-01-18 11:11:24 +010069 OPTIMIZED_KERNEL_DIR="${TFLU_OPTIMIZED_KERNEL_DIR}"
70 CO_PROCESSOR="${TFLU_CO_PROCESSOR}"
Kristofer Jonssond273d8e2020-10-13 09:35:55 +020071 $<$<BOOL:${FLOAT}>:FLOAT=${FLOAT}>
72 BUILD_TYPE=${TFLU_BUILD_TYPE}
73 $<$<BOOL:${TFLU_OPTIMIZATION_LEVEL}>:OPTIMIZATION_LEVEL=${TFLU_OPTIMIZATION_LEVEL}>
74 CMSIS_PATH=${CMSIS_PATH}
75 ETHOSU_DRIVER_PATH=${CORE_DRIVER_PATH}
76 ETHOSU_DRIVER_LIBS=${TFLU_ETHOSU_LIBS}
Per Åstrand69c6aa92020-10-12 10:55:52 +020077 BYPRODUCTS ${CMAKE_CURRENT_SOURCE_DIR}/tensorflow/tensorflow/lite/micro/tools/make/downloads
Kristofer Jonsson18239302020-04-17 08:45:38 +020078 WORKING_DIRECTORY ${TENSORFLOW_PATH})
79
Jonas Ohlsson7f3c1c92021-05-05 10:48:03 +020080 set(TFLU_IMPORTED_LIB_PATH "${TFLU_GENDIR}/lib/libtensorflow-microlite.a")
81endif()
82
Kristofer Jonsson18239302020-04-17 08:45:38 +020083# Create library and link library to custom target
84add_library(tflu STATIC IMPORTED)
Jonas Ohlsson7f3c1c92021-05-05 10:48:03 +020085set_property(TARGET tflu PROPERTY IMPORTED_LOCATION "${TFLU_IMPORTED_LIB_PATH}")
Kristofer Jonsson18239302020-04-17 08:45:38 +020086add_dependencies(tflu tflu_gen)
Kristofer Jonsson5d6d4742021-06-07 16:07:54 +020087target_include_directories(tflu INTERFACE
88 ${TENSORFLOW_PATH})
89target_compile_options(tflu INTERFACE
90 -I${TENSORFLOW_PATH}/tensorflow/lite/micro/tools/make/downloads/flatbuffers/include)
Kristofer Jonsson6f144be2020-11-16 09:21:20 +010091target_compile_definitions(tflu INTERFACE TF_LITE_MICRO TF_LITE_STATIC_MEMORY)
Bhavik Patel50aa51d2020-07-27 17:23:31 +020092
Kristofer Jonsson91f600c2021-02-10 11:29:52 +010093if(${TFLU_BUILD_TYPE} STREQUAL "release")
94 target_compile_definitions(tflu INTERFACE TF_LITE_STRIP_ERROR_STRINGS)
95endif()
96
Henrik Hoglind78f7f942020-10-29 10:12:15 +010097if(CORE_SOFTWARE_ACCELERATOR STREQUAL NPU)
98 target_link_libraries(tflu INTERFACE ethosu_core_driver)
99endif()
100
Bhavik Patel50aa51d2020-07-27 17:23:31 +0200101# Install libraries and header files
102get_target_property(TFLU_IMPORTED_LOCATION tflu IMPORTED_LOCATION)
103install(FILES ${TFLU_IMPORTED_LOCATION} DESTINATION "lib")