xref: /aosp_15_r20/external/pigweed/targets/emcraft_sf2_som/BUILD.gn (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker# Copyright 2022 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_system/system_target.gni")
22*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_third_party/smartfusion_mss/mss.gni")
23*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_toolchain/generate_toolchain.gni")
24*61c4878aSAndroid Build Coastguard Worker
25*61c4878aSAndroid Build Coastguard Workerconfig("pw_malloc_active") {
26*61c4878aSAndroid Build Coastguard Worker  if (pw_malloc_BACKEND != "") {
27*61c4878aSAndroid Build Coastguard Worker    defines = [ "PW_MALLOC_ACTIVE=1" ]
28*61c4878aSAndroid Build Coastguard Worker  }
29*61c4878aSAndroid Build Coastguard Worker}
30*61c4878aSAndroid Build Coastguard Worker
31*61c4878aSAndroid Build Coastguard Workerconfig("emcraft_ddr_init") {
32*61c4878aSAndroid Build Coastguard Worker  # Emcraft's DDR config must be manually set by a custom init function. This
33*61c4878aSAndroid Build Coastguard Worker  # conflicts with the built-in MSS init function. I have not looked into this
34*61c4878aSAndroid Build Coastguard Worker  # myself to see if it's absoutely needed or not.
35*61c4878aSAndroid Build Coastguard Worker  defines = [ "MSS_SYS_MDDR_CONFIG_BY_CORTEX=0" ]
36*61c4878aSAndroid Build Coastguard Worker}
37*61c4878aSAndroid Build Coastguard Worker
38*61c4878aSAndroid Build Coastguard Workerif (current_toolchain != default_toolchain) {
39*61c4878aSAndroid Build Coastguard Worker  pw_linker_script("mddr_debug_linker_script") {
40*61c4878aSAndroid Build Coastguard Worker    defines = [
41*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_CODE_BEGIN=0x00000200",  # After vector table.
42*61c4878aSAndroid Build Coastguard Worker
43*61c4878aSAndroid Build Coastguard Worker      # TODO(skeys) Bootloader is capable of loading 16M of uncompressed code
44*61c4878aSAndroid Build Coastguard Worker      # from SPI flash to external RAM. For now use the allocated eNVM flash
45*61c4878aSAndroid Build Coastguard Worker      # (256K - Bootloader - InSystemProgrammer = 192K)
46*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_CODE_SIZE=0x30000",
47*61c4878aSAndroid Build Coastguard Worker
48*61c4878aSAndroid Build Coastguard Worker      # TODO: b/235348465 - Currently "pw_tokenizer/detokenize_test" requires at
49*61c4878aSAndroid Build Coastguard Worker      # least 6K bytes in heap when using pw_malloc:bucket_block_allocator.
50*61c4878aSAndroid Build Coastguard Worker      # The heap size required for tests should be investigated.
51*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_HEAP_SIZE=4M",
52*61c4878aSAndroid Build Coastguard Worker
53*61c4878aSAndroid Build Coastguard Worker      # With external RAM remapped, we use the entire internal ram for the
54*61c4878aSAndroid Build Coastguard Worker      # stack (64K).
55*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_MIN_STACK_SIZE=64K",
56*61c4878aSAndroid Build Coastguard Worker
57*61c4878aSAndroid Build Coastguard Worker      # Using external DDR RAM, we just need to make sure we go past our ROM
58*61c4878aSAndroid Build Coastguard Worker      # sections.
59*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_RAM_BEGIN=0xA1000000",
60*61c4878aSAndroid Build Coastguard Worker
61*61c4878aSAndroid Build Coastguard Worker      # We assume that the bootloader loaded all 16M of text.
62*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_RAM_SIZE=48M",
63*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_VECTOR_TABLE_BEGIN=0x00000000",
64*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_VECTOR_TABLE_SIZE=512",
65*61c4878aSAndroid Build Coastguard Worker    ]
66*61c4878aSAndroid Build Coastguard Worker    linker_script = "emcraft_sf2_som_mddr_debug.ld"
67*61c4878aSAndroid Build Coastguard Worker  }
68*61c4878aSAndroid Build Coastguard Worker  pw_linker_script("mddr_production_linker_script") {
69*61c4878aSAndroid Build Coastguard Worker    defines = [
70*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_FLASH_BEGIN=0x00000200",  # After vector table.
71*61c4878aSAndroid Build Coastguard Worker
72*61c4878aSAndroid Build Coastguard Worker      # TODO(skeys) Bootloader is capable of loading 16M of uncompressed code
73*61c4878aSAndroid Build Coastguard Worker      # from SPI flash to external RAM. For now use the allocated eNVM flash
74*61c4878aSAndroid Build Coastguard Worker      # (256K - Bootloader - InSystemProgrammer = 192K)
75*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_FLASH_SIZE=0x30000",
76*61c4878aSAndroid Build Coastguard Worker
77*61c4878aSAndroid Build Coastguard Worker      # TODO: b/235348465 - Currently "pw_tokenizer/detokenize_test" requires at
78*61c4878aSAndroid Build Coastguard Worker      # least 6K bytes in heap when using pw_malloc:bucket_block_allocator.
79*61c4878aSAndroid Build Coastguard Worker      # The heap size required for tests should be investigated.
80*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_HEAP_SIZE=4M",
81*61c4878aSAndroid Build Coastguard Worker
82*61c4878aSAndroid Build Coastguard Worker      # With external RAM remapped, we use the entire internal ram for the
83*61c4878aSAndroid Build Coastguard Worker      # stack (64K).
84*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_MIN_STACK_SIZE=1024K",
85*61c4878aSAndroid Build Coastguard Worker
86*61c4878aSAndroid Build Coastguard Worker      # Using external DDR RAM, we just need to make sure we go past our ROM
87*61c4878aSAndroid Build Coastguard Worker      # sections.
88*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_RAM_BEGIN=0xA1000000",
89*61c4878aSAndroid Build Coastguard Worker
90*61c4878aSAndroid Build Coastguard Worker      # We assume that the bootloader loaded all 16M of text.
91*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_RAM_SIZE=48M",
92*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_VECTOR_TABLE_BEGIN=0x00000000",
93*61c4878aSAndroid Build Coastguard Worker      "PW_BOOT_VECTOR_TABLE_SIZE=512",
94*61c4878aSAndroid Build Coastguard Worker    ]
95*61c4878aSAndroid Build Coastguard Worker    linker_script = "$dir_pw_boot_cortex_m/basic_cortex_m.ld"
96*61c4878aSAndroid Build Coastguard Worker  }
97*61c4878aSAndroid Build Coastguard Worker
98*61c4878aSAndroid Build Coastguard Worker  pw_source_set("pre_init") {
99*61c4878aSAndroid Build Coastguard Worker    configs = [ ":pw_malloc_active" ]
100*61c4878aSAndroid Build Coastguard Worker    deps = [
101*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_boot",
102*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_boot_cortex_m",
103*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_malloc",
104*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_preprocessor",
105*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_string",
106*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sys_io_emcraft_sf2",
107*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_system",
108*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_third_party/freertos",
109*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_third_party/freertos:support",
110*61c4878aSAndroid Build Coastguard Worker    ]
111*61c4878aSAndroid Build Coastguard Worker    sources = [
112*61c4878aSAndroid Build Coastguard Worker      "boot.cc",
113*61c4878aSAndroid Build Coastguard Worker      "vector_table.c",
114*61c4878aSAndroid Build Coastguard Worker    ]
115*61c4878aSAndroid Build Coastguard Worker  }
116*61c4878aSAndroid Build Coastguard Worker
117*61c4878aSAndroid Build Coastguard Worker  config("config_includes") {
118*61c4878aSAndroid Build Coastguard Worker    include_dirs = [ "config" ]
119*61c4878aSAndroid Build Coastguard Worker    configs = [ ":emcraft_ddr_init" ]
120*61c4878aSAndroid Build Coastguard Worker  }
121*61c4878aSAndroid Build Coastguard Worker
122*61c4878aSAndroid Build Coastguard Worker  pw_source_set("sf2_mss_hal_config") {
123*61c4878aSAndroid Build Coastguard Worker    public_configs = [ ":config_includes" ]
124*61c4878aSAndroid Build Coastguard Worker    public =
125*61c4878aSAndroid Build Coastguard Worker        [ "config/sf2_mss_hal_conf.h" ]  # SKEYS likely want to put the MDDR
126*61c4878aSAndroid Build Coastguard Worker                                         # config by cortex etc stuff here
127*61c4878aSAndroid Build Coastguard Worker  }
128*61c4878aSAndroid Build Coastguard Worker
129*61c4878aSAndroid Build Coastguard Worker  pw_source_set("sf2_freertos_config") {
130*61c4878aSAndroid Build Coastguard Worker    public_configs = [ ":config_includes" ]
131*61c4878aSAndroid Build Coastguard Worker    public_deps = [ "$dir_pw_third_party/freertos:config_assert" ]
132*61c4878aSAndroid Build Coastguard Worker    public = [ "config/FreeRTOSConfig.h" ]
133*61c4878aSAndroid Build Coastguard Worker  }
134*61c4878aSAndroid Build Coastguard Worker}
135*61c4878aSAndroid Build Coastguard Worker
136*61c4878aSAndroid Build Coastguard Worker# Configured for use with a first stage boot loader to configure DDR and
137*61c4878aSAndroid Build Coastguard Worker# perform memory remapping.
138*61c4878aSAndroid Build Coastguard Workerpw_system_target("emcraft_sf2_som") {
139*61c4878aSAndroid Build Coastguard Worker  cpu = PW_SYSTEM_CPU.CORTEX_M3
140*61c4878aSAndroid Build Coastguard Worker  scheduler = PW_SYSTEM_SCHEDULER.FREERTOS
141*61c4878aSAndroid Build Coastguard Worker  link_deps = [ "$dir_pigweed/targets/emcraft_sf2_som:pre_init" ]
142*61c4878aSAndroid Build Coastguard Worker
143*61c4878aSAndroid Build Coastguard Worker  build_args = {
144*61c4878aSAndroid Build Coastguard Worker    pw_log_BACKEND = dir_pw_log_tokenized
145*61c4878aSAndroid Build Coastguard Worker    pw_log_tokenized_HANDLER_BACKEND = "$dir_pw_system:log_backend.impl"
146*61c4878aSAndroid Build Coastguard Worker    pw_third_party_freertos_CONFIG =
147*61c4878aSAndroid Build Coastguard Worker        "$dir_pigweed/targets/emcraft_sf2_som:sf2_freertos_config"
148*61c4878aSAndroid Build Coastguard Worker    pw_third_party_freertos_PORT = "$dir_pw_third_party/freertos:arm_cm3"
149*61c4878aSAndroid Build Coastguard Worker    pw_sys_io_BACKEND = dir_pw_sys_io_emcraft_sf2
150*61c4878aSAndroid Build Coastguard Worker
151*61c4878aSAndroid Build Coastguard Worker    pw_boot_cortex_m_LINKER_SCRIPT =
152*61c4878aSAndroid Build Coastguard Worker        "//targets/emcraft_sf2_som:mddr_production_linker_script"
153*61c4878aSAndroid Build Coastguard Worker  }
154*61c4878aSAndroid Build Coastguard Worker}
155*61c4878aSAndroid Build Coastguard Worker
156*61c4878aSAndroid Build Coastguard Worker# Debug target configured to work with MSS linker script and startup code.
157*61c4878aSAndroid Build Coastguard Worker# TODO(skeys) Add linker script and config for debug builds using SoftConsole.
158*61c4878aSAndroid Build Coastguard Workerpw_system_target("emcraft_sf2_som_debug") {
159*61c4878aSAndroid Build Coastguard Worker  cpu = PW_SYSTEM_CPU.CORTEX_M3
160*61c4878aSAndroid Build Coastguard Worker  scheduler = PW_SYSTEM_SCHEDULER.FREERTOS
161*61c4878aSAndroid Build Coastguard Worker  link_deps = [ "$dir_pigweed/targets/emcraft_sf2_som:pre_init" ]
162*61c4878aSAndroid Build Coastguard Worker
163*61c4878aSAndroid Build Coastguard Worker  build_args = {
164*61c4878aSAndroid Build Coastguard Worker    pw_log_BACKEND = dir_pw_log_tokenized
165*61c4878aSAndroid Build Coastguard Worker    pw_log_tokenized_HANDLER_BACKEND = "$dir_pw_system:log_backend.impl"
166*61c4878aSAndroid Build Coastguard Worker    pw_third_party_freertos_CONFIG =
167*61c4878aSAndroid Build Coastguard Worker        "$dir_pigweed/targets/emcraft_sf2_som:sf2_freertos_config"
168*61c4878aSAndroid Build Coastguard Worker    pw_third_party_freertos_PORT = "$dir_pw_third_party/freertos:arm_cm3"
169*61c4878aSAndroid Build Coastguard Worker    pw_sys_io_BACKEND = dir_pw_sys_io_emcraft_sf2
170*61c4878aSAndroid Build Coastguard Worker
171*61c4878aSAndroid Build Coastguard Worker    # Override the default pw_boot_cortex_m linker script and set the memory
172*61c4878aSAndroid Build Coastguard Worker    # regions for the target.
173*61c4878aSAndroid Build Coastguard Worker    pw_boot_cortex_m_LINKER_SCRIPT =
174*61c4878aSAndroid Build Coastguard Worker        "//targets/emcraft_sf2_som:mddr_debug_linker_script"
175*61c4878aSAndroid Build Coastguard Worker    pw_third_party_smartfusion_mss_CONFIG = "debug"
176*61c4878aSAndroid Build Coastguard Worker  }
177*61c4878aSAndroid Build Coastguard Worker}
178*61c4878aSAndroid Build Coastguard Worker
179*61c4878aSAndroid Build Coastguard Workerpw_doc_group("docs") {
180*61c4878aSAndroid Build Coastguard Worker  sources = [ "target_docs.rst" ]
181*61c4878aSAndroid Build Coastguard Worker}
182