1*61c4878aSAndroid Build Coastguard Worker# Copyright 2021 The Pigweed Authors 2*61c4878aSAndroid Build Coastguard Worker# 3*61c4878aSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); you may not 4*61c4878aSAndroid Build Coastguard Worker# use this file except in compliance with the License. You may obtain a copy of 5*61c4878aSAndroid Build Coastguard Worker# the License at 6*61c4878aSAndroid Build Coastguard Worker# 7*61c4878aSAndroid Build Coastguard Worker# https://www.apache.org/licenses/LICENSE-2.0 8*61c4878aSAndroid Build Coastguard Worker# 9*61c4878aSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 10*61c4878aSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 11*61c4878aSAndroid Build Coastguard Worker# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 12*61c4878aSAndroid Build Coastguard Worker# License for the specific language governing permissions and limitations under 13*61c4878aSAndroid Build Coastguard Worker# the License. 14*61c4878aSAndroid Build Coastguard Worker 15*61c4878aSAndroid Build Coastguard Workerimport("//build_overrides/pigweed.gni") 16*61c4878aSAndroid Build Coastguard Worker 17*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_build/linker_script.gni") 18*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_build/target_types.gni") 19*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_docgen/docs.gni") 20*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_malloc/backend.gni") 21*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_third_party/freertos/freertos.gni") 22*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_third_party/mcuxpresso/mcuxpresso.gni") 23*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_toolchain/generate_toolchain.gni") 24*61c4878aSAndroid Build Coastguard Workerimport("target_toolchains.gni") 25*61c4878aSAndroid Build Coastguard Worker 26*61c4878aSAndroid Build Coastguard Workergenerate_toolchains("target_toolchains") { 27*61c4878aSAndroid Build Coastguard Worker toolchains = pw_target_toolchain_mimxrt595_evk_freertos_list 28*61c4878aSAndroid Build Coastguard Worker} 29*61c4878aSAndroid Build Coastguard Worker 30*61c4878aSAndroid Build Coastguard Workerdeclare_args() { 31*61c4878aSAndroid Build Coastguard Worker # When compiling with an MCUXpresso SDK, this variable is set to the path of 32*61c4878aSAndroid Build Coastguard Worker # the manifest file within the SDK installation. When set, a pw_source_set 33*61c4878aSAndroid Build Coastguard Worker # for a sample project SDK is created at 34*61c4878aSAndroid Build Coastguard Worker # "//targets/mimxrt595_evk_freertos:sdk". 35*61c4878aSAndroid Build Coastguard Worker pw_target_mimxrt595_evk_freertos_MANIFEST = "" 36*61c4878aSAndroid Build Coastguard Worker 37*61c4878aSAndroid Build Coastguard Worker # This list should contain the necessary defines for setting linker script 38*61c4878aSAndroid Build Coastguard Worker # memory regions. While we don't directly use the pw_boot_cortex_m linker 39*61c4878aSAndroid Build Coastguard Worker # script, these are deliberately matching to make being able to later easier. 40*61c4878aSAndroid Build Coastguard Worker pw_target_mimxrt595_evk_freertos_LINK_CONFIG_DEFINES = [] 41*61c4878aSAndroid Build Coastguard Worker} 42*61c4878aSAndroid Build Coastguard Worker 43*61c4878aSAndroid Build Coastguard Workerconfig("pw_malloc_active") { 44*61c4878aSAndroid Build Coastguard Worker if (pw_malloc_BACKEND != "") { 45*61c4878aSAndroid Build Coastguard Worker defines = [ "PW_MALLOC_ACTIVE=1" ] 46*61c4878aSAndroid Build Coastguard Worker } 47*61c4878aSAndroid Build Coastguard Worker} 48*61c4878aSAndroid Build Coastguard Worker 49*61c4878aSAndroid Build Coastguard Workerconfig("disable_warnings") { 50*61c4878aSAndroid Build Coastguard Worker cflags = [ 51*61c4878aSAndroid Build Coastguard Worker "-Wno-cast-qual", 52*61c4878aSAndroid Build Coastguard Worker "-Wno-redundant-decls", 53*61c4878aSAndroid Build Coastguard Worker "-Wno-undef", 54*61c4878aSAndroid Build Coastguard Worker "-Wno-unused-parameter", 55*61c4878aSAndroid Build Coastguard Worker "-Wno-unused-variable", 56*61c4878aSAndroid Build Coastguard Worker "-Wno-error=strict-prototypes", 57*61c4878aSAndroid Build Coastguard Worker ] 58*61c4878aSAndroid Build Coastguard Worker visibility = [ ":*" ] 59*61c4878aSAndroid Build Coastguard Worker} 60*61c4878aSAndroid Build Coastguard Worker 61*61c4878aSAndroid Build Coastguard Workerconfig("freestanding") { 62*61c4878aSAndroid Build Coastguard Worker cflags = [ 63*61c4878aSAndroid Build Coastguard Worker "-ffreestanding", 64*61c4878aSAndroid Build Coastguard Worker "-fno-builtin", 65*61c4878aSAndroid Build Coastguard Worker ] 66*61c4878aSAndroid Build Coastguard Worker asmflags = cflags 67*61c4878aSAndroid Build Coastguard Worker ldflags = cflags 68*61c4878aSAndroid Build Coastguard Worker visibility = [ ":*" ] 69*61c4878aSAndroid Build Coastguard Worker} 70*61c4878aSAndroid Build Coastguard Worker 71*61c4878aSAndroid Build Coastguard Workerconfig("sdk_defines") { 72*61c4878aSAndroid Build Coastguard Worker defines = [ 73*61c4878aSAndroid Build Coastguard Worker "CPU_MIMXRT595SFFOC_cm33", 74*61c4878aSAndroid Build Coastguard Worker "DEBUG_CONSOLE_TRANSFER_NON_BLOCKING", 75*61c4878aSAndroid Build Coastguard Worker "SDK_DEBUGCONSOLE=1", 76*61c4878aSAndroid Build Coastguard Worker ] 77*61c4878aSAndroid Build Coastguard Worker visibility = [ ":*" ] 78*61c4878aSAndroid Build Coastguard Worker} 79*61c4878aSAndroid Build Coastguard Worker 80*61c4878aSAndroid Build Coastguard Workerif (current_toolchain != default_toolchain) { 81*61c4878aSAndroid Build Coastguard Worker pw_linker_script("flash_linker_script") { 82*61c4878aSAndroid Build Coastguard Worker defines = pw_target_mimxrt595_evk_freertos_LINK_CONFIG_DEFINES 83*61c4878aSAndroid Build Coastguard Worker linker_script = "mimxrt595_flash.ld" 84*61c4878aSAndroid Build Coastguard Worker } 85*61c4878aSAndroid Build Coastguard Worker} 86*61c4878aSAndroid Build Coastguard Worker 87*61c4878aSAndroid Build Coastguard Workerif (pw_third_party_mcuxpresso_SDK != "") { 88*61c4878aSAndroid Build Coastguard Worker # Startup and vector table for NXP MIMXRT595-EVK. 89*61c4878aSAndroid Build Coastguard Worker pw_source_set("boot") { 90*61c4878aSAndroid Build Coastguard Worker public_configs = [ ":pw_malloc_active" ] 91*61c4878aSAndroid Build Coastguard Worker deps = [ 92*61c4878aSAndroid Build Coastguard Worker "$dir_pw_boot", 93*61c4878aSAndroid Build Coastguard Worker "$dir_pw_boot_cortex_m:armv8m", 94*61c4878aSAndroid Build Coastguard Worker "$dir_pw_malloc", 95*61c4878aSAndroid Build Coastguard Worker "$dir_pw_preprocessor", 96*61c4878aSAndroid Build Coastguard Worker "$dir_pw_sys_io_mcuxpresso", 97*61c4878aSAndroid Build Coastguard Worker "$dir_pw_third_party/freertos", 98*61c4878aSAndroid Build Coastguard Worker "$dir_pw_third_party/freertos:support", 99*61c4878aSAndroid Build Coastguard Worker pw_third_party_mcuxpresso_SDK, 100*61c4878aSAndroid Build Coastguard Worker ] 101*61c4878aSAndroid Build Coastguard Worker if (pw_malloc_BACKEND != "") { 102*61c4878aSAndroid Build Coastguard Worker deps += [ "$dir_pw_malloc" ] 103*61c4878aSAndroid Build Coastguard Worker } 104*61c4878aSAndroid Build Coastguard Worker sources = [ 105*61c4878aSAndroid Build Coastguard Worker "boot.cc", 106*61c4878aSAndroid Build Coastguard Worker "vector_table.c", 107*61c4878aSAndroid Build Coastguard Worker ] 108*61c4878aSAndroid Build Coastguard Worker } 109*61c4878aSAndroid Build Coastguard Worker} 110*61c4878aSAndroid Build Coastguard Worker 111*61c4878aSAndroid Build Coastguard Workerif (pw_third_party_mcuxpresso_SDK == "//targets/mimxrt595_evk_freertos:sdk") { 112*61c4878aSAndroid Build Coastguard Worker pw_mcuxpresso_sdk("sdk") { 113*61c4878aSAndroid Build Coastguard Worker manifest = pw_target_mimxrt595_evk_freertos_MANIFEST 114*61c4878aSAndroid Build Coastguard Worker include = [ 115*61c4878aSAndroid Build Coastguard Worker "project_template.evkmimxrt595.MIMXRT595S", 116*61c4878aSAndroid Build Coastguard Worker "component.serial_manager_uart.MIMXRT595S", 117*61c4878aSAndroid Build Coastguard Worker "platform.drivers.flexcomm_i2c.MIMXRT595S", 118*61c4878aSAndroid Build Coastguard Worker "platform.drivers.flexcomm_spi.MIMXRT595S", 119*61c4878aSAndroid Build Coastguard Worker "platform.drivers.flexcomm_usart_dma.MIMXRT595S", 120*61c4878aSAndroid Build Coastguard Worker "platform.drivers.flexcomm_usart_freertos.MIMXRT595S", 121*61c4878aSAndroid Build Coastguard Worker "platform.drivers.flexio_spi.MIMXRT595S", 122*61c4878aSAndroid Build Coastguard Worker "platform.drivers.inputmux.MIMXRT595S", 123*61c4878aSAndroid Build Coastguard Worker "platform.drivers.lpc_dma.MIMXRT595S", 124*61c4878aSAndroid Build Coastguard Worker "platform.drivers.lpc_gpio.MIMXRT595S", 125*61c4878aSAndroid Build Coastguard Worker "platform.drivers.mu.MIMXRT595S", 126*61c4878aSAndroid Build Coastguard Worker "platform.drivers.pint.MIMXRT595S", 127*61c4878aSAndroid Build Coastguard Worker "platform.drivers.power.MIMXRT595S", 128*61c4878aSAndroid Build Coastguard Worker "utility.debug_console.MIMXRT595S", 129*61c4878aSAndroid Build Coastguard Worker ] 130*61c4878aSAndroid Build Coastguard Worker exclude = [ 131*61c4878aSAndroid Build Coastguard Worker "device.MIMXRT595S_startup.MIMXRT595S", 132*61c4878aSAndroid Build Coastguard Worker 133*61c4878aSAndroid Build Coastguard Worker # Don't need to generate build rules for freertos, we use pigweed's. 134*61c4878aSAndroid Build Coastguard Worker "middleware.freertos-kernel.MIMXRT595S", 135*61c4878aSAndroid Build Coastguard Worker ] 136*61c4878aSAndroid Build Coastguard Worker 137*61c4878aSAndroid Build Coastguard Worker public_configs = [ 138*61c4878aSAndroid Build Coastguard Worker ":disable_warnings", 139*61c4878aSAndroid Build Coastguard Worker ":freestanding", 140*61c4878aSAndroid Build Coastguard Worker ":sdk_defines", 141*61c4878aSAndroid Build Coastguard Worker ] 142*61c4878aSAndroid Build Coastguard Worker 143*61c4878aSAndroid Build Coastguard Worker public_deps = [ 144*61c4878aSAndroid Build Coastguard Worker ":mimxrt595_config", 145*61c4878aSAndroid Build Coastguard Worker "$dir_pw_third_party/freertos", 146*61c4878aSAndroid Build Coastguard Worker ] 147*61c4878aSAndroid Build Coastguard Worker } 148*61c4878aSAndroid Build Coastguard Worker 149*61c4878aSAndroid Build Coastguard Worker config("config_public_includes") { 150*61c4878aSAndroid Build Coastguard Worker include_dirs = [ "board" ] 151*61c4878aSAndroid Build Coastguard Worker visibility = [ ":*" ] 152*61c4878aSAndroid Build Coastguard Worker } 153*61c4878aSAndroid Build Coastguard Worker 154*61c4878aSAndroid Build Coastguard Worker config("config_public_defines") { 155*61c4878aSAndroid Build Coastguard Worker defines = [ 156*61c4878aSAndroid Build Coastguard Worker "CPU_MIMXRT595SFFOC_cm33", 157*61c4878aSAndroid Build Coastguard Worker "DEBUG_CONSOLE_DISABLE_RTOS_SYNCHRONIZATION", 158*61c4878aSAndroid Build Coastguard Worker "FSL_RTOS_FREE_RTOS", 159*61c4878aSAndroid Build Coastguard Worker "FSL_SDK_DRIVER_QUICK_ACCESS_ENABLE=1", 160*61c4878aSAndroid Build Coastguard Worker "SDK_DEBUGCONSOLE=1", 161*61c4878aSAndroid Build Coastguard Worker "SDK_OS_FREE_RTOS", 162*61c4878aSAndroid Build Coastguard Worker ] 163*61c4878aSAndroid Build Coastguard Worker visibility = [ ":*" ] 164*61c4878aSAndroid Build Coastguard Worker } 165*61c4878aSAndroid Build Coastguard Worker 166*61c4878aSAndroid Build Coastguard Worker # Project-specific board configuration. 167*61c4878aSAndroid Build Coastguard Worker pw_source_set("mimxrt595_config") { 168*61c4878aSAndroid Build Coastguard Worker public_configs = [ 169*61c4878aSAndroid Build Coastguard Worker ":config_public_defines", 170*61c4878aSAndroid Build Coastguard Worker ":config_public_includes", 171*61c4878aSAndroid Build Coastguard Worker ":disable_warnings", 172*61c4878aSAndroid Build Coastguard Worker ":sdk__defines", 173*61c4878aSAndroid Build Coastguard Worker ":sdk__includes", 174*61c4878aSAndroid Build Coastguard Worker ] 175*61c4878aSAndroid Build Coastguard Worker } 176*61c4878aSAndroid Build Coastguard Worker 177*61c4878aSAndroid Build Coastguard Worker # Project-specific FreeRTOS configurations. 178*61c4878aSAndroid Build Coastguard Worker config("freertos_config_public_includes") { 179*61c4878aSAndroid Build Coastguard Worker include_dirs = [ "." ] 180*61c4878aSAndroid Build Coastguard Worker visibility = [ ":*" ] 181*61c4878aSAndroid Build Coastguard Worker } 182*61c4878aSAndroid Build Coastguard Worker 183*61c4878aSAndroid Build Coastguard Worker pw_source_set("freertos_config") { 184*61c4878aSAndroid Build Coastguard Worker public_configs = [ 185*61c4878aSAndroid Build Coastguard Worker ":config_public_defines", 186*61c4878aSAndroid Build Coastguard Worker ":config_public_includes", 187*61c4878aSAndroid Build Coastguard Worker ":disable_warnings", 188*61c4878aSAndroid Build Coastguard Worker ":freertos_config_public_includes", 189*61c4878aSAndroid Build Coastguard Worker ] 190*61c4878aSAndroid Build Coastguard Worker public_deps = [ "$dir_pw_third_party/freertos:config_assert" ] 191*61c4878aSAndroid Build Coastguard Worker public = [ "FreeRTOSConfig.h" ] 192*61c4878aSAndroid Build Coastguard Worker } 193*61c4878aSAndroid Build Coastguard Worker 194*61c4878aSAndroid Build Coastguard Worker # Project-specific FreeRTOS port. 195*61c4878aSAndroid Build Coastguard Worker _freertos_port_dir = 196*61c4878aSAndroid Build Coastguard Worker "$dir_pw_third_party_freertos/portable/GCC/ARM_CM33_NTZ/non_secure" 197*61c4878aSAndroid Build Coastguard Worker config("freertos_port_public_includes") { 198*61c4878aSAndroid Build Coastguard Worker include_dirs = [ 199*61c4878aSAndroid Build Coastguard Worker "$_freertos_port_dir", 200*61c4878aSAndroid Build Coastguard Worker "$dir_pw_third_party_freertos/include", 201*61c4878aSAndroid Build Coastguard Worker ] 202*61c4878aSAndroid Build Coastguard Worker visibility = [ ":*" ] 203*61c4878aSAndroid Build Coastguard Worker } 204*61c4878aSAndroid Build Coastguard Worker 205*61c4878aSAndroid Build Coastguard Worker pw_source_set("freertos_port") { 206*61c4878aSAndroid Build Coastguard Worker public_configs = [ ":freertos_port_public_includes" ] 207*61c4878aSAndroid Build Coastguard Worker public = [ 208*61c4878aSAndroid Build Coastguard Worker "$_freertos_port_dir/portasm.h", 209*61c4878aSAndroid Build Coastguard Worker "$_freertos_port_dir/portmacro.h", 210*61c4878aSAndroid Build Coastguard Worker ] 211*61c4878aSAndroid Build Coastguard Worker configs = [ ":disable_warnings" ] 212*61c4878aSAndroid Build Coastguard Worker sources = [ 213*61c4878aSAndroid Build Coastguard Worker "$_freertos_port_dir/port.c", 214*61c4878aSAndroid Build Coastguard Worker "$_freertos_port_dir/portasm.c", 215*61c4878aSAndroid Build Coastguard Worker "$dir_pw_third_party_freertos/portable/MemMang/heap_4.c", 216*61c4878aSAndroid Build Coastguard Worker ] 217*61c4878aSAndroid Build Coastguard Worker deps = [ ":freertos_config" ] 218*61c4878aSAndroid Build Coastguard Worker } 219*61c4878aSAndroid Build Coastguard Worker} 220*61c4878aSAndroid Build Coastguard Worker 221*61c4878aSAndroid Build Coastguard Workerpw_doc_group("target_docs") { 222*61c4878aSAndroid Build Coastguard Worker sources = [ "target_docs.rst" ] 223*61c4878aSAndroid Build Coastguard Worker} 224