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 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | # you may not use this file except in compliance with the License. |
| 5 | # You may obtain a copy of the License at |
| 6 | # |
| 7 | # https://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | # See the License for the specific language governing permissions and |
| 13 | # limitations under the License. |
| 14 | |
| 15 | declare_args() { |
| 16 | # Set by arch toolchain. Prefix for binutils tools. |
| 17 | tool_prefix = "" |
Alfredo Mazzinghi | 8aa8c62 | 2019-01-18 17:40:58 +0000 | [diff] [blame] | 18 | |
| 19 | # Enable link time optimizations |
| 20 | use_lto = true |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 21 | } |
| 22 | |
| 23 | # Template for embedded toolchains; there is no support for C++ or libraries. |
| 24 | # Instead, use source_set to group source together. |
| 25 | template("embedded_cc_toolchain") { |
| 26 | toolchain(target_name) { |
| 27 | assert(defined(invoker.cc), "\"cc\" must be defined for ${target_name}.") |
| 28 | assert(defined(invoker.ld), "\"ld\" must be defined for ${target_name}.") |
| 29 | |
| 30 | # Collect extra flags from the toolchain. |
| 31 | extra_defines = "" |
Alfredo Mazzinghi | 8aa8c62 | 2019-01-18 17:40:58 +0000 | [diff] [blame] | 32 | extra_cflags = "-ffunction-sections -fdata-sections" |
| 33 | if (use_lto) { |
| 34 | extra_cflags += " -flto" |
| 35 | } |
| 36 | extra_ldflags = "-pie --gc-sections" |
| 37 | |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 38 | if (defined(invoker.extra_defines)) { |
| 39 | extra_defines += " ${invoker.extra_defines}" |
| 40 | } |
| 41 | if (defined(invoker.extra_cflags)) { |
| 42 | extra_cflags += " ${invoker.extra_cflags}" |
| 43 | } |
| 44 | if (defined(invoker.extra_ldflags)) { |
| 45 | extra_ldflags += " ${invoker.extra_ldflags}" |
| 46 | } |
| 47 | |
| 48 | # Define the tools. |
| 49 | tool("cc") { |
| 50 | depfile = "{{output}}.d" |
| 51 | command = "${invoker.cc} -MMD -MF $depfile ${extra_defines} {{defines}} {{include_dirs}} ${extra_cflags} {{cflags}} {{cflags_c}} -c {{source}} -o {{output}}" |
| 52 | depsformat = "gcc" |
| 53 | description = "CC {{output}}" |
| 54 | outputs = [ |
| 55 | "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o", |
| 56 | ] |
| 57 | } |
| 58 | |
| 59 | tool("asm") { |
| 60 | depfile = "{{output}}.d" |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 61 | 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] | 62 | depsformat = "gcc" |
| 63 | description = "ASM {{output}}" |
| 64 | outputs = [ |
| 65 | "{{source_out_dir}}/{{target_output_name}}.{{source_name_part}}.o", |
| 66 | ] |
| 67 | } |
| 68 | |
| 69 | tool("link") { |
| 70 | outfile = "{{output_dir}}/{{target_output_name}}{{output_extension}}" |
| 71 | rspfile = "$outfile.rsp" |
| 72 | command = "${invoker.ld} ${extra_ldflags} {{ldflags}} -o $outfile --start-group @$rspfile --end-group" |
| 73 | description = "LINK $outfile" |
| 74 | default_output_dir = "{{root_out_dir}}" |
| 75 | rspfile_content = "{{inputs}}" |
| 76 | outputs = [ |
| 77 | outfile, |
| 78 | ] |
| 79 | } |
| 80 | |
| 81 | tool("stamp") { |
| 82 | command = "touch {{output}}" |
| 83 | description = "STAMP {{output}}" |
| 84 | } |
| 85 | |
| 86 | tool("copy") { |
| 87 | command = "cp -af {{source}} {{output}}" |
| 88 | description = "COPY {{source}} {{output}}" |
| 89 | } |
| 90 | |
| 91 | toolchain_args = { |
| 92 | forward_variables_from(invoker.toolchain_args, "*") |
| 93 | } |
| 94 | } |
| 95 | } |
| 96 | |
| 97 | # Specialize for clang. |
| 98 | template("embedded_clang_toolchain") { |
| 99 | assert(defined(invoker.target), |
| 100 | "\"target\" must be defined for ${target_name}.") |
| 101 | assert(defined(invoker.tool_prefix), |
| 102 | "\"tool_prefix\" must be defined for ${target_name}.") |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 103 | assert(defined(invoker.extra_defines), |
| 104 | "\"extra_defines\" must be defined for ${target_name}") |
| 105 | assert(defined(invoker.extra_cflags), |
| 106 | "\"extra_cflags\" must be defined for ${target_name}") |
| 107 | assert(defined(invoker.extra_ldflags), |
| 108 | "\"extra_ldflags\" must be defined for ${target_name}") |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 109 | |
| 110 | embedded_cc_toolchain(target_name) { |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 111 | cc = "clang" |
| 112 | ld = "ld.lld" |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 113 | |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 114 | forward_variables_from(invoker, |
| 115 | [ |
| 116 | "extra_defines", |
| 117 | "extra_cflags", |
| 118 | "extra_ldflags", |
| 119 | ]) |
Andrew Walbran | 883a4b2 | 2019-03-05 15:13:56 +0000 | [diff] [blame] | 120 | |
| 121 | # TODO: Remove //inc/system if we can stop using the version of stdatomic.h |
| 122 | # from the Android prebuilt Clang. |
| 123 | extra_cflags += |
| 124 | " -target ${invoker.target} -fcolor-diagnostics -nostdinc -isystem" + |
Andrew Walbran | 883a4b2 | 2019-03-05 15:13:56 +0000 | [diff] [blame] | 125 | rebase_path("//prebuilts/linux-x64/clang/lib64/clang/8.0.4/include") + |
| 126 | " -isystem" + rebase_path("//inc/system") |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 127 | extra_ldflags += |
| 128 | " -O2 -lto-O2 --icf=all --fatal-warnings --color-diagnostics" |
| 129 | |
| 130 | toolchain_args = { |
| 131 | tool_prefix = invoker.tool_prefix |
| 132 | if (defined(invoker.toolchain_args)) { |
| 133 | forward_variables_from(invoker.toolchain_args, "*") |
| 134 | } |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 135 | } |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 136 | } |
| 137 | } |
| 138 | |
| 139 | # Specialize for mixed toolchain with clang and bfd linker. |
| 140 | template("embedded_clang_bfd_toolchain") { |
| 141 | assert(defined(invoker.target), |
| 142 | "\"target\" must be defined for ${target_name}.") |
| 143 | assert(defined(invoker.tool_prefix), |
| 144 | "\"tool_prefix\" must be defined for ${target_name}.") |
| 145 | assert(defined(invoker.extra_defines), |
| 146 | "\"extra_defines\" must be defined for ${target_name}") |
| 147 | assert(defined(invoker.extra_cflags), |
| 148 | "\"extra_cflags\" must be defined for ${target_name}") |
| 149 | assert(defined(invoker.extra_ldflags), |
| 150 | "\"extra_ldflags\" must be defined for ${target_name}") |
| 151 | |
| 152 | embedded_cc_toolchain(target_name) { |
| 153 | cc = "clang" |
| 154 | ld = "${invoker.tool_prefix}ld.bfd" |
| 155 | |
| 156 | forward_variables_from(invoker, |
| 157 | [ |
| 158 | "extra_defines", |
| 159 | "extra_cflags", |
| 160 | "extra_ldflags", |
| 161 | ]) |
| 162 | extra_cflags += " -target ${invoker.target} -fcolor-diagnostics" |
Alfredo Mazzinghi | 8aa8c62 | 2019-01-18 17:40:58 +0000 | [diff] [blame] | 163 | extra_ldflags += " --fatal-warnings" |
| 164 | if (use_lto) { |
| 165 | extra_ldflags += " -O2 -lto-O2 --icf=all" |
| 166 | } |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 167 | |
| 168 | toolchain_args = { |
| 169 | tool_prefix = invoker.tool_prefix |
| 170 | if (defined(invoker.toolchain_args)) { |
| 171 | forward_variables_from(invoker.toolchain_args, "*") |
| 172 | } |
| 173 | } |
| 174 | } |
| 175 | } |
| 176 | |
| 177 | # Specialize for gcc. |
| 178 | template("embedded_gcc_toolchain") { |
| 179 | assert(defined(invoker.tool_prefix), |
| 180 | "\"tool_prefix\" must be defined for ${target_name}.") |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 181 | assert(defined(invoker.extra_defines), |
| 182 | "\"extra_defines\" must be defined for ${target_name}.") |
| 183 | assert(defined(invoker.extra_cflags), |
| 184 | "\"extra_cflags\" must be defined for ${target_name}.") |
| 185 | assert(defined(invoker.extra_ldflags), |
| 186 | "\"extra_ldflags\" must be defined for ${target_name}.") |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 187 | |
| 188 | embedded_cc_toolchain(target_name) { |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 189 | cc = "${invoker.tool_prefix}gcc" |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 190 | ld = "${invoker.tool_prefix}ld" |
| 191 | |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 192 | forward_variables_from(invoker, |
| 193 | [ |
| 194 | "extra_defines", |
| 195 | "extra_cflags", |
| 196 | "extra_ldflags", |
| 197 | ]) |
| 198 | |
| 199 | extra_cflags += " -fdiagnostics-color=always" |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 200 | |
| 201 | toolchain_args = { |
| 202 | tool_prefix = invoker.tool_prefix |
| 203 | if (defined(invoker.toolchain_args)) { |
| 204 | forward_variables_from(invoker.toolchain_args, "*") |
| 205 | } |
| 206 | } |
| 207 | } |
| 208 | } |
| 209 | |
| 210 | # Expand to clang and gcc variants. |
| 211 | template("embedded_platform_toolchain") { |
| 212 | assert(defined(invoker.arch), "\"arch\" must be defined for ${target_name}.") |
| 213 | assert(defined(invoker.target), |
| 214 | "\"target\" must be defined for ${target_name}.") |
| 215 | assert(defined(invoker.tool_prefix), |
| 216 | "\"tool_prefix\" must be defined for ${target_name}.") |
| 217 | assert(defined(invoker.origin_address), |
| 218 | "\"origin_address\" must be defined for ${target_name}.") |
Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 219 | assert(defined(invoker.heap_pages), |
| 220 | "\"heap_pages\" must be defined for ${target_name}.") |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 221 | assert(defined(invoker.max_cpus), |
| 222 | "\"max_cpus\" must be defined for ${target_name}.") |
| 223 | assert(defined(invoker.max_vms), |
| 224 | "\"max_vms\" must be defined for ${target_name}.") |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 225 | assert(defined(invoker.platform_name), |
| 226 | "\"platform_name\" must be defined for ${target_name}.") |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 227 | |
| 228 | defines = "" |
Andrew Scull | a59f9bc | 2019-04-03 15:24:35 +0100 | [diff] [blame] | 229 | cflags = "-fno-builtin -ffreestanding -fpic" |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 230 | ldflags = "--defsym=ORIGIN_ADDRESS=${invoker.origin_address}" |
| 231 | if (defined(invoker.extra_defines)) { |
| 232 | defines += " ${invoker.extra_defines}" |
| 233 | } |
| 234 | if (defined(invoker.extra_cflags)) { |
| 235 | cflags += " ${invoker.extra_cflags}" |
| 236 | } |
| 237 | if (defined(invoker.extra_ldflags)) { |
| 238 | ldflags += " ${invoker.extra_ldflags}" |
| 239 | } |
| 240 | |
| 241 | embedded_clang_toolchain("${target_name}_clang") { |
| 242 | target = invoker.target |
| 243 | tool_prefix = invoker.tool_prefix |
| 244 | extra_defines = defines |
| 245 | extra_cflags = cflags |
| 246 | extra_ldflags = ldflags |
| 247 | toolchain_args = { |
Andrew Scull | b401ba3 | 2018-11-09 10:30:54 +0000 | [diff] [blame] | 248 | use_platform = true |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 249 | plat_name = invoker.platform_name |
| 250 | plat_arch = invoker.arch |
| 251 | plat_heap_pages = invoker.heap_pages |
| 252 | plat_max_cpus = invoker.max_cpus |
| 253 | plat_max_vms = invoker.max_vms |
| 254 | if (defined(invoker.toolchain_args)) { |
| 255 | forward_variables_from(invoker.toolchain_args, "*") |
| 256 | } |
| 257 | } |
| 258 | } |
| 259 | |
| 260 | embedded_clang_bfd_toolchain("${target_name}_clang_bfd") { |
| 261 | target = invoker.target |
| 262 | tool_prefix = invoker.tool_prefix |
| 263 | extra_defines = defines |
| 264 | extra_cflags = cflags |
| 265 | extra_ldflags = ldflags |
| 266 | toolchain_args = { |
| 267 | use_platform = true |
| 268 | plat_name = invoker.platform_name |
Andrew Scull | b401ba3 | 2018-11-09 10:30:54 +0000 | [diff] [blame] | 269 | plat_arch = invoker.arch |
Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 270 | plat_heap_pages = invoker.heap_pages |
Andrew Scull | b401ba3 | 2018-11-09 10:30:54 +0000 | [diff] [blame] | 271 | plat_max_cpus = invoker.max_cpus |
| 272 | plat_max_vms = invoker.max_vms |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 273 | if (defined(invoker.toolchain_args)) { |
| 274 | forward_variables_from(invoker.toolchain_args, "*") |
| 275 | } |
| 276 | } |
| 277 | } |
| 278 | |
| 279 | embedded_gcc_toolchain("${target_name}_gcc") { |
| 280 | tool_prefix = invoker.tool_prefix |
| 281 | extra_defines = defines |
| 282 | extra_cflags = cflags |
| 283 | extra_ldflags = ldflags |
| 284 | toolchain_args = { |
Andrew Scull | b401ba3 | 2018-11-09 10:30:54 +0000 | [diff] [blame] | 285 | use_platform = true |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 286 | plat_name = invoker.platform_name |
Andrew Scull | b401ba3 | 2018-11-09 10:30:54 +0000 | [diff] [blame] | 287 | plat_arch = invoker.arch |
Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 288 | plat_heap_pages = invoker.heap_pages |
Andrew Scull | b401ba3 | 2018-11-09 10:30:54 +0000 | [diff] [blame] | 289 | plat_max_cpus = invoker.max_cpus |
| 290 | plat_max_vms = invoker.max_vms |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 291 | if (defined(invoker.toolchain_args)) { |
| 292 | forward_variables_from(invoker.toolchain_args, "*") |
| 293 | } |
| 294 | } |
| 295 | } |
| 296 | } |
| 297 | |
| 298 | # Specialize for different architectures. |
| 299 | |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 300 | template("aarch64_common_toolchain") { |
Andrew Walbran | 549a9f2 | 2019-05-09 17:29:00 +0100 | [diff] [blame] | 301 | assert(defined(invoker.cpu), "\"cpu\" must be defined for ${target_name}.") |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 302 | assert(defined(invoker.target), |
| 303 | "\"target\" must be defined for ${target_name}") |
| 304 | assert(defined(invoker.tool_prefix), |
| 305 | "\"tool_prefix\" must be defined for ${target_name}") |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 306 | assert(defined(invoker.origin_address), |
| 307 | "\"origin_address\" must be defined for ${target_name}.") |
| 308 | assert(defined(invoker.use_pl011), |
| 309 | "\"use_pl011\" must be defined for ${target_name}.") |
Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 310 | assert(defined(invoker.heap_pages), |
| 311 | "\"heap_pages\" must be defined for ${target_name}.") |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 312 | assert(defined(invoker.max_cpus), |
| 313 | "\"max_cpus\" must be defined for ${target_name}.") |
| 314 | assert(defined(invoker.max_vms), |
| 315 | "\"max_vms\" must be defined for ${target_name}.") |
Andrew Walbran | 53f3876 | 2018-12-07 15:21:29 +0000 | [diff] [blame] | 316 | if (invoker.gic_version == 3 || invoker.gic_version == 4) { |
| 317 | assert(defined(invoker.gicd_base_address), |
| 318 | "\"gicd_base_address\" must be defined for ${target_name}.") |
| 319 | assert(defined(invoker.gicr_base_address), |
| 320 | "\"gicr_base_address\" must be defined for ${target_name}.") |
| 321 | } |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 322 | assert(defined(invoker.platform_name), |
| 323 | "\"platform_name\" must be defined for ${target_name}.") |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 324 | |
| 325 | embedded_platform_toolchain(target_name) { |
| 326 | forward_variables_from(invoker, |
| 327 | [ |
| 328 | "origin_address", |
Andrew Walbran | de33f08 | 2018-12-07 14:10:11 +0000 | [diff] [blame] | 329 | "heap_pages", |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 330 | "max_cpus", |
| 331 | "max_vms", |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 332 | "platform_name", |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 333 | "extra_ldflags", |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 334 | ]) |
| 335 | arch = "aarch64" |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 336 | target = invoker.target |
| 337 | tool_prefix = invoker.tool_prefix |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 338 | extra_cflags = "-mcpu=${invoker.cpu} -mstrict-align" |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 339 | if (defined(invoker.extra_cflags)) { |
| 340 | extra_cflags += " ${invoker.extra_cflags}" |
| 341 | } |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 342 | |
Andrew Walbran | 53f3876 | 2018-12-07 15:21:29 +0000 | [diff] [blame] | 343 | extra_defines = "" |
Alfredo Mazzinghi | 62e9156 | 2019-02-13 17:11:23 +0000 | [diff] [blame] | 344 | if (defined(invoker.extra_defines)) { |
| 345 | extra_defines += " ${invoker.extra_defines}" |
| 346 | } |
| 347 | |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 348 | if (invoker.use_pl011) { |
| 349 | assert(defined(invoker.pl011_base_address), |
| 350 | "\"pl011_base_address\" must be defined for ${target_name}.") |
Andrew Walbran | 53f3876 | 2018-12-07 15:21:29 +0000 | [diff] [blame] | 351 | extra_defines += " -DPL011_BASE=${invoker.pl011_base_address}" |
| 352 | } |
| 353 | if (invoker.gic_version > 0) { |
| 354 | extra_defines += " -DGIC_VERSION=${invoker.gic_version}" |
| 355 | } |
| 356 | if (invoker.gic_version == 3 || invoker.gic_version == 4) { |
| 357 | extra_defines += " -DGICD_BASE=${invoker.gicd_base_address} -DGICR_BASE=${invoker.gicr_base_address}" |
Andrew Scull | 23e93a8 | 2018-10-26 14:56:04 +0100 | [diff] [blame] | 358 | } |
| 359 | |
| 360 | toolchain_args = { |
| 361 | arch_aarch64_use_pl011 = invoker.use_pl011 |
| 362 | } |
| 363 | } |
| 364 | } |
Alfredo Mazzinghi | 880f5b2 | 2019-02-07 15:42:41 +0000 | [diff] [blame] | 365 | |
| 366 | template("aarch64_toolchain") { |
| 367 | aarch64_common_toolchain("${target_name}") { |
| 368 | forward_variables_from(invoker, "*") |
| 369 | target = "aarch64-none-eabi" |
| 370 | tool_prefix = "aarch64-linux-gnu-" # TODO: this isn't right for bare metal but it works. |
| 371 | platform_name = target_name |
| 372 | } |
| 373 | } |