| Andrew Walbran | 692b325 | 2019-03-07 15:51:31 +0000 | [diff] [blame] | 1 | # Copyright 2018 The Hafnium Authors. |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 2 | # |
| Andrew Walbran | e959ec1 | 2020-06-17 15:01:09 +0100 | [diff] [blame] | 3 | # Use of this source code is governed by a BSD-style |
| 4 | # license that can be found in the LICENSE file or at |
| 5 | # https://opensource.org/licenses/BSD-3-Clause. |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 6 | |
| 7 | declare_args() { |
| 8 | # Set by arch toolchain. Prefix for binutils tools. |
| 9 | tool_prefix = "" |
| Alfredo Mazzinghi | 8aa8c62 | 2019-01-18 17:40:58 +0000 | [diff] [blame] | 10 | |
| 11 | # Enable link time optimizations |
| 12 | use_lto = true |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 13 | } |
| 14 | |
| 15 | # Template for embedded toolchains; there is no support for C++ or libraries. |
| 16 | # Instead, use source_set to group source together. |
| 17 | template("embedded_cc_toolchain") { |
| 18 | toolchain(target_name) { |
| 19 | assert(defined(invoker.cc), "\"cc\" must be defined for ${target_name}.") |
| 20 | assert(defined(invoker.ld), "\"ld\" must be defined for ${target_name}.") |
| 21 | |
| 22 | # Collect extra flags from the toolchain. |
| 23 | extra_defines = "" |
| Alfredo Mazzinghi | 8aa8c62 | 2019-01-18 17:40:58 +0000 | [diff] [blame] | 24 | extra_cflags = "-ffunction-sections -fdata-sections" |
| 25 | if (use_lto) { |
| 26 | extra_cflags += " -flto" |
| 27 | } |
| 28 | extra_ldflags = "-pie --gc-sections" |
| 29 | |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 30 | if (defined(invoker.extra_defines)) { |
| 31 | extra_defines += " ${invoker.extra_defines}" |
| 32 | } |
| 33 | if (defined(invoker.extra_cflags)) { |
| 34 | extra_cflags += " ${invoker.extra_cflags}" |
| 35 | } |
| 36 | if (defined(invoker.extra_ldflags)) { |
| 37 | extra_ldflags += " ${invoker.extra_ldflags}" |
| 38 | } |
| 39 | |
| 40 | # Define the tools. |
| 41 | tool("cc") { |
| 42 | depfile = "{{output}}.d" |
| 43 | command = "${invoker.cc} -MMD -MF $depfile ${extra_defines} {{defines}} {{include_dirs}} ${extra_cflags} {{cflags}} {{cflags_c}} -c {{source}} -o {{output}}" |
| 44 | depsformat = "gcc" |
| 45 | description = "CC {{output}}" |
| Olivier Deprez | 306d781 | 2023-02-02 09:51:10 +0100 | [diff] [blame] | 46 | outputs = |
| 47 | [ "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o" ] |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 48 | } |
| 49 | |
| 50 | tool("asm") { |
| 51 | depfile = "{{output}}.d" |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 52 | command = "${invoker.cc} -MMD -MF $depfile ${extra_defines} {{defines}} {{include_dirs}} ${extra_cflags} {{asmflags}} -c {{source}} -o {{output}}" |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 53 | depsformat = "gcc" |
| 54 | description = "ASM {{output}}" |
| Olivier Deprez | 306d781 | 2023-02-02 09:51:10 +0100 | [diff] [blame] | 55 | outputs = |
| 56 | [ "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o" ] |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 57 | } |
| 58 | |
| 59 | tool("link") { |
| 60 | outfile = "{{output_dir}}/{{target_output_name}}{{output_extension}}" |
| 61 | rspfile = "$outfile.rsp" |
| 62 | command = "${invoker.ld} ${extra_ldflags} {{ldflags}} -o $outfile --start-group @$rspfile --end-group" |
| 63 | description = "LINK $outfile" |
| 64 | default_output_dir = "{{root_out_dir}}" |
| 65 | rspfile_content = "{{inputs}}" |
| Olivier Deprez | 306d781 | 2023-02-02 09:51:10 +0100 | [diff] [blame] | 66 | outputs = [ outfile ] |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 67 | } |
| 68 | |
| David Brazdil | 863b150 | 2019-10-24 13:55:50 +0100 | [diff] [blame] | 69 | tool("alink") { |
| 70 | outfile = "{{target_out_dir}}/{{target_output_name}}.a" |
| 71 | command = "rm -f $outfile && ${invoker.ar} -rc $outfile {{inputs}}" |
| 72 | description = "ALINK $outfile" |
| Olivier Deprez | 306d781 | 2023-02-02 09:51:10 +0100 | [diff] [blame] | 73 | outputs = [ outfile ] |
| David Brazdil | 863b150 | 2019-10-24 13:55:50 +0100 | [diff] [blame] | 74 | } |
| 75 | |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 76 | tool("stamp") { |
| 77 | command = "touch {{output}}" |
| 78 | description = "STAMP {{output}}" |
| 79 | } |
| 80 | |
| 81 | tool("copy") { |
| 82 | command = "cp -af {{source}} {{output}}" |
| 83 | description = "COPY {{source}} {{output}}" |
| 84 | } |
| 85 | |
| 86 | toolchain_args = { |
| 87 | forward_variables_from(invoker.toolchain_args, "*") |
| 88 | } |
| 89 | } |
| 90 | } |
| 91 | |
| 92 | # Specialize for clang. |
| 93 | template("embedded_clang_toolchain") { |
| 94 | assert(defined(invoker.target), |
| 95 | "\"target\" must be defined for ${target_name}.") |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 96 | assert(defined(invoker.extra_defines), |
| 97 | "\"extra_defines\" must be defined for ${target_name}") |
| 98 | assert(defined(invoker.extra_cflags), |
| 99 | "\"extra_cflags\" must be defined for ${target_name}") |
| 100 | assert(defined(invoker.extra_ldflags), |
| 101 | "\"extra_ldflags\" must be defined for ${target_name}") |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 102 | |
| 103 | embedded_cc_toolchain(target_name) { |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 104 | cc = "clang" |
| 105 | ld = "ld.lld" |
| David Brazdil | 863b150 | 2019-10-24 13:55:50 +0100 | [diff] [blame] | 106 | ar = "llvm-ar" |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 107 | |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 108 | forward_variables_from(invoker, |
| 109 | [ |
| 110 | "extra_defines", |
| 111 | "extra_cflags", |
| 112 | "extra_ldflags", |
| 113 | ]) |
| Andrew Walbran | 883a4b2 | 2019-03-05 15:13:56 +0000 | [diff] [blame] | 114 | |
| 115 | # TODO: Remove //inc/system if we can stop using the version of stdatomic.h |
| 116 | # from the Android prebuilt Clang. |
| Olivier Deprez | 9fa3696 | 2021-09-20 14:32:14 +0100 | [diff] [blame] | 117 | extra_cflags += " -target ${invoker.target} -fcolor-diagnostics -nostdinc" + |
| 118 | " -isystem ${toolchain_lib}/include" + " -isystem " + |
| 119 | rebase_path("//inc/system") |
| Olivier Deprez | b9bb6c29 | 2021-04-20 13:45:38 +0200 | [diff] [blame] | 120 | extra_ldflags += " -O2 --icf=all --fatal-warnings --color-diagnostics" |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 121 | |
| 122 | toolchain_args = { |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 123 | if (defined(invoker.toolchain_args)) { |
| 124 | forward_variables_from(invoker.toolchain_args, "*") |
| 125 | } |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 126 | } |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 127 | } |
| 128 | } |
| 129 | |
| 130 | # Specialize for mixed toolchain with clang and bfd linker. |
| 131 | template("embedded_clang_bfd_toolchain") { |
| 132 | assert(defined(invoker.target), |
| 133 | "\"target\" must be defined for ${target_name}.") |
| 134 | assert(defined(invoker.tool_prefix), |
| 135 | "\"tool_prefix\" must be defined for ${target_name}.") |
| 136 | assert(defined(invoker.extra_defines), |
| 137 | "\"extra_defines\" must be defined for ${target_name}") |
| 138 | assert(defined(invoker.extra_cflags), |
| 139 | "\"extra_cflags\" must be defined for ${target_name}") |
| 140 | assert(defined(invoker.extra_ldflags), |
| 141 | "\"extra_ldflags\" must be defined for ${target_name}") |
| 142 | |
| 143 | embedded_cc_toolchain(target_name) { |
| 144 | cc = "clang" |
| 145 | ld = "${invoker.tool_prefix}ld.bfd" |
| David Brazdil | 863b150 | 2019-10-24 13:55:50 +0100 | [diff] [blame] | 146 | ar = "llvm-ar" |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 147 | |
| 148 | forward_variables_from(invoker, |
| 149 | [ |
| 150 | "extra_defines", |
| 151 | "extra_cflags", |
| 152 | "extra_ldflags", |
| 153 | ]) |
| 154 | extra_cflags += " -target ${invoker.target} -fcolor-diagnostics" |
| Alfredo Mazzinghi | 8aa8c62 | 2019-01-18 17:40:58 +0000 | [diff] [blame] | 155 | extra_ldflags += " --fatal-warnings" |
| 156 | if (use_lto) { |
| Olivier Deprez | b9bb6c29 | 2021-04-20 13:45:38 +0200 | [diff] [blame] | 157 | extra_ldflags += " -O2 --icf=all" |
| Alfredo Mazzinghi | 8aa8c62 | 2019-01-18 17:40:58 +0000 | [diff] [blame] | 158 | } |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 159 | |
| 160 | toolchain_args = { |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 161 | if (defined(invoker.toolchain_args)) { |
| 162 | forward_variables_from(invoker.toolchain_args, "*") |
| 163 | } |
| 164 | } |
| 165 | } |
| 166 | } |
| 167 | |
| Andrew Walbran | ff28f3b | 2019-10-21 13:00:00 +0100 | [diff] [blame] | 168 | # Expand to clang variants. |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 169 | template("embedded_platform_toolchain") { |
| 170 | assert(defined(invoker.arch), "\"arch\" must be defined for ${target_name}.") |
| 171 | assert(defined(invoker.target), |
| 172 | "\"target\" must be defined for ${target_name}.") |
| 173 | assert(defined(invoker.tool_prefix), |
| 174 | "\"tool_prefix\" must be defined for ${target_name}.") |
| 175 | assert(defined(invoker.origin_address), |
| 176 | "\"origin_address\" must be defined for ${target_name}.") |
| Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 177 | assert(defined(invoker.heap_pages), |
| 178 | "\"heap_pages\" must be defined for ${target_name}.") |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 179 | assert(defined(invoker.max_cpus), |
| 180 | "\"max_cpus\" must be defined for ${target_name}.") |
| 181 | assert(defined(invoker.max_vms), |
| 182 | "\"max_vms\" must be defined for ${target_name}.") |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 183 | assert(defined(invoker.platform_name), |
| 184 | "\"platform_name\" must be defined for ${target_name}.") |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 185 | |
| Andrew Walbran | 8e94669 | 2019-05-21 11:22:00 +0100 | [diff] [blame] | 186 | extra_defines = "" |
| 187 | extra_cflags = "-fno-builtin -ffreestanding -fpic" |
| 188 | extra_ldflags = "--defsym=ORIGIN_ADDRESS=${invoker.origin_address}" |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 189 | if (defined(invoker.extra_defines)) { |
| Andrew Walbran | 8e94669 | 2019-05-21 11:22:00 +0100 | [diff] [blame] | 190 | extra_defines += " ${invoker.extra_defines}" |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 191 | } |
| 192 | if (defined(invoker.extra_cflags)) { |
| Andrew Walbran | 8e94669 | 2019-05-21 11:22:00 +0100 | [diff] [blame] | 193 | extra_cflags += " ${invoker.extra_cflags}" |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 194 | } |
| 195 | if (defined(invoker.extra_ldflags)) { |
| Andrew Walbran | 8e94669 | 2019-05-21 11:22:00 +0100 | [diff] [blame] | 196 | extra_ldflags += " ${invoker.extra_ldflags}" |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 197 | } |
| Andrew Walbran | 8e94669 | 2019-05-21 11:22:00 +0100 | [diff] [blame] | 198 | toolchain_args = { |
| 199 | use_platform = true |
| 200 | plat_name = invoker.platform_name |
| 201 | plat_arch = invoker.arch |
| 202 | plat_heap_pages = invoker.heap_pages |
| 203 | plat_max_cpus = invoker.max_cpus |
| 204 | plat_max_vms = invoker.max_vms |
| 205 | if (defined(invoker.toolchain_args)) { |
| 206 | forward_variables_from(invoker.toolchain_args, "*") |
| 207 | } |
| 208 | } |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 209 | |
| 210 | embedded_clang_toolchain("${target_name}_clang") { |
| 211 | target = invoker.target |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 212 | } |
| 213 | |
| 214 | embedded_clang_bfd_toolchain("${target_name}_clang_bfd") { |
| 215 | target = invoker.target |
| Andrew Walbran | ff28f3b | 2019-10-21 13:00:00 +0100 | [diff] [blame] | 216 | tool_prefix = invoker.tool_prefix |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 217 | } |
| 218 | } |
| 219 | |
| 220 | # Specialize for different architectures. |
| 221 | |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 222 | template("aarch64_common_toolchain") { |
| Andrew Walbran | 549a9f2 | 2019-05-09 17:29:00 +0100 | [diff] [blame] | 223 | assert(defined(invoker.cpu), "\"cpu\" must be defined for ${target_name}.") |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 224 | assert(defined(invoker.target), |
| 225 | "\"target\" must be defined for ${target_name}") |
| 226 | assert(defined(invoker.tool_prefix), |
| 227 | "\"tool_prefix\" must be defined for ${target_name}") |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 228 | assert(defined(invoker.origin_address), |
| 229 | "\"origin_address\" must be defined for ${target_name}.") |
| Andrew Walbran | 4869936 | 2019-05-20 14:38:00 +0100 | [diff] [blame] | 230 | assert(defined(invoker.console), |
| 231 | "\"console\" must be defined for ${target_name}.") |
| Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 232 | assert(defined(invoker.heap_pages), |
| 233 | "\"heap_pages\" must be defined for ${target_name}.") |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 234 | assert(defined(invoker.max_cpus), |
| 235 | "\"max_cpus\" must be defined for ${target_name}.") |
| 236 | assert(defined(invoker.max_vms), |
| 237 | "\"max_vms\" must be defined for ${target_name}.") |
| Andrew Walbran | 53f3876 | 2018-12-07 15:21:29 +0000 | [diff] [blame] | 238 | if (invoker.gic_version == 3 || invoker.gic_version == 4) { |
| 239 | assert(defined(invoker.gicd_base_address), |
| 240 | "\"gicd_base_address\" must be defined for ${target_name}.") |
| 241 | assert(defined(invoker.gicr_base_address), |
| 242 | "\"gicr_base_address\" must be defined for ${target_name}.") |
| Bo Yan | ef64233 | 2022-02-10 10:05:11 -0800 | [diff] [blame] | 243 | assert(defined(invoker.gicr_frames), |
| 244 | "\"gicr_frames\" must be defined for ${target_name}.") |
| Andrew Walbran | 53f3876 | 2018-12-07 15:21:29 +0000 | [diff] [blame] | 245 | } |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 246 | assert(defined(invoker.platform_name), |
| 247 | "\"platform_name\" must be defined for ${target_name}.") |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 248 | |
| 249 | embedded_platform_toolchain(target_name) { |
| 250 | forward_variables_from(invoker, |
| 251 | [ |
| 252 | "origin_address", |
| Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 253 | "heap_pages", |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 254 | "max_cpus", |
| 255 | "max_vms", |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 256 | "platform_name", |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 257 | "extra_ldflags", |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 258 | ]) |
| 259 | arch = "aarch64" |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 260 | target = invoker.target |
| 261 | tool_prefix = invoker.tool_prefix |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 262 | extra_cflags = "-mcpu=${invoker.cpu} -mstrict-align" |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 263 | if (defined(invoker.extra_cflags)) { |
| 264 | extra_cflags += " ${invoker.extra_cflags}" |
| 265 | } |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 266 | |
| Andrew Walbran | 53f3876 | 2018-12-07 15:21:29 +0000 | [diff] [blame] | 267 | extra_defines = "" |
| Alfredo Mazzinghi | 62e9156 | 2019-02-13 17:11:23 +0000 | [diff] [blame] | 268 | if (defined(invoker.extra_defines)) { |
| 269 | extra_defines += " ${invoker.extra_defines}" |
| 270 | } |
| 271 | |
| Andrew Walbran | 53f3876 | 2018-12-07 15:21:29 +0000 | [diff] [blame] | 272 | if (invoker.gic_version > 0) { |
| 273 | extra_defines += " -DGIC_VERSION=${invoker.gic_version}" |
| 274 | } |
| 275 | if (invoker.gic_version == 3 || invoker.gic_version == 4) { |
| Bo Yan | ef64233 | 2022-02-10 10:05:11 -0800 | [diff] [blame] | 276 | extra_defines += " -DGICD_BASE=${invoker.gicd_base_address} -DGICR_BASE=${invoker.gicr_base_address} -DGICR_FRAMES=${invoker.gicr_frames}" |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 277 | } |
| Raghu Krishnamurthy | 94220fb | 2022-08-09 22:28:14 -0700 | [diff] [blame] | 278 | if (defined(invoker.gic_enable_espi)) { |
| 279 | extra_defines += " -DGIC_EXT_INTID=${invoker.gic_enable_espi}" |
| 280 | } |
| Raghu Krishnamurthy | 75ebf8c | 2021-11-28 07:22:12 -0800 | [diff] [blame] | 281 | if (defined(invoker.branch_protection)) { |
| 282 | extra_cflags += " -mbranch-protection=${invoker.branch_protection}" |
| 283 | extra_defines += " -DBRANCH_PROTECTION=1" |
| 284 | } |
| 285 | |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 286 | toolchain_args = { |
| David Brazdil | 0dbb41f | 2019-09-09 18:03:35 +0100 | [diff] [blame] | 287 | plat_boot_flow = invoker.boot_flow |
| Andrew Walbran | 4869936 | 2019-05-20 14:38:00 +0100 | [diff] [blame] | 288 | plat_console = invoker.console |
| Andrew Scull | 3c25745 | 2019-11-26 13:32:50 +0000 | [diff] [blame] | 289 | plat_iommu = invoker.iommu |
| David Brazdil | 5223043 | 2020-01-27 15:08:34 +0000 | [diff] [blame] | 290 | if (defined(invoker.stdout)) { |
| 291 | stdout = invoker.stdout |
| 292 | } |
| David Brazdil | a2f4521 | 2020-01-20 13:19:31 +0000 | [diff] [blame] | 293 | if (defined(invoker.max_image_size)) { |
| 294 | plat_max_image_size = invoker.max_image_size |
| 295 | } |
| Andrew Walbran | 4869936 | 2019-05-20 14:38:00 +0100 | [diff] [blame] | 296 | forward_variables_from(invoker.toolchain_args, "*") |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 297 | } |
| Maksims Svecovs | 6a0ccc9 | 2022-03-04 15:16:55 +0000 | [diff] [blame] | 298 | |
| 299 | if (defined(toolchain_args.enable_mte)) { |
| 300 | extra_cflags += " -march=armv8.5-a+memtag" |
| 301 | extra_cflags += " -fsanitize=memtag" |
| 302 | extra_defines += " -DENABLE_MTE" |
| 303 | } |
| Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 304 | } |
| 305 | } |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 306 | |
| 307 | template("aarch64_toolchain") { |
| 308 | aarch64_common_toolchain("${target_name}") { |
| 309 | forward_variables_from(invoker, "*") |
| 310 | target = "aarch64-none-eabi" |
| Olivier Deprez | 306d781 | 2023-02-02 09:51:10 +0100 | [diff] [blame] | 311 | tool_prefix = "aarch64-linux-gnu-" # TODO: this isn't right for bare metal |
| 312 | # but it works. |
| Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 313 | platform_name = target_name |
| 314 | } |
| 315 | } |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 316 | |
| 317 | template("aarch64_toolchains") { |
| 318 | aarch64_toolchain("${target_name}") { |
| 319 | forward_variables_from(invoker, |
| 320 | [ |
| 321 | "origin_address", |
| David Brazdil | 0dbb41f | 2019-09-09 18:03:35 +0100 | [diff] [blame] | 322 | "boot_flow", |
| Andrew Walbran | 4869936 | 2019-05-20 14:38:00 +0100 | [diff] [blame] | 323 | "console", |
| Andrew Scull | 3c25745 | 2019-11-26 13:32:50 +0000 | [diff] [blame] | 324 | "iommu", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 325 | "gic_version", |
| Raghu Krishnamurthy | 94220fb | 2022-08-09 22:28:14 -0700 | [diff] [blame] | 326 | "gic_enable_espi", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 327 | "gicd_base_address", |
| 328 | "gicr_base_address", |
| Bo Yan | ef64233 | 2022-02-10 10:05:11 -0800 | [diff] [blame] | 329 | "gicr_frames", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 330 | "heap_pages", |
| 331 | "max_cpus", |
| David Brazdil | a2f4521 | 2020-01-20 13:19:31 +0000 | [diff] [blame] | 332 | "max_image_size", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 333 | "max_vms", |
| Andrew Walbran | 4869936 | 2019-05-20 14:38:00 +0100 | [diff] [blame] | 334 | "toolchain_args", |
| Raghu Krishnamurthy | 75ebf8c | 2021-11-28 07:22:12 -0800 | [diff] [blame] | 335 | "branch_protection", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 336 | ]) |
| 337 | cpu = "${invoker.cpu}+nofp" |
| David Brazdil | 711fbe9 | 2019-08-06 13:39:58 +0100 | [diff] [blame] | 338 | |
| 339 | # Add a macro so files can tell whether they are not being built for a VM. |
| 340 | extra_defines = " -DVM_TOOLCHAIN=0" |
| Maksims Svecovs | 6a0ccc9 | 2022-03-04 15:16:55 +0000 | [diff] [blame] | 341 | extra_cflags = " -mgeneral-regs-only" |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 342 | } |
| 343 | |
| 344 | # Toolchain for building test VMs which run under Hafnium. |
| 345 | aarch64_toolchain("${target_name}_vm") { |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 346 | forward_variables_from(invoker, |
| 347 | [ |
| 348 | "origin_address", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 349 | "gic_version", |
| Raghu Krishnamurthy | 94220fb | 2022-08-09 22:28:14 -0700 | [diff] [blame] | 350 | "gic_enable_espi", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 351 | "gicd_base_address", |
| 352 | "gicr_base_address", |
| Bo Yan | ef64233 | 2022-02-10 10:05:11 -0800 | [diff] [blame] | 353 | "gicr_frames", |
| Andrew Walbran | afabe85 | 2019-03-20 17:55:11 +0000 | [diff] [blame] | 354 | "max_cpus", |
| Andrew Walbran | 4869936 | 2019-05-20 14:38:00 +0100 | [diff] [blame] | 355 | "toolchain_args", |
| David Brazdil | 5223043 | 2020-01-27 15:08:34 +0000 | [diff] [blame] | 356 | "console", |
| Raghu Krishnamurthy | 75ebf8c | 2021-11-28 07:22:12 -0800 | [diff] [blame] | 357 | "branch_protection", |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 358 | ]) |
| 359 | cpu = "${invoker.cpu}+fp" |
| David Brazdil | 0dbb41f | 2019-09-09 18:03:35 +0100 | [diff] [blame] | 360 | boot_flow = "//src/arch/fake:boot_flow" |
| Andrew Scull | 3c25745 | 2019-11-26 13:32:50 +0000 | [diff] [blame] | 361 | iommu = "//src/iommu:absent" |
| David Brazdil | 5223043 | 2020-01-27 15:08:34 +0000 | [diff] [blame] | 362 | stdout = "//src/arch/aarch64/hftest:stdout" |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 363 | |
| 364 | # Nonsense values because they are required but shouldn't be used. |
| 365 | heap_pages = 0 |
| Andrew Walbran | 7f904bf | 2019-07-12 16:38:38 +0100 | [diff] [blame] | 366 | max_vms = 0 |
| David Brazdil | 711fbe9 | 2019-08-06 13:39:58 +0100 | [diff] [blame] | 367 | |
| 368 | # Add a macro so files can tell whether they are being built for a VM. |
| 369 | extra_defines = " -DVM_TOOLCHAIN=1" |
| Andrew Walbran | 7559fcf | 2019-05-09 17:11:20 +0100 | [diff] [blame] | 370 | } |
| 371 | } |