1 LOCAL_PATH := $(call my-dir)
2 SPVTOOLS_OUT_PATH=$(if $(call host-path-is-absolute,$(TARGET_OUT)),$(TARGET_OUT),$(abspath $(TARGET_OUT)))
3 SPVHEADERS_LOCAL_PATH := $(LOCAL_PATH)/external/spirv-headers
5 SPVTOOLS_SRC_FILES := \
6 source/assembly_grammar.cpp \
8 source/diagnostic.cpp \
9 source/disassemble.cpp \
11 source/enum_string_mapping.cpp \
12 source/extensions.cpp \
13 source/id_descriptor.cpp \
15 source/name_mapper.cpp \
18 source/parsed_operand.cpp \
20 source/software_version.cpp \
21 source/spirv_endian.cpp \
22 source/spirv_target_env.cpp \
23 source/spirv_validator_options.cpp \
26 source/text_handler.cpp \
27 source/util/bit_stream.cpp \
28 source/util/parse_number.cpp \
29 source/util/string_utils.cpp \
30 source/val/basic_block.cpp \
31 source/val/construct.cpp \
32 source/val/function.cpp \
33 source/val/instruction.cpp \
34 source/val/validation_state.cpp \
36 source/validate_adjacency.cpp \
37 source/validate_arithmetics.cpp \
38 source/validate_atomics.cpp \
39 source/validate_barriers.cpp \
40 source/validate_bitwise.cpp \
41 source/validate_capability.cpp \
42 source/validate_cfg.cpp \
43 source/validate_composites.cpp \
44 source/validate_conversion.cpp \
45 source/validate_datarules.cpp \
46 source/validate_decorations.cpp \
47 source/validate_derivatives.cpp \
48 source/validate_ext_inst.cpp \
49 source/validate_id.cpp \
50 source/validate_image.cpp \
51 source/validate_instruction.cpp \
52 source/validate_layout.cpp \
53 source/validate_literals.cpp \
54 source/validate_logicals.cpp \
55 source/validate_primitives.cpp \
56 source/validate_type_unique.cpp
58 SPVTOOLS_OPT_SRC_FILES := \
59 source/opt/aggressive_dead_code_elim_pass.cpp \
60 source/opt/basic_block.cpp \
61 source/opt/block_merge_pass.cpp \
62 source/opt/build_module.cpp \
64 source/opt/cfg_cleanup_pass.cpp \
65 source/opt/ccp_pass.cpp \
66 source/opt/common_uniform_elim_pass.cpp \
67 source/opt/compact_ids_pass.cpp \
68 source/opt/composite.cpp \
69 source/opt/const_folding_rules.cpp \
70 source/opt/constants.cpp \
71 source/opt/dead_branch_elim_pass.cpp \
72 source/opt/dead_insert_elim_pass.cpp \
73 source/opt/dead_variable_elimination.cpp \
74 source/opt/decoration_manager.cpp \
75 source/opt/def_use_manager.cpp \
76 source/opt/dominator_analysis.cpp \
77 source/opt/dominator_tree.cpp \
78 source/opt/eliminate_dead_constant_pass.cpp \
79 source/opt/eliminate_dead_functions_pass.cpp \
80 source/opt/feature_manager.cpp \
81 source/opt/flatten_decoration_pass.cpp \
83 source/opt/folding_rules.cpp \
84 source/opt/fold_spec_constant_op_and_composite_pass.cpp \
85 source/opt/freeze_spec_constant_value_pass.cpp \
86 source/opt/function.cpp \
87 source/opt/if_conversion.cpp \
88 source/opt/inline_pass.cpp \
89 source/opt/inline_exhaustive_pass.cpp \
90 source/opt/inline_opaque_pass.cpp \
91 source/opt/insert_extract_elim.cpp \
92 source/opt/instruction.cpp \
93 source/opt/instruction_list.cpp \
94 source/opt/ir_context.cpp \
95 source/opt/ir_loader.cpp \
96 source/opt/licm_pass.cpp \
97 source/opt/local_access_chain_convert_pass.cpp \
98 source/opt/local_redundancy_elimination.cpp \
99 source/opt/local_single_block_elim_pass.cpp \
100 source/opt/local_single_store_elim_pass.cpp \
101 source/opt/local_ssa_elim_pass.cpp \
102 source/opt/loop_descriptor.cpp \
103 source/opt/loop_unroller.cpp \
104 source/opt/loop_unswitch_pass.cpp \
105 source/opt/loop_utils.cpp \
106 source/opt/mem_pass.cpp \
107 source/opt/merge_return_pass.cpp \
108 source/opt/module.cpp \
109 source/opt/optimizer.cpp \
110 source/opt/pass.cpp \
111 source/opt/pass_manager.cpp \
112 source/opt/private_to_local_pass.cpp \
113 source/opt/propagator.cpp \
114 source/opt/redundancy_elimination.cpp \
115 source/opt/remove_duplicates_pass.cpp \
116 source/opt/replace_invalid_opc.cpp \
117 source/opt/scalar_replacement_pass.cpp \
118 source/opt/set_spec_constant_default_value_pass.cpp \
119 source/opt/simplification_pass.cpp \
120 source/opt/strength_reduction_pass.cpp \
121 source/opt/strip_debug_info_pass.cpp \
122 source/opt/type_manager.cpp \
123 source/opt/types.cpp \
124 source/opt/unify_const_pass.cpp \
125 source/opt/value_number_table.cpp \
126 source/opt/workaround1209.cpp
128 # Locations of grammar files.
130 # TODO(dneto): Build a single set of tables that embeds versioning differences on
131 # a per-item basis. That must happen before SPIR-V 1.4, etc.
132 # https://github.com/KhronosGroup/SPIRV-Tools/issues/1195
133 SPV_CORE10_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.0/spirv.core.grammar.json
134 SPV_CORE11_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.1/spirv.core.grammar.json
135 SPV_CORE12_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.2/spirv.core.grammar.json
136 SPV_COREUNIFIED1_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/unified1/spirv.core.grammar.json
137 SPV_CORELATEST_GRAMMAR=$(SPV_COREUNIFIED1_GRAMMAR)
138 SPV_GLSL_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.2/extinst.glsl.std.450.grammar.json
139 SPV_OPENCL_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.2/extinst.opencl.std.100.grammar.json
140 # TODO(dneto): I expect the DebugInfo grammar file to eventually migrate to SPIRV-Headers
141 SPV_DEBUGINFO_GRAMMAR=$(LOCAL_PATH)/source/extinst.debuginfo.grammar.json
143 define gen_spvtools_grammar_tables
144 $(call generate-file-dir,$(1)/core.insts-1.0.inc)
145 $(1)/core.insts-1.0.inc $(1)/operand.kinds-1.0.inc $(1)/glsl.std.450.insts.inc $(1)/opencl.std.insts.inc: \
146 $(LOCAL_PATH)/utils/generate_grammar_tables.py \
147 $(SPV_CORE10_GRAMMAR) \
148 $(SPV_GLSL_GRAMMAR) \
149 $(SPV_OPENCL_GRAMMAR) \
150 $(SPV_DEBUGINFO_GRAMMAR)
151 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
152 --spirv-core-grammar=$(SPV_CORE10_GRAMMAR) \
153 --extinst-glsl-grammar=$(SPV_GLSL_GRAMMAR) \
154 --extinst-opencl-grammar=$(SPV_OPENCL_GRAMMAR) \
155 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
156 --core-insts-output=$(1)/core.insts-1.0.inc \
157 --glsl-insts-output=$(1)/glsl.std.450.insts.inc \
158 --opencl-insts-output=$(1)/opencl.std.insts.inc \
159 --operand-kinds-output=$(1)/operand.kinds-1.0.inc
160 @echo "[$(TARGET_ARCH_ABI)] Grammar v1.0 : instructions & operands <= grammar JSON files"
161 $(1)/core.insts-1.1.inc $(1)/operand.kinds-1.1.inc: \
162 $(LOCAL_PATH)/utils/generate_grammar_tables.py \
163 $(SPV_CORE11_GRAMMAR) \
164 $(SPV_DEBUGINFO_GRAMMAR)
165 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
166 --spirv-core-grammar=$(SPV_CORE11_GRAMMAR) \
167 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
168 --core-insts-output=$(1)/core.insts-1.1.inc \
169 --operand-kinds-output=$(1)/operand.kinds-1.1.inc
170 @echo "[$(TARGET_ARCH_ABI)] Grammar v1.1 : instructions & operands <= grammar JSON files"
171 $(1)/core.insts-1.2.inc $(1)/operand.kinds-1.2.inc: \
172 $(LOCAL_PATH)/utils/generate_grammar_tables.py \
173 $(SPV_CORE12_GRAMMAR) \
174 $(SPV_DEBUGINFO_GRAMMAR)
175 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
176 --spirv-core-grammar=$(SPV_CORE12_GRAMMAR) \
177 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
178 --core-insts-output=$(1)/core.insts-1.2.inc \
179 --operand-kinds-output=$(1)/operand.kinds-1.2.inc
180 @echo "[$(TARGET_ARCH_ABI)] Grammar v1.2 : instructions & operands <= grammar JSON files"
181 $(1)/core.insts-unified1.inc $(1)/operand.kinds-unified1.inc: \
182 $(LOCAL_PATH)/utils/generate_grammar_tables.py \
183 $(SPV_COREUNIFIED1_GRAMMAR) \
184 $(SPV_DEBUGINFO_GRAMMAR)
185 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
186 --spirv-core-grammar=$(SPV_COREUNIFIED1_GRAMMAR) \
187 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
188 --core-insts-output=$(1)/core.insts-unified1.inc \
189 --operand-kinds-output=$(1)/operand.kinds-unified1.inc
190 @echo "[$(TARGET_ARCH_ABI)] Grammar v1.3 (from unified1) : instructions & operands <= grammar JSON files"
191 $(LOCAL_PATH)/source/opcode.cpp: $(1)/core.insts-1.0.inc $(1)/core.insts-1.1.inc $(1)/core.insts-1.2.inc $(1)/core.insts-unified1.inc
192 $(LOCAL_PATH)/source/operand.cpp: $(1)/operand.kinds-1.0.inc $(1)/operand.kinds-1.1.inc $(1)/operand.kinds-1.2.inc $(1)/operand.kinds-unified1.inc
193 $(LOCAL_PATH)/source/ext_inst.cpp: \
194 $(1)/glsl.std.450.insts.inc \
195 $(1)/opencl.std.insts.inc \
196 $(1)/debuginfo.insts.inc \
197 $(1)/spv-amd-gcn-shader.insts.inc \
198 $(1)/spv-amd-shader-ballot.insts.inc \
199 $(1)/spv-amd-shader-explicit-vertex-parameter.insts.inc \
200 $(1)/spv-amd-shader-trinary-minmax.insts.inc
202 $(eval $(call gen_spvtools_grammar_tables,$(SPVTOOLS_OUT_PATH)))
205 define gen_spvtools_lang_headers
206 # Generate language-specific headers. So far we only generate C headers
207 # $1 is the output directory.
208 # $2 is the base name of the header file, e.g. "DebugInfo".
209 # $3 is the grammar file containing token definitions.
210 $(call generate-file-dir,$(1)/$(2).h)
212 $(LOCAL_PATH)/utils/generate_language_headers.py \
214 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_language_headers.py \
215 --extinst-name=$(2) \
216 --extinst-grammar=$(3) \
217 --extinst-output-base=$(1)/$(2)
218 @echo "[$(TARGET_ARCH_ABI)] Generate language specific header for $(2): headers <= grammar"
219 $(LOCAL_PATH)/source/ext_inst.cpp: $(1)/$(2).h
221 # We generate language-specific headers for DebugInfo
222 $(eval $(call gen_spvtools_lang_headers,$(SPVTOOLS_OUT_PATH),DebugInfo,$(SPV_DEBUGINFO_GRAMMAR)))
225 define gen_spvtools_vendor_tables
226 $(call generate-file-dir,$(1)/$(2).insts.inc)
227 $(1)/$(2).insts.inc : \
228 $(LOCAL_PATH)/utils/generate_grammar_tables.py \
229 $(LOCAL_PATH)/source/extinst.$(2).grammar.json
230 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
231 --extinst-vendor-grammar=$(LOCAL_PATH)/source/extinst.$(2).grammar.json \
232 --vendor-insts-output=$(1)/$(2).insts.inc
233 @echo "[$(TARGET_ARCH_ABI)] Vendor extended instruction set: $(2) tables <= grammar"
234 $(LOCAL_PATH)/source/ext_inst.cpp: $(1)/$(2).insts.inc
236 # Vendor extended instruction sets, with grammars from SPIRV-Tools source tree.
237 SPV_NONSTANDARD_EXTINST_GRAMMARS=$(foreach F,$(wildcard $(LOCAL_PATH)/source/extinst.*.grammar.json),$(patsubst extinst.%.grammar.json,%,$(notdir $F)))
238 $(foreach E,$(SPV_NONSTANDARD_EXTINST_GRAMMARS),$(eval $(call gen_spvtools_vendor_tables,$(SPVTOOLS_OUT_PATH),$E)))
240 define gen_spvtools_enum_string_mapping
241 $(call generate-file-dir,$(1)/extension_enum.inc.inc)
242 $(1)/extension_enum.inc $(1)/enum_string_mapping.inc: \
243 $(LOCAL_PATH)/utils/generate_grammar_tables.py \
244 $(SPV_CORELATEST_GRAMMAR)
245 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
246 --spirv-core-grammar=$(SPV_CORELATEST_GRAMMAR) \
247 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
248 --extension-enum-output=$(1)/extension_enum.inc \
249 --enum-string-mapping-output=$(1)/enum_string_mapping.inc
250 @echo "[$(TARGET_ARCH_ABI)] Generate enum<->string mapping <= grammar JSON files"
251 # Generated header extension_enum.inc is transitively included by table.h, which is
252 # used pervasively. Capture the pervasive dependency.
253 $(foreach F,$(SPVTOOLS_SRC_FILES) $(SPVTOOLS_OPT_SRC_FILES),$(LOCAL_PATH)/$F ) \
254 : $(1)/extension_enum.inc
255 $(LOCAL_PATH)/source/enum_string_mapping.cpp: $(1)/enum_string_mapping.inc
257 $(eval $(call gen_spvtools_enum_string_mapping,$(SPVTOOLS_OUT_PATH)))
259 define gen_spvtools_build_version_inc
260 $(call generate-file-dir,$(1)/dummy_filename)
261 $(1)/build-version.inc: \
262 $(LOCAL_PATH)/utils/update_build_version.py \
263 $(LOCAL_PATH)/CHANGES
264 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/update_build_version.py \
265 $(LOCAL_PATH) $(1)/build-version.inc
266 @echo "[$(TARGET_ARCH_ABI)] Generate : build-version.inc <= CHANGES"
267 $(LOCAL_PATH)/source/software_version.cpp: $(1)/build-version.inc
269 $(eval $(call gen_spvtools_build_version_inc,$(SPVTOOLS_OUT_PATH)))
271 define gen_spvtools_generators_inc
272 $(call generate-file-dir,$(1)/dummy_filename)
273 $(1)/generators.inc: \
274 $(LOCAL_PATH)/utils/generate_registry_tables.py \
275 $(SPVHEADERS_LOCAL_PATH)/include/spirv/spir-v.xml
276 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_registry_tables.py \
277 --xml=$(SPVHEADERS_LOCAL_PATH)/include/spirv/spir-v.xml \
278 --generator-output=$(1)/generators.inc
279 @echo "[$(TARGET_ARCH_ABI)] Generate : generators.inc <= spir-v.xml"
280 $(LOCAL_PATH)/source/opcode.cpp: $(1)/generators.inc
282 $(eval $(call gen_spvtools_generators_inc,$(SPVTOOLS_OUT_PATH)))
284 include $(CLEAR_VARS)
285 LOCAL_MODULE := SPIRV-Tools
286 LOCAL_C_INCLUDES := \
287 $(LOCAL_PATH)/include \
288 $(LOCAL_PATH)/source \
289 $(LOCAL_PATH)/external/spirv-headers/include \
291 LOCAL_EXPORT_C_INCLUDES := \
292 $(LOCAL_PATH)/include
293 LOCAL_CXXFLAGS:=-std=c++11 -fno-exceptions -fno-rtti -Werror
294 LOCAL_SRC_FILES:= $(SPVTOOLS_SRC_FILES)
295 include $(BUILD_STATIC_LIBRARY)
297 include $(CLEAR_VARS)
298 LOCAL_MODULE := SPIRV-Tools-opt
299 LOCAL_C_INCLUDES := \
300 $(LOCAL_PATH)/include \
301 $(LOCAL_PATH)/source \
302 $(LOCAL_PATH)/external/spirv-headers/include \
304 LOCAL_CXXFLAGS:=-std=c++11 -fno-exceptions -fno-rtti -Werror
305 LOCAL_STATIC_LIBRARIES:=SPIRV-Tools
306 LOCAL_SRC_FILES:= $(SPVTOOLS_OPT_SRC_FILES)
307 include $(BUILD_STATIC_LIBRARY)