1*61c4878aSAndroid Build Coastguard Worker# Copyright 2023 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 Workerload("@rules_python//sphinxdocs:sphinx_docs_library.bzl", "sphinx_docs_library") 16*61c4878aSAndroid Build Coastguard Workerload("//pw_build:compatibility.bzl", "incompatible_with_mcu") 17*61c4878aSAndroid Build Coastguard Workerload("//pw_build:pw_linker_script.bzl", "pw_linker_script") 18*61c4878aSAndroid Build Coastguard Worker 19*61c4878aSAndroid Build Coastguard Workerpackage(default_visibility = ["//visibility:public"]) 20*61c4878aSAndroid Build Coastguard Worker 21*61c4878aSAndroid Build Coastguard Workerlicenses(["notice"]) 22*61c4878aSAndroid Build Coastguard Worker 23*61c4878aSAndroid Build Coastguard Workerpw_linker_script( 24*61c4878aSAndroid Build Coastguard Worker name = "flash_linker_script", 25*61c4878aSAndroid Build Coastguard Worker defines = [ 26*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_FLASH_BEGIN=0x08001180", 27*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_FLASH_SIZE=0x001FEE80", 28*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_HEAP_SIZE=200K", 29*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_MIN_STACK_SIZE=1K", 30*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_RAM_BEGIN=0x20080000", 31*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_RAM_SIZE=0x00280000", 32*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_VECTOR_TABLE_BEGIN=0x08001000", 33*61c4878aSAndroid Build Coastguard Worker "PW_BOOT_VECTOR_TABLE_SIZE=0x00000180", 34*61c4878aSAndroid Build Coastguard Worker ], 35*61c4878aSAndroid Build Coastguard Worker linker_script = "mimxrt595_flash.ld", 36*61c4878aSAndroid Build Coastguard Worker) 37*61c4878aSAndroid Build Coastguard Worker 38*61c4878aSAndroid Build Coastguard Workercc_library( 39*61c4878aSAndroid Build Coastguard Worker name = "boot", 40*61c4878aSAndroid Build Coastguard Worker srcs = [ 41*61c4878aSAndroid Build Coastguard Worker "boot.cc", 42*61c4878aSAndroid Build Coastguard Worker "vector_table.c", 43*61c4878aSAndroid Build Coastguard Worker ], 44*61c4878aSAndroid Build Coastguard Worker defines = [ 45*61c4878aSAndroid Build Coastguard Worker "PW_MALLOC_ACTIVE=1", 46*61c4878aSAndroid Build Coastguard Worker ], 47*61c4878aSAndroid Build Coastguard Worker target_compatible_with = [ 48*61c4878aSAndroid Build Coastguard Worker "//pw_build/constraints/board:mimxrt595_evk", 49*61c4878aSAndroid Build Coastguard Worker "@platforms//cpu:armv8-m", 50*61c4878aSAndroid Build Coastguard Worker ], 51*61c4878aSAndroid Build Coastguard Worker deps = [ 52*61c4878aSAndroid Build Coastguard Worker ":flash_linker_script", 53*61c4878aSAndroid Build Coastguard Worker "//pw_boot", 54*61c4878aSAndroid Build Coastguard Worker "//pw_boot_cortex_m", 55*61c4878aSAndroid Build Coastguard Worker "//pw_preprocessor", 56*61c4878aSAndroid Build Coastguard Worker "//pw_sys_io_mcuxpresso", 57*61c4878aSAndroid Build Coastguard Worker "//targets:mcuxpresso_sdk", 58*61c4878aSAndroid Build Coastguard Worker "//third_party/freertos:support", 59*61c4878aSAndroid Build Coastguard Worker ], 60*61c4878aSAndroid Build Coastguard Worker alwayslink = 1, 61*61c4878aSAndroid Build Coastguard Worker) 62*61c4878aSAndroid Build Coastguard Worker 63*61c4878aSAndroid Build Coastguard Workercc_library( 64*61c4878aSAndroid Build Coastguard Worker name = "freertos_config", 65*61c4878aSAndroid Build Coastguard Worker hdrs = [ 66*61c4878aSAndroid Build Coastguard Worker "FreeRTOSConfig.h", 67*61c4878aSAndroid Build Coastguard Worker ], 68*61c4878aSAndroid Build Coastguard Worker includes = ["./"], 69*61c4878aSAndroid Build Coastguard Worker deps = ["//third_party/freertos:config_assert"], 70*61c4878aSAndroid Build Coastguard Worker) 71*61c4878aSAndroid Build Coastguard Worker 72*61c4878aSAndroid Build Coastguard Workersphinx_docs_library( 73*61c4878aSAndroid Build Coastguard Worker name = "docs", 74*61c4878aSAndroid Build Coastguard Worker srcs = [ 75*61c4878aSAndroid Build Coastguard Worker "target_docs.rst", 76*61c4878aSAndroid Build Coastguard Worker ], 77*61c4878aSAndroid Build Coastguard Worker target_compatible_with = incompatible_with_mcu(), 78*61c4878aSAndroid Build Coastguard Worker) 79