Cancel on-going scan when change directory is requested.
[chromium-blink-merge.git] / third_party / yasm / yasm_assemble.gni
blob1a84d5149d29e66f09af6f7f05c0a0b18369bd62
1 # Copyright 2014 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.
5 # This provides the yasm_assemble() template which uses YASM to assemble
6 # assembly files.
8 # Files to be assembled with YASM should have an extension of .asm.
10 # Parameters
12 #   yasm_flags (optional)
13 #       [list of strings] Pass additional flags into YASM. These are appended
14 #       to the command line. Note that the target machine type and system is
15 #       already set up based on the current toolchain so you don't need to
16 #       specify these things (see below).
18 #       Example: yasm_flags = [ "--force-strict" ]
20 #   include_dirs (optional)
21 #       [list of dir names] List of additional include dirs. Note that the
22 #       source root and the root generated file dir is always added, just like
23 #       our C++ build sets up.
25 #       Example: include_dirs = [ "//some/other/path", target_gen_dir ]
27 #   defines (optional)
28 #       [list of strings] List of defines, as with the native code defines.
30 #       Example: defines = [ "FOO", "BAR=1" ]
32 #   inputs, deps, visibility  (optional)
33 #       These have the same meaning as in an action.
35 # Example
37 #   yasm_assemble("my_yasm_target") {
38 #     sources = [
39 #       "ultra_optimized_awesome.asm",
40 #     ]
41 #     include_dirs = [ "assembly_include" ]
42 #   }
44 if (is_mac || is_ios) {
45   if (current_cpu == "x86") {
46     _yasm_flags = [
47       "-fmacho32",
48       "-m",
49       "x86",
50     ]
51   } else if (current_cpu == "x64") {
52     _yasm_flags = [
53       "-fmacho64",
54       "-m",
55       "amd64",
56     ]
57   }
58 } else if (is_posix) {
59   if (current_cpu == "x86") {
60     _yasm_flags = [
61       "-felf32",
62       "-m",
63       "x86",
64     ]
65   } else if (current_cpu == "x64") {
66     _yasm_flags = [
67       "-DPIC",
68       "-felf64",
69       "-m",
70       "amd64",
71     ]
72   }
73 } else if (is_win) {
74   if (current_cpu == "x86") {
75     _yasm_flags = [
76       "-DPREFIX",
77       "-fwin32",
78       "-m",
79       "x86",
80     ]
81   } else if (current_cpu == "x64") {
82     _yasm_flags = [
83       "-fwin64",
84       "-m",
85       "amd64",
86     ]
87   }
90 if (is_win) {
91   asm_obj_extension = "obj"
92 } else {
93   asm_obj_extension = "o"
96 template("yasm_assemble") {
97   # TODO(ajwong): Support use_system_yasm.
98   assert(defined(invoker.sources), "Need sources defined for $target_name")
100   # Only depend on YASM on x86 systems. Force compilation of .asm files for
101   # ARM to fail.
102   assert(current_cpu == "x86" || current_cpu == "x64")
104   action_name = "${target_name}_action"
105   source_set_name = target_name
107   action_foreach(action_name) {
108     # Only the source set can depend on this.
109     visibility = [ ":$source_set_name" ]
111     script = "//third_party/yasm/run_yasm.py"
112     sources = invoker.sources
114     if (defined(invoker.inputs)) {
115       inputs = invoker.inputs
116     }
118     # Executable (first in the args). The binary might be in the root build dir
119     # (no cross-compiling) or in a toolchain-specific subdirectory of that
120     # (when cross-compiling).
121     yasm_label = "//third_party/yasm($host_toolchain)"
122     args = [ "./" +  # Force current dir.
123              rebase_path(get_label_info(yasm_label, "root_out_dir") + "/yasm",
124                          root_build_dir) ]
126     # Deps.
127     deps = [
128       yasm_label,
129     ]
130     if (defined(invoker.deps)) {
131       deps += invoker.deps
132     }
134     # Flags.
135     args += _yasm_flags
136     if (defined(invoker.yasm_flags)) {
137       args += invoker.yasm_flags
138     }
140     # User defined include dirs go first.
141     if (defined(invoker.include_dirs)) {
142       foreach(include, invoker.include_dirs) {
143         args += [ "-I" + rebase_path(include, root_build_dir) ]
144       }
145     }
147     # Default yasm include dirs. Make it match the native build (source root and
148     # root generated code directory).
149     # This goes to the end of include list.
150     args += [
151       "-I.",
153       # Using "//." will produce a relative path "../.." which looks better than
154       # "../../" which will result from using "//" as the base (although both
155       # work). This is because rebase_path will terminate the result in a
156       # slash if the input ends in a slash.
157       "-I" + rebase_path("//.", root_build_dir),
158       "-I" + rebase_path(root_gen_dir, root_build_dir),
159     ]
161     # Extra defines.
162     if (defined(invoker.defines)) {
163       foreach(def, invoker.defines) {
164         args += [ "-D$def" ]
165       }
166     }
168     # Output file.
169     #
170     # TODO(brettw) it might be nice if there was a source expansion for the
171     # path of the source file relative to the source root. Then we could
172     # exactly duplicate the naming and location of object files from the
173     # native build, which would be:
174     # "$root_out_dir/${target_name}.{{source_dir_part}}.$asm_obj_extension"
175     outputs = [
176       "$target_out_dir/{{source_name_part}}.o",
177     ]
178     args += [
179       "-o",
180       rebase_path(outputs[0], root_build_dir),
181       "{{source}}",
182     ]
184     # The wrapper script run_yasm will write the depfile to the same name as
185     # the output but with .d appended (like gcc will).
186     depfile = outputs[0] + ".d"
187   }
189   # Gather the .o files into a linkable thing. This doesn't actually link
190   # anything (a source set just compiles files to link later), but will pass
191   # the object files generated by the action up the dependency chain.
192   source_set(source_set_name) {
193     if (defined(invoker.visibility)) {
194       visibility = invoker.visibility
195     }
197     sources = get_target_outputs(":$action_name")
199     deps = [
200       ":$action_name",
201     ]
202   }