| # Copyright 2020 The Fuchsia Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style license that can be |
| # found in the LICENSE file. |
| |
| import("//build/zircon/tools.gni") |
| import("zbi_input.gni") |
| |
| declare_args() { |
| # Compression setting for ZBI "storage" items. |
| # This can be "zstd", optionally followed by ".LEVEL" |
| # where `LEVEL` can be an integer or "max". |
| zbi_compression = "zstd" |
| } |
| |
| # Assembles a Zircon Boot Image file from various inputs. |
| # |
| # Parameters |
| # |
| # This template has two outputs: the first is the ZBI in question, whose path |
| # is a function of the `output_dir`, `output_name`, and `output_extension` |
| # parameters in the usual way, and the second is a JSON representation of its |
| # contents whose path is formed by adding a further ".json" to the ZBI's path. |
| # |
| # cpu |
| # Optional: A CPU name ("arm64" or "x64") or "". If not "", ensure that |
| # the ZBI is bootable on this CPU, failing if not. If "", then no such |
| # check is performed so this can be used to generate a partial ZBI |
| # which can be converted to a full bootable ZBI by a later action. |
| # Type: string |
| # Default: current_cpu |
| # |
| # compress |
| # Optional: Whether to compress the BOOTFS and other `ZBI_TYPE_STORAGE` |
| # items in the output. See the `--compressed` switch in `zbi --help`. |
| # If this is a string rather than a bool, it's the argument for the |
| # `--compressed` switch to `zbi`. A value of `true` is replaced with |
| # $zbi_compression. |
| # Type: bool or string |
| # Default: true |
| # |
| # output_dir |
| # Optional: Directory where the output file is written. |
| # Type: dir |
| # Default: target_out_dir |
| # |
| # output_extension |
| # Optional: Extension added to $output_name. |
| # Type: string |
| # Default: "zbi" |
| # |
| # output_name |
| # Optional: Name of the output file. |
| # Type: string |
| # Default: target_name |
| # |
| # deps, data_deps, testonly, assert_no_deps, metadata, visibility |
| # See `gn help`. |
| template("zbi") { |
| main_target = target_name |
| input_target = "${target_name}_input" |
| rsp_target = "${target_name}_rsp" |
| |
| rsp_file = "$target_gen_dir/$target_name.zbi.rsp" |
| |
| zbi_input(input_target) { |
| forward_variables_from(invoker, |
| [ |
| "deps", |
| "testonly", |
| ]) |
| } |
| |
| # Collect metadata corresponding to additional command-line arguments |
| # passed to the `zbi` host tool, describing inputs to be assembled into |
| # the final ZBI image. The schema for the metadata is: |
| # |
| # zbi_input_args: a list of strings, each one corresponding to a |
| # command-line argument. |
| # |
| # zbi_input_barrier: usual GN metadata collection walk key, used to |
| # restrict collection to specific target dependencies when needed. |
| # |
| generated_file(rsp_target) { |
| forward_variables_from(invoker, [ "testonly" ]) |
| deps = [ ":$input_target" ] |
| data_keys = [ "zbi_input_args" ] |
| walk_keys = [ "zbi_input_barrier" ] |
| output_conversion = "list lines" |
| outputs = [ rsp_file ] |
| } |
| |
| _output_name = target_name |
| if (defined(invoker.output_name)) { |
| _output_name = invoker.output_name |
| } |
| if (defined(invoker.output_extension)) { |
| if (invoker.output_extension != "") { |
| _output_name += ".${invoker.output_extension}" |
| } |
| } else { |
| _output_name += ".zbi" |
| } |
| if (defined(invoker.output_dir)) { |
| output_file = "${invoker.output_dir}/${_output_name}" |
| } else { |
| output_file = "$target_out_dir/${_output_name}" |
| } |
| json_output_file = "$output_file.json" |
| |
| action(main_target) { |
| forward_variables_from(invoker, |
| [ |
| "assert_no_deps", |
| "compress", |
| "data_deps", |
| "testonly", |
| "visibility", |
| ]) |
| |
| script = "//build/zbi/run_zbi.py" |
| |
| deps = [ |
| ":$rsp_target", |
| zbi_tool_target, |
| ] |
| |
| inputs = [ |
| rsp_file, |
| zbi_tool_path, |
| ] |
| outputs = [ |
| output_file, |
| json_output_file, |
| ] |
| depfile = "$output_file.d" |
| |
| args = [ |
| "--zbi", |
| rebase_path(zbi_tool_path, root_build_dir), |
| "--depfile", |
| rebase_path(depfile, root_build_dir), |
| "--rspfile", |
| rebase_path(rsp_file, root_build_dir), |
| |
| # The remaining arguments are passed to the zbi tool along with the |
| # contents of the response file. |
| "--output", |
| rebase_path(outputs[0], root_build_dir), |
| |
| "--json-output", |
| rebase_path(outputs[1], root_build_dir), |
| ] |
| |
| # Require a bootable ZBI for the specified $cpu (or $current_cpu). |
| # A value of "" means it need not be a bootable ZBI. |
| if (defined(invoker.cpu)) { |
| cpu = invoker.cpu |
| } else { |
| cpu = current_cpu |
| } |
| if (cpu != "") { |
| args += [ "--bootable=$cpu" ] |
| } |
| |
| # This comes last to affect the output despite any earlier |
| # "-c" or "-u" from metadata.zbi_input_args meant to affect |
| # a particular input (e.g. for "--type=ramdisk"). |
| if (!defined(compress) || compress == true) { |
| compress = zbi_compression |
| } |
| if (compress == false) { |
| args += [ "--uncompressed" ] |
| } else { |
| args += [ "--compressed=$compress" ] |
| } |
| |
| metadata = { |
| # Provide metadata so that a zbi() target can also act as if it were a |
| # zbi_input() with type == "zbi" and $sources of this target's $outputs. |
| # Thus a zbi() target can be a dependency of another zbi() target to |
| # combine them without requiring an intervening zbi_input() target. |
| zbi_input_barrier = [] |
| zbi_input_args = [] |
| |
| if (defined(invoker.metadata)) { |
| forward_variables_from(invoker.metadata, "*") |
| } |
| |
| zbi_input_args += [ |
| "--type=container", |
| rebase_path(output_file, root_build_dir), |
| ] |
| } |
| } |
| } |