aboutsummaryrefslogtreecommitdiff
path: root/targets/mimxrt595_evk_freertos/BUILD.gn
diff options
context:
space:
mode:
Diffstat (limited to 'targets/mimxrt595_evk_freertos/BUILD.gn')
-rw-r--r--targets/mimxrt595_evk_freertos/BUILD.gn219
1 files changed, 219 insertions, 0 deletions
diff --git a/targets/mimxrt595_evk_freertos/BUILD.gn b/targets/mimxrt595_evk_freertos/BUILD.gn
new file mode 100644
index 000000000..c692fad79
--- /dev/null
+++ b/targets/mimxrt595_evk_freertos/BUILD.gn
@@ -0,0 +1,219 @@
+# Copyright 2021 The Pigweed Authors
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may not
+# use this file except in compliance with the License. You may obtain a copy of
+# the License at
+#
+# https://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations under
+# the License.
+
+import("//build_overrides/pigweed.gni")
+
+import("$dir_pw_build/linker_script.gni")
+import("$dir_pw_build/target_types.gni")
+import("$dir_pw_docgen/docs.gni")
+import("$dir_pw_malloc/backend.gni")
+import("$dir_pw_third_party/freertos/freertos.gni")
+import("$dir_pw_third_party/mcuxpresso/mcuxpresso.gni")
+import("$dir_pw_toolchain/generate_toolchain.gni")
+import("target_toolchains.gni")
+
+generate_toolchains("target_toolchains") {
+ toolchains = pw_target_toolchain_mimxrt595_evk_freertos_list
+}
+
+declare_args() {
+ # When compiling with an MCUXpresso SDK, this variable is set to the path of
+ # the manifest file within the SDK installation. When set, a pw_source_set
+ # for a sample project SDK is created at
+ # "//targets/mimxrt595_evk_freertos:sdk".
+ pw_target_mimxrt595_evk_freertos_MANIFEST = ""
+
+ # This list should contain the necessary defines for setting linker script
+ # memory regions. While we don't directly use the pw_boot_cortex_m linker
+ # script, these are deliberately matching to make being able to later easier.
+ pw_target_mimxrt595_evk_freertos_LINK_CONFIG_DEFINES = []
+}
+
+config("pw_malloc_active") {
+ if (pw_malloc_BACKEND != "") {
+ defines = [ "PW_MALLOC_ACTIVE=1" ]
+ }
+}
+
+config("disable_warnings") {
+ cflags = [
+ "-Wno-cast-qual",
+ "-Wno-redundant-decls",
+ "-Wno-undef",
+ "-Wno-unused-parameter",
+ "-Wno-unused-variable",
+ "-Wno-error=strict-prototypes",
+ ]
+ visibility = [ ":*" ]
+}
+
+config("freestanding") {
+ cflags = [
+ "-ffreestanding",
+ "-fno-builtin",
+ ]
+ asmflags = cflags
+ ldflags = cflags
+ visibility = [ ":*" ]
+}
+
+config("sdk_defines") {
+ defines = [
+ "CPU_MIMXRT595SFFOC_cm33",
+ "DEBUG_CONSOLE_TRANSFER_NON_BLOCKING",
+ "SDK_DEBUGCONSOLE=1",
+ ]
+ visibility = [ ":*" ]
+}
+
+if (current_toolchain != default_toolchain) {
+ pw_linker_script("flash_linker_script") {
+ defines = pw_target_mimxrt595_evk_freertos_LINK_CONFIG_DEFINES
+ linker_script = "mimxrt595_flash.ld"
+ }
+}
+
+if (pw_third_party_mcuxpresso_SDK != "") {
+ # Startup and vector table for NXP MIMXRT595-EVK.
+ pw_source_set("boot") {
+ public_configs = [ ":pw_malloc_active" ]
+ deps = [
+ "$dir_pw_boot",
+ "$dir_pw_boot_cortex_m:armv8m",
+ "$dir_pw_malloc",
+ "$dir_pw_preprocessor",
+ "$dir_pw_sys_io_mcuxpresso",
+ pw_third_party_mcuxpresso_SDK,
+ ]
+ if (pw_malloc_BACKEND != "") {
+ deps += [ "$dir_pw_malloc" ]
+ }
+ sources = [
+ "boot.cc",
+ "vector_table.c",
+ ]
+ }
+}
+
+if (pw_third_party_mcuxpresso_SDK == "//targets/mimxrt595_evk_freertos:sdk") {
+ pw_mcuxpresso_sdk("sdk") {
+ manifest = pw_target_mimxrt595_evk_freertos_MANIFEST
+ include = [
+ "project_template.evkmimxrt595.MIMXRT595S",
+ "component.serial_manager_uart.MIMXRT595S",
+ "platform.drivers.flexcomm_i2c.MIMXRT595S",
+ "platform.drivers.flexcomm_spi.MIMXRT595S",
+ "platform.drivers.flexcomm_usart_freertos.MIMXRT595S",
+ "platform.drivers.flexio_spi.MIMXRT595S",
+ "platform.drivers.pint.MIMXRT595S",
+ "platform.drivers.power.MIMXRT595S",
+ "platform.drivers.lpc_gpio.MIMXRT595S",
+ "platform.drivers.mu.MIMXRT595S",
+ "utility.debug_console.MIMXRT595S",
+ ]
+ exclude = [
+ "device.MIMXRT595S_startup.MIMXRT595S",
+
+ # Don't need to generate build rules for freertos, we use pigweed's.
+ "middleware.freertos-kernel.MIMXRT595S",
+ ]
+
+ public_configs = [
+ ":disable_warnings",
+ ":freestanding",
+ ":sdk_defines",
+ ]
+
+ public_deps = [
+ ":mimxrt595_config",
+ "$dir_pw_third_party/freertos",
+ ]
+ }
+
+ config("config_public_includes") {
+ include_dirs = [ "board" ]
+ visibility = [ ":*" ]
+ }
+
+ config("config_public_defines") {
+ defines = [
+ "CPU_MIMXRT595SFFOC_cm33",
+ "DEBUG_CONSOLE_DISABLE_RTOS_SYNCHRONIZATION",
+ "FSL_RTOS_FREE_RTOS",
+ "FSL_SDK_DRIVER_QUICK_ACCESS_ENABLE=1",
+ "SDK_DEBUGCONSOLE=1",
+ "SDK_OS_FREE_RTOS",
+ ]
+ visibility = [ ":*" ]
+ }
+
+ # Project-specific board configuration.
+ pw_source_set("mimxrt595_config") {
+ public_configs = [
+ ":config_public_defines",
+ ":config_public_includes",
+ ":disable_warnings",
+ ":sdk__defines",
+ ":sdk__includes",
+ ]
+ }
+
+ # Project-specific FreeRTOS configurations.
+ config("freertos_config_public_includes") {
+ include_dirs = [ "." ]
+ visibility = [ ":*" ]
+ }
+
+ pw_source_set("freertos_config") {
+ public_configs = [
+ ":config_public_defines",
+ ":config_public_includes",
+ ":disable_warnings",
+ ":freertos_config_public_includes",
+ ]
+ public_deps = [ "$dir_pw_third_party/freertos:config_assert" ]
+ public = [ "FreeRTOSConfig.h" ]
+ }
+
+ # Project-specific FreeRTOS port.
+ _freertos_port_dir =
+ "$dir_pw_third_party_freertos/portable/GCC/ARM_CM33_NTZ/non_secure"
+ config("freertos_port_public_includes") {
+ include_dirs = [
+ "$_freertos_port_dir",
+ "$dir_pw_third_party_freertos/include",
+ ]
+ visibility = [ ":*" ]
+ }
+
+ pw_source_set("freertos_port") {
+ public_configs = [ ":freertos_port_public_includes" ]
+ public = [
+ "$_freertos_port_dir/portasm.h",
+ "$_freertos_port_dir/portmacro.h",
+ ]
+ configs = [ ":disable_warnings" ]
+ sources = [
+ "$_freertos_port_dir/port.c",
+ "$_freertos_port_dir/portasm.c",
+ "$dir_pw_third_party_freertos/portable/MemMang/heap_4.c",
+ "tasks.c",
+ ]
+ deps = [ ":freertos_config" ]
+ }
+}
+
+pw_doc_group("target_docs") {
+ sources = [ "target_docs.rst" ]
+}