| # Copyright 2016 The Chromium Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style license that can be |
| # found in the LICENSE file. |
| |
| if (current_cpu == "x86") { |
| _yasm_flags = [ |
| "-felf32", |
| "-m", |
| "x86", |
| ] |
| } else if (current_cpu == "x64") { |
| _yasm_flags = [ |
| "-DPIC", |
| "-felf64", |
| "-m", |
| "amd64", |
| ] |
| } |
| |
| template("yasm_assemble") { |
| action_name = "${target_name}_action" |
| source_set_name = target_name |
| |
| action_foreach(action_name) { |
| # Only the source set can depend on this. |
| visibility = [ ":$source_set_name" ] |
| |
| script = "//third_party/yasm/run_yasm.py" |
| sources = invoker.sources |
| |
| if (defined(invoker.inputs)) { |
| inputs = invoker.inputs |
| } |
| |
| deps = [] |
| if (defined(invoker.deps)) { |
| deps += invoker.deps |
| } |
| |
| args = [ "yasm" ] + _yasm_flags |
| if (defined(invoker.yasm_flags)) { |
| args += invoker.yasm_flags |
| } |
| |
| # User defined include dirs go first. |
| if (defined(invoker.include_dirs)) { |
| foreach(include, invoker.include_dirs) { |
| args += [ "-I" + rebase_path(include, root_build_dir) ] |
| } |
| } |
| |
| # Default yasm include dirs. Make it match the native build (source root and |
| # root generated code directory). |
| # This goes to the end of include list. |
| args += [ |
| "-I.", |
| |
| # Using "//." will produce a relative path "../.." which looks better than |
| # "../../" which will result from using "//" as the base (although both |
| # work). This is because rebase_path will terminate the result in a |
| # slash if the input ends in a slash. |
| "-I" + rebase_path("//.", root_build_dir), |
| "-I" + rebase_path(root_gen_dir, root_build_dir), |
| ] |
| |
| # Extra defines. |
| if (defined(invoker.defines)) { |
| foreach(def, invoker.defines) { |
| args += [ "-D$def" ] |
| } |
| } |
| |
| # Output file. |
| outputs = [ |
| "$target_out_dir/$source_set_name/{{source_name_part}}.o", |
| ] |
| args += [ |
| "-o", |
| rebase_path(outputs[0], root_build_dir), |
| "{{source}}", |
| ] |
| |
| # The wrapper script run_yasm will write the depfile to the same name as |
| # the output but with .d appended (like gcc will). |
| depfile = outputs[0] + ".d" |
| } |
| |
| # Gather the .o files into a linkable thing. This doesn't actually link |
| # anything (a source set just compiles files to link later), but will pass |
| # the object files generated by the action up the dependency chain. |
| static_library(source_set_name) { |
| if (defined(invoker.visibility)) { |
| visibility = invoker.visibility |
| } |
| |
| sources = get_target_outputs(":$action_name") |
| |
| deps = [ |
| ":$action_name", |
| ] |
| } |
| } |