alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 1 | #---------------------------------------------------------------------------- |
alexander | cb8a987 | 2022-02-11 13:23:22 +0000 | [diff] [blame] | 2 | # Copyright (c) 2021 - 2022 Arm Limited. All rights reserved. |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 3 | # SPDX-License-Identifier: Apache-2.0 |
| 4 | # |
| 5 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 6 | # you may not use this file except in compliance with the License. |
| 7 | # You may obtain a copy of the License at |
| 8 | # |
| 9 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 10 | # |
| 11 | # Unless required by applicable law or agreed to in writing, software |
| 12 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 13 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 14 | # See the License for the specific language governing permissions and |
| 15 | # limitations under the License. |
| 16 | #---------------------------------------------------------------------------- |
| 17 | |
| 18 | include(ProcessorCount) |
| 19 | ProcessorCount(J) |
| 20 | |
| 21 | if (CMAKE_BUILD_TYPE STREQUAL Debug) |
Richard Burton | 0d11059 | 2021-08-12 17:26:30 +0100 | [diff] [blame] | 22 | set(TENSORFLOW_LITE_MICRO_CORE_OPTIMIZATION_LEVEL "-O0") |
| 23 | set(TENSORFLOW_LITE_MICRO_KERNEL_OPTIMIZATION_LEVEL "-O0") |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 24 | elseif (CMAKE_BUILD_TYPE STREQUAL Release) |
Richard Burton | 0d11059 | 2021-08-12 17:26:30 +0100 | [diff] [blame] | 25 | set(TENSORFLOW_LITE_MICRO_CORE_OPTIMIZATION_LEVEL "-O3") |
| 26 | set(TENSORFLOW_LITE_MICRO_KERNEL_OPTIMIZATION_LEVEL "-O3") |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 27 | endif() |
| 28 | |
Kshitij Sisodia | b59ba68 | 2021-11-23 17:19:52 +0000 | [diff] [blame] | 29 | assert_defined(TENSORFLOW_LITE_MICRO_BUILD_TYPE) |
| 30 | assert_defined(TENSORFLOW_LITE_MICRO_CLEAN_DOWNLOADS) |
| 31 | assert_defined(TENSORFLOW_LITE_MICRO_CLEAN_BUILD) |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 32 | |
| 33 | if (CMAKE_CXX_COMPILER_ID STREQUAL "ARMClang") |
| 34 | set(TENSORFLOW_LITE_MICRO_TOOLCHAIN "armclang") |
| 35 | elseif (CMAKE_CXX_COMPILER_ID STREQUAL "GNU") |
| 36 | set(TENSORFLOW_LITE_MICRO_TOOLCHAIN "gcc") |
| 37 | else () |
| 38 | message(FATAL_ERROR "No compiler ID is set") |
| 39 | endif() |
| 40 | |
| 41 | get_filename_component(TENSORFLOW_LITE_MICRO_TARGET_TOOLCHAIN_ROOT ${CMAKE_C_COMPILER} DIRECTORY) |
| 42 | set(TENSORFLOW_LITE_MICRO_TARGET_TOOLCHAIN_ROOT "${TENSORFLOW_LITE_MICRO_TARGET_TOOLCHAIN_ROOT}/") |
| 43 | |
| 44 | set(TENSORFLOW_LITE_MICRO_PATH "${TENSORFLOW_SRC_PATH}/tensorflow/lite/micro") |
| 45 | set(TENSORFLOW_LITE_MICRO_GENDIR ${CMAKE_CURRENT_BINARY_DIR}/tensorflow/) |
alexander | 31ae9f0 | 2022-02-10 16:15:54 +0000 | [diff] [blame] | 46 | set(TENSORFLOW_LITE_MICRO_PLATFORM_LIB_NAME "libtensorflow-microlite.a") |
ayamas01 | 15f8070 | 2021-11-18 14:22:23 +0000 | [diff] [blame] | 47 | |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 48 | if (TARGET_PLATFORM STREQUAL native) |
| 49 | set(TENSORFLOW_LITE_MICRO_TARGET "linux") |
| 50 | set(TENSORFLOW_LITE_MICRO_TARGET_ARCH x86_64) |
| 51 | else() |
Nina Drozd | 68549b4 | 2022-02-15 14:32:57 +0000 | [diff] [blame^] | 52 | set(TENSORFLOW_LITE_MICRO_TARGET "cortex_m_generic") |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 53 | set(TENSORFLOW_LITE_MICRO_TARGET_ARCH ${CMAKE_SYSTEM_PROCESSOR}${CPU_FEATURES}) |
Cisco Cervellera | f085fa5 | 2021-08-02 09:32:07 +0100 | [diff] [blame] | 54 | if(ETHOS_U_NPU_ENABLED) |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 55 | # Arm Ethos-U55 NPU is the co-processor for ML workload: |
| 56 | set(TENSORFLOW_LITE_MICRO_CO_PROCESSOR "ethos_u") |
Nina Drozd | 68549b4 | 2022-02-15 14:32:57 +0000 | [diff] [blame^] | 57 | string(TOLOWER ${ETHOS_U_NPU_ID} ETHOSU_ARCH) |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 58 | endif() |
| 59 | |
| 60 | set(TENSORFLOW_LITE_MICRO_OPTIMIZED_KERNEL "cmsis_nn") |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 61 | endif() |
| 62 | |
| 63 | if (TENSORFLOW_LITE_MICRO_CLEAN_DOWNLOADS) |
| 64 | list(APPEND MAKE_TARGETS_LIST "clean_downloads") |
| 65 | endif() |
| 66 | |
| 67 | if (TENSORFLOW_LITE_MICRO_CLEAN_BUILD) |
| 68 | list(APPEND MAKE_TARGETS_LIST "clean") |
| 69 | endif() |
| 70 | |
Richard Burton | 527b474 | 2021-11-26 12:17:19 +0000 | [diff] [blame] | 71 | if (ETHOS_U_NPU_ID) |
| 72 | string(TOLOWER ${ETHOS_U_NPU_ID} ETHOSU_ARCH) |
| 73 | endif() |
| 74 | |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 75 | # Primary target |
| 76 | list(APPEND MAKE_TARGETS_LIST "microlite") |
| 77 | message(STATUS "TensorFlow Lite Micro build to be called for these targets: ${MAKE_TARGETS_LIST}") |
| 78 | |
| 79 | # Commands and targets |
| 80 | add_custom_target(tensorflow_build ALL |
| 81 | |
| 82 | # Command to build the TensorFlow Lite Micro library |
| 83 | COMMAND make -j${J} -f ${TENSORFLOW_LITE_MICRO_PATH}/tools/make/Makefile ${MAKE_TARGETS_LIST} |
| 84 | TARGET_TOOLCHAIN_ROOT=${TENSORFLOW_LITE_MICRO_TARGET_TOOLCHAIN_ROOT} |
| 85 | TOOLCHAIN=${TENSORFLOW_LITE_MICRO_TOOLCHAIN} |
| 86 | GENDIR=${TENSORFLOW_LITE_MICRO_GENDIR} |
| 87 | TARGET=${TENSORFLOW_LITE_MICRO_TARGET} |
| 88 | TARGET_ARCH=${TENSORFLOW_LITE_MICRO_TARGET_ARCH} |
| 89 | BUILD_TYPE=${TENSORFLOW_LITE_MICRO_BUILD_TYPE} |
alexander | 31ae9f0 | 2022-02-10 16:15:54 +0000 | [diff] [blame] | 90 | CMSIS_PATH=${CMSIS_SRC_PATH} |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 91 | # Conditional arguments |
Nina Drozd | 68549b4 | 2022-02-15 14:32:57 +0000 | [diff] [blame^] | 92 | $<$<BOOL:${ETHOS_U_NPU_ENABLED}>:ETHOSU_ARCH=${ETHOSU_ARCH}> |
| 93 | $<$<BOOL:${ETHOS_U_NPU_ENABLED}>:ETHOSU_DRIVER_PATH=${ETHOS_U_NPU_DRIVER_SRC_PATH}> |
| 94 | $<$<BOOL:${ETHOS_U_NPU_ENABLED}>:ETHOSU_DRIVER_LIBS=$<TARGET_FILE:ethosu_core_driver>> |
| 95 | |
Richard Burton | 0d11059 | 2021-08-12 17:26:30 +0100 | [diff] [blame] | 96 | $<$<BOOL:${TENSORFLOW_LITE_MICRO_CORE_OPTIMIZATION_LEVEL}>:CORE_OPTIMIZATION_LEVEL=${TENSORFLOW_LITE_MICRO_CORE_OPTIMIZATION_LEVEL}> |
| 97 | $<$<BOOL:${TENSORFLOW_LITE_MICRO_KERNEL_OPTIMIZATION_LEVEL}>:KERNEL_OPTIMIZATION_LEVEL=${TENSORFLOW_LITE_MICRO_KERNEL_OPTIMIZATION_LEVEL}> |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 98 | $<$<BOOL:${TENSORFLOW_LITE_MICRO_OPTIMIZED_KERNEL}>:OPTIMIZED_KERNEL_DIR=${TENSORFLOW_LITE_MICRO_OPTIMIZED_KERNEL}> |
| 99 | $<$<BOOL:${TENSORFLOW_LITE_MICRO_CO_PROCESSOR}>:CO_PROCESSOR=${TENSORFLOW_LITE_MICRO_CO_PROCESSOR}> |
| 100 | |
| 101 | # Command to copy over the generated library to the local build tree. |
| 102 | COMMAND ${CMAKE_COMMAND} -E copy ${TENSORFLOW_LITE_MICRO_GENDIR}/lib/${TENSORFLOW_LITE_MICRO_PLATFORM_LIB_NAME} |
| 103 | ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/${TENSORFLOW_LITE_MICRO_PLATFORM_LIB_NAME} |
| 104 | |
| 105 | COMMENT "Building TensorFlow Lite Micro library..." |
| 106 | |
| 107 | BYPRODUCTS ${TENSORFLOW_SRC_PATH}/tensorflow/tensorflow/lite/micro/tools/make/downloads |
| 108 | ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/${TENSORFLOW_LITE_MICRO_PLATFORM_LIB_NAME} |
| 109 | ${TENSORFLOW_LITE_MICRO_GENDIR}/lib/${TENSORFLOW_LITE_MICRO_PLATFORM_LIB_NAME} |
| 110 | |
| 111 | WORKING_DIRECTORY ${TENSORFLOW_SRC_PATH}) |
| 112 | |
| 113 | # Create library |
alexander | 31ae9f0 | 2022-02-10 16:15:54 +0000 | [diff] [blame] | 114 | |
Nina Drozd | 68549b4 | 2022-02-15 14:32:57 +0000 | [diff] [blame^] | 115 | |
| 116 | set(TENSORFLOW_LITE_MICRO_TARGET tensorflow-lite-micro) |
| 117 | add_library(${TENSORFLOW_LITE_MICRO_TARGET} STATIC IMPORTED) |
| 118 | |
| 119 | if(ETHOS_U_NPU_ENABLED) |
| 120 | add_dependencies(tensorflow_build ethosu_core_driver) |
| 121 | endif() |
alexander | 31ae9f0 | 2022-02-10 16:15:54 +0000 | [diff] [blame] | 122 | |
alexander | 3c79893 | 2021-03-26 21:42:19 +0000 | [diff] [blame] | 123 | add_dependencies(tensorflow-lite-micro tensorflow_build) |
alexander | 31ae9f0 | 2022-02-10 16:15:54 +0000 | [diff] [blame] | 124 | |
ayamas01 | 15f8070 | 2021-11-18 14:22:23 +0000 | [diff] [blame] | 125 | set_property(TARGET tensorflow-lite-micro PROPERTY IMPORTED_LOCATION |
| 126 | "${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/${TENSORFLOW_LITE_MICRO_PLATFORM_LIB_NAME}") |
alexander | 31ae9f0 | 2022-02-10 16:15:54 +0000 | [diff] [blame] | 127 | |
| 128 | target_include_directories(tensorflow-lite-micro |
| 129 | INTERFACE |
| 130 | ${TENSORFLOW_SRC_PATH}) |
| 131 | |
| 132 | target_compile_definitions(tensorflow-lite-micro |
| 133 | INTERFACE |
Nina Drozd | 68549b4 | 2022-02-15 14:32:57 +0000 | [diff] [blame^] | 134 | TF_LITE_STATIC_MEMORY) |