OLD | NEW |
(Empty) | |
| 1 # Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 # Use of this source code is governed by a BSD-style license that can be |
| 3 # found in the LICENSE file. |
| 4 |
| 5 if (current_cpu == "x86") { |
| 6 _yasm_flags = [ |
| 7 "-felf32", |
| 8 "-m", |
| 9 "x86", |
| 10 ] |
| 11 } else if (current_cpu == "x64") { |
| 12 _yasm_flags = [ |
| 13 "-DPIC", |
| 14 "-felf64", |
| 15 "-m", |
| 16 "amd64", |
| 17 ] |
| 18 } |
| 19 |
| 20 template("yasm_assemble") { |
| 21 action_name = "${target_name}_action" |
| 22 source_set_name = target_name |
| 23 |
| 24 action_foreach(action_name) { |
| 25 # Only the source set can depend on this. |
| 26 visibility = [ ":$source_set_name" ] |
| 27 |
| 28 script = "//third_party/yasm/run_yasm.py" |
| 29 sources = invoker.sources |
| 30 |
| 31 if (defined(invoker.inputs)) { |
| 32 inputs = invoker.inputs |
| 33 } |
| 34 |
| 35 deps = [] |
| 36 if (defined(invoker.deps)) { |
| 37 deps += invoker.deps |
| 38 } |
| 39 |
| 40 args = [ "yasm" ] + _yasm_flags |
| 41 if (defined(invoker.yasm_flags)) { |
| 42 args += invoker.yasm_flags |
| 43 } |
| 44 |
| 45 # User defined include dirs go first. |
| 46 if (defined(invoker.include_dirs)) { |
| 47 foreach(include, invoker.include_dirs) { |
| 48 args += [ "-I" + rebase_path(include, root_build_dir) ] |
| 49 } |
| 50 } |
| 51 |
| 52 # Default yasm include dirs. Make it match the native build (source root and |
| 53 # root generated code directory). |
| 54 # This goes to the end of include list. |
| 55 args += [ |
| 56 "-I.", |
| 57 |
| 58 # Using "//." will produce a relative path "../.." which looks better than |
| 59 # "../../" which will result from using "//" as the base (although both |
| 60 # work). This is because rebase_path will terminate the result in a |
| 61 # slash if the input ends in a slash. |
| 62 "-I" + rebase_path("//.", root_build_dir), |
| 63 "-I" + rebase_path(root_gen_dir, root_build_dir), |
| 64 ] |
| 65 |
| 66 # Extra defines. |
| 67 if (defined(invoker.defines)) { |
| 68 foreach(def, invoker.defines) { |
| 69 args += [ "-D$def" ] |
| 70 } |
| 71 } |
| 72 |
| 73 # Output file. |
| 74 outputs = [ |
| 75 "$target_out_dir/{{source_name_part}}.o", |
| 76 ] |
| 77 args += [ |
| 78 "-o", |
| 79 rebase_path(outputs[0], root_build_dir), |
| 80 "{{source}}", |
| 81 ] |
| 82 |
| 83 # The wrapper script run_yasm will write the depfile to the same name as |
| 84 # the output but with .d appended (like gcc will). |
| 85 depfile = outputs[0] + ".d" |
| 86 } |
| 87 |
| 88 # Gather the .o files into a linkable thing. This doesn't actually link |
| 89 # anything (a source set just compiles files to link later), but will pass |
| 90 # the object files generated by the action up the dependency chain. |
| 91 source_set(source_set_name) { |
| 92 if (defined(invoker.visibility)) { |
| 93 visibility = invoker.visibility |
| 94 } |
| 95 |
| 96 sources = get_target_outputs(":$action_name") |
| 97 |
| 98 deps = [ |
| 99 ":$action_name", |
| 100 ] |
| 101 } |
| 102 } |
OLD | NEW |