OLD | NEW |
| (Empty) |
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. | |
4 | |
5 # This provides the yasm_assemble() template which uses YASM to assemble | |
6 # assembly files. | |
7 # | |
8 # Files to be assembled with YASM should have an extension of .asm. | |
9 # | |
10 # Parameters | |
11 # | |
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). | |
17 # | |
18 # Example: yasm_flags = [ "--force-strict" ] | |
19 # | |
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. | |
24 # | |
25 # Example: include_dirs = [ "//some/other/path", target_gen_dir ] | |
26 # | |
27 # defines (optional) | |
28 # [list of strings] List of defines, as with the native code defines. | |
29 # | |
30 # Example: defines = [ "FOO", "BAR=1" ] | |
31 # | |
32 # inputs, deps, visibility (optional) | |
33 # These have the same meaning as in an action. | |
34 # | |
35 # Example | |
36 # | |
37 # yasm_assemble("my_yasm_target") { | |
38 # sources = [ | |
39 # "ultra_optimized_awesome.asm", | |
40 # ] | |
41 # include_dirs = [ "assembly_include" ] | |
42 # } | |
43 | |
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 } | |
88 } | |
89 | |
90 if (is_win) { | |
91 asm_obj_extension = "obj" | |
92 } else { | |
93 asm_obj_extension = "o" | |
94 } | |
95 | |
96 template("yasm_assemble") { | |
97 # TODO(ajwong): Support use_system_yasm. | |
98 assert(defined(invoker.sources), "Need sources defined for $target_name") | |
99 | |
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") | |
103 | |
104 action_name = "${target_name}_action" | |
105 source_set_name = target_name | |
106 | |
107 action_foreach(action_name) { | |
108 # Only the source set can depend on this. | |
109 visibility = [ ":$source_set_name" ] | |
110 | |
111 script = "//third_party/yasm/run_yasm.py" | |
112 sources = invoker.sources | |
113 | |
114 if (defined(invoker.inputs)) { | |
115 inputs = invoker.inputs | |
116 } | |
117 | |
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) ] | |
125 | |
126 # Deps. | |
127 deps = [ | |
128 yasm_label, | |
129 ] | |
130 if (defined(invoker.deps)) { | |
131 deps += invoker.deps | |
132 } | |
133 | |
134 # Flags. | |
135 args += _yasm_flags | |
136 if (defined(invoker.yasm_flags)) { | |
137 args += invoker.yasm_flags | |
138 } | |
139 | |
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 } | |
146 | |
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.", | |
152 | |
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 ] | |
160 | |
161 # Extra defines. | |
162 if (defined(invoker.defines)) { | |
163 foreach(def, invoker.defines) { | |
164 args += [ "-D$def" ] | |
165 } | |
166 } | |
167 | |
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 ] | |
183 | |
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 } | |
188 | |
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 } | |
196 | |
197 sources = get_target_outputs(":$action_name") | |
198 | |
199 deps = [ | |
200 ":$action_name", | |
201 ] | |
202 } | |
203 } | |
OLD | NEW |