xref: /aosp_15_r20/external/pigweed/targets/lm3s6965evb_qemu/target_toolchains.gni (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker# Copyright 2020 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_sys_io/backend.gni")
18*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_toolchain/arm_clang/toolchains.gni")
19*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_toolchain/arm_gcc/toolchains.gni")
20*61c4878aSAndroid Build Coastguard Worker
21*61c4878aSAndroid Build Coastguard Worker_test_runner_script = "py/lm3s6965evb_qemu_utils/unit_test_runner.py"
22*61c4878aSAndroid Build Coastguard Worker
23*61c4878aSAndroid Build Coastguard Worker_target_config = {
24*61c4878aSAndroid Build Coastguard Worker  # Use the logging main.
25*61c4878aSAndroid Build Coastguard Worker  pw_unit_test_MAIN = "$dir_pw_unit_test:logging_main"
26*61c4878aSAndroid Build Coastguard Worker
27*61c4878aSAndroid Build Coastguard Worker  # Configuration options for Pigweed executable targets.
28*61c4878aSAndroid Build Coastguard Worker  pw_build_EXECUTABLE_TARGET_TYPE = "lm3s6965evb_executable"
29*61c4878aSAndroid Build Coastguard Worker
30*61c4878aSAndroid Build Coastguard Worker  pw_build_EXECUTABLE_TARGET_TYPE_FILE =
31*61c4878aSAndroid Build Coastguard Worker      get_path_info("lm3s6965evb_executable.gni", "abspath")
32*61c4878aSAndroid Build Coastguard Worker
33*61c4878aSAndroid Build Coastguard Worker  # Path to the bloaty config file for the output binaries.
34*61c4878aSAndroid Build Coastguard Worker  pw_bloat_BLOATY_CONFIG = "$dir_pw_boot_cortex_m/bloaty_config.bloaty"
35*61c4878aSAndroid Build Coastguard Worker
36*61c4878aSAndroid Build Coastguard Worker  pw_unit_test_AUTOMATIC_RUNNER = get_path_info(_test_runner_script, "abspath")
37*61c4878aSAndroid Build Coastguard Worker
38*61c4878aSAndroid Build Coastguard Worker  # Facade backends
39*61c4878aSAndroid Build Coastguard Worker  pw_assert_BACKEND = dir_pw_assert_basic
40*61c4878aSAndroid Build Coastguard Worker  pw_boot_BACKEND = "$dir_pw_boot_cortex_m"
41*61c4878aSAndroid Build Coastguard Worker  pw_log_BACKEND = dir_pw_log_basic
42*61c4878aSAndroid Build Coastguard Worker  pw_sys_io_BACKEND = dir_pw_sys_io_baremetal_lm3s6965evb
43*61c4878aSAndroid Build Coastguard Worker  pw_rpc_system_server_BACKEND = "$dir_pw_hdlc:hdlc_sys_io_system_server"
44*61c4878aSAndroid Build Coastguard Worker  pw_sync_INTERRUPT_SPIN_LOCK_BACKEND =
45*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync_baremetal:interrupt_spin_lock"
46*61c4878aSAndroid Build Coastguard Worker  pw_sync_MUTEX_BACKEND = "$dir_pw_sync_baremetal:mutex"
47*61c4878aSAndroid Build Coastguard Worker  pw_rpc_CONFIG = "$dir_pw_rpc:disable_global_mutex"
48*61c4878aSAndroid Build Coastguard Worker
49*61c4878aSAndroid Build Coastguard Worker  # pw_cpu_exception_armv7m tests do not work as expected in QEMU. It does not
50*61c4878aSAndroid Build Coastguard Worker  # appear the divide-by-zero traps as expected when enabled, which prevents the
51*61c4878aSAndroid Build Coastguard Worker  # module from triggering a recoverable exception. Since pw_cpu_exception is
52*61c4878aSAndroid Build Coastguard Worker  # not fully set up on this target, disable it for now.
53*61c4878aSAndroid Build Coastguard Worker  # pw_cpu_exception_ENTRY_BACKEND =
54*61c4878aSAndroid Build Coastguard Worker  #     "$dir_pw_cpu_exception_cortex_m:cpu_exception_armv7m
55*61c4878aSAndroid Build Coastguard Worker
56*61c4878aSAndroid Build Coastguard Worker  pw_boot_cortex_m_LINK_CONFIG_DEFINES = [
57*61c4878aSAndroid Build Coastguard Worker    "PW_BOOT_FLASH_BEGIN=0x00000200",
58*61c4878aSAndroid Build Coastguard Worker    "PW_BOOT_FLASH_SIZE=255K",
59*61c4878aSAndroid Build Coastguard Worker    "PW_BOOT_HEAP_SIZE=0",
60*61c4878aSAndroid Build Coastguard Worker    "PW_BOOT_MIN_STACK_SIZE=1K",
61*61c4878aSAndroid Build Coastguard Worker    "PW_BOOT_RAM_BEGIN=0x20000000",
62*61c4878aSAndroid Build Coastguard Worker    "PW_BOOT_RAM_SIZE=64K",
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
67*61c4878aSAndroid Build Coastguard Worker  pw_build_LINK_DEPS = [
68*61c4878aSAndroid Build Coastguard Worker    "$dir_pw_assert:impl",
69*61c4878aSAndroid Build Coastguard Worker    "$dir_pw_log:impl",
70*61c4878aSAndroid Build Coastguard Worker  ]
71*61c4878aSAndroid Build Coastguard Worker
72*61c4878aSAndroid Build Coastguard Worker  pw_rust_USE_STD = false
73*61c4878aSAndroid Build Coastguard Worker
74*61c4878aSAndroid Build Coastguard Worker  current_cpu = "arm"
75*61c4878aSAndroid Build Coastguard Worker  current_os = ""
76*61c4878aSAndroid Build Coastguard Worker}
77*61c4878aSAndroid Build Coastguard Worker
78*61c4878aSAndroid Build Coastguard Worker_gcc_target_default_configs = [
79*61c4878aSAndroid Build Coastguard Worker  "$dir_pw_build:extra_strict_warnings",
80*61c4878aSAndroid Build Coastguard Worker  "$dir_pw_toolchain/arm_gcc:enable_float_printf",
81*61c4878aSAndroid Build Coastguard Worker]
82*61c4878aSAndroid Build Coastguard Worker
83*61c4878aSAndroid Build Coastguard Worker_clang_target_default_configs = [
84*61c4878aSAndroid Build Coastguard Worker  "$dir_pw_build:clang_thread_safety_warnings",
85*61c4878aSAndroid Build Coastguard Worker  "$dir_pw_build:extra_strict_warnings",
86*61c4878aSAndroid Build Coastguard Worker  "$dir_pw_toolchain/arm_clang:enable_float_printf",
87*61c4878aSAndroid Build Coastguard Worker
88*61c4878aSAndroid Build Coastguard Worker  # TODO: b/232587313 - Disable lock annotations for this target because the
89*61c4878aSAndroid Build Coastguard Worker  # clang toolchain currently relies on the standard library headers provided by
90*61c4878aSAndroid Build Coastguard Worker  # arm-none-eabi-gcc, and thus do not have thread safety lock annotations on
91*61c4878aSAndroid Build Coastguard Worker  # things like std::lock_guard. Thread safety checks will not work until
92*61c4878aSAndroid Build Coastguard Worker  # the clang-based ARM toolchain uses a C++ standard library that has these
93*61c4878aSAndroid Build Coastguard Worker  # annotations set up.
94*61c4878aSAndroid Build Coastguard Worker  "$dir_pigweed/targets/lm3s6965evb_qemu:disable_lock_annotations",
95*61c4878aSAndroid Build Coastguard Worker]
96*61c4878aSAndroid Build Coastguard Worker
97*61c4878aSAndroid Build Coastguard Workerpw_target_toolchain_lm3s6965evb_qemu = {
98*61c4878aSAndroid Build Coastguard Worker  _excluded_members = [
99*61c4878aSAndroid Build Coastguard Worker    "defaults",
100*61c4878aSAndroid Build Coastguard Worker    "name",
101*61c4878aSAndroid Build Coastguard Worker  ]
102*61c4878aSAndroid Build Coastguard Worker
103*61c4878aSAndroid Build Coastguard Worker  debug = {
104*61c4878aSAndroid Build Coastguard Worker    name = "lm3s6965evb_qemu_gcc_debug"
105*61c4878aSAndroid Build Coastguard Worker    _toolchain_base = pw_toolchain_arm_gcc.cortex_m3_debug
106*61c4878aSAndroid Build Coastguard Worker    forward_variables_from(_toolchain_base, "*", _excluded_members)
107*61c4878aSAndroid Build Coastguard Worker    defaults = {
108*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_toolchain_base.defaults, "*")
109*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_target_config, "*")
110*61c4878aSAndroid Build Coastguard Worker      default_configs += _gcc_target_default_configs
111*61c4878aSAndroid Build Coastguard Worker    }
112*61c4878aSAndroid Build Coastguard Worker  }
113*61c4878aSAndroid Build Coastguard Worker
114*61c4878aSAndroid Build Coastguard Worker  speed_optimized = {
115*61c4878aSAndroid Build Coastguard Worker    name = "lm3s6965evb_qemu_gcc_speed_optimized"
116*61c4878aSAndroid Build Coastguard Worker    _toolchain_base = pw_toolchain_arm_gcc.cortex_m3_speed_optimized
117*61c4878aSAndroid Build Coastguard Worker    forward_variables_from(_toolchain_base, "*", _excluded_members)
118*61c4878aSAndroid Build Coastguard Worker    defaults = {
119*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_toolchain_base.defaults, "*")
120*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_target_config, "*")
121*61c4878aSAndroid Build Coastguard Worker      default_configs += _gcc_target_default_configs
122*61c4878aSAndroid Build Coastguard Worker    }
123*61c4878aSAndroid Build Coastguard Worker  }
124*61c4878aSAndroid Build Coastguard Worker
125*61c4878aSAndroid Build Coastguard Worker  size_optimized = {
126*61c4878aSAndroid Build Coastguard Worker    name = "lm3s6965evb_qemu_gcc_size_optimized"
127*61c4878aSAndroid Build Coastguard Worker    _toolchain_base = pw_toolchain_arm_gcc.cortex_m3_size_optimized
128*61c4878aSAndroid Build Coastguard Worker    forward_variables_from(_toolchain_base, "*", _excluded_members)
129*61c4878aSAndroid Build Coastguard Worker    defaults = {
130*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_toolchain_base.defaults, "*")
131*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_target_config, "*")
132*61c4878aSAndroid Build Coastguard Worker      default_configs += _gcc_target_default_configs
133*61c4878aSAndroid Build Coastguard Worker    }
134*61c4878aSAndroid Build Coastguard Worker  }
135*61c4878aSAndroid Build Coastguard Worker
136*61c4878aSAndroid Build Coastguard Worker  debug_clang = {
137*61c4878aSAndroid Build Coastguard Worker    name = "lm3s6965evb_qemu_clang_debug"
138*61c4878aSAndroid Build Coastguard Worker    _toolchain_base = pw_toolchain_arm_clang.cortex_m3_debug
139*61c4878aSAndroid Build Coastguard Worker    forward_variables_from(_toolchain_base, "*", _excluded_members)
140*61c4878aSAndroid Build Coastguard Worker    defaults = {
141*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_toolchain_base.defaults, "*")
142*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_target_config, "*")
143*61c4878aSAndroid Build Coastguard Worker      default_configs += _clang_target_default_configs
144*61c4878aSAndroid Build Coastguard Worker    }
145*61c4878aSAndroid Build Coastguard Worker  }
146*61c4878aSAndroid Build Coastguard Worker
147*61c4878aSAndroid Build Coastguard Worker  speed_optimized_clang = {
148*61c4878aSAndroid Build Coastguard Worker    name = "lm3s6965evb_qemu_clang_speed_optimized"
149*61c4878aSAndroid Build Coastguard Worker    _toolchain_base = pw_toolchain_arm_clang.cortex_m3_speed_optimized
150*61c4878aSAndroid Build Coastguard Worker    forward_variables_from(_toolchain_base, "*", _excluded_members)
151*61c4878aSAndroid Build Coastguard Worker    defaults = {
152*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_toolchain_base.defaults, "*")
153*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_target_config, "*")
154*61c4878aSAndroid Build Coastguard Worker      default_configs += _clang_target_default_configs
155*61c4878aSAndroid Build Coastguard Worker    }
156*61c4878aSAndroid Build Coastguard Worker  }
157*61c4878aSAndroid Build Coastguard Worker
158*61c4878aSAndroid Build Coastguard Worker  size_optimized_clang = {
159*61c4878aSAndroid Build Coastguard Worker    name = "lm3s6965evb_qemu_clang_size_optimized"
160*61c4878aSAndroid Build Coastguard Worker    _toolchain_base = pw_toolchain_arm_clang.cortex_m3_size_optimized
161*61c4878aSAndroid Build Coastguard Worker    forward_variables_from(_toolchain_base, "*", _excluded_members)
162*61c4878aSAndroid Build Coastguard Worker    defaults = {
163*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_toolchain_base.defaults, "*")
164*61c4878aSAndroid Build Coastguard Worker      forward_variables_from(_target_config, "*")
165*61c4878aSAndroid Build Coastguard Worker      default_configs += _clang_target_default_configs
166*61c4878aSAndroid Build Coastguard Worker    }
167*61c4878aSAndroid Build Coastguard Worker  }
168*61c4878aSAndroid Build Coastguard Worker}
169*61c4878aSAndroid Build Coastguard Worker
170*61c4878aSAndroid Build Coastguard Worker# This list just contains the members of the above scope for convenience to make
171*61c4878aSAndroid Build Coastguard Worker# it trivial to generate all the toolchains in this file via a
172*61c4878aSAndroid Build Coastguard Worker# `generate_toolchains` target.
173*61c4878aSAndroid Build Coastguard Workerpw_target_toolchain_lm3s6965evb_qemu_list = [
174*61c4878aSAndroid Build Coastguard Worker  pw_target_toolchain_lm3s6965evb_qemu.debug,
175*61c4878aSAndroid Build Coastguard Worker  pw_target_toolchain_lm3s6965evb_qemu.speed_optimized,
176*61c4878aSAndroid Build Coastguard Worker  pw_target_toolchain_lm3s6965evb_qemu.size_optimized,
177*61c4878aSAndroid Build Coastguard Worker  pw_target_toolchain_lm3s6965evb_qemu.debug_clang,
178*61c4878aSAndroid Build Coastguard Worker  pw_target_toolchain_lm3s6965evb_qemu.speed_optimized_clang,
179*61c4878aSAndroid Build Coastguard Worker  pw_target_toolchain_lm3s6965evb_qemu.size_optimized_clang,
180*61c4878aSAndroid Build Coastguard Worker]
181