xref: /aosp_15_r20/external/pigweed/targets/mimxrt595_evk_freertos/BUILD.bazel (revision 61c4878ac05f98d0ceed94b57d316916de578985)
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