Fixes #1354. Do not merge integer division.
[platform/upstream/SPIRV-Tools.git] / Android.mk
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
4
5 SPVTOOLS_SRC_FILES := \
6                 source/assembly_grammar.cpp \
7                 source/binary.cpp \
8                 source/diagnostic.cpp \
9                 source/disassemble.cpp \
10                 source/ext_inst.cpp \
11                 source/enum_string_mapping.cpp \
12                 source/extensions.cpp \
13                 source/id_descriptor.cpp \
14                 source/libspirv.cpp \
15                 source/name_mapper.cpp \
16                 source/opcode.cpp \
17                 source/operand.cpp \
18                 source/parsed_operand.cpp \
19                 source/print.cpp \
20                 source/software_version.cpp \
21                 source/spirv_endian.cpp \
22                 source/spirv_target_env.cpp \
23                 source/spirv_validator_options.cpp \
24                 source/table.cpp \
25                 source/text.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 \
35                 source/validate.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
57
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 \
63                 source/opt/cfg.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 \
82                 source/opt/fold.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
127
128 # Locations of grammar files.
129 SPV_CORE10_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.0/spirv.core.grammar.json
130 SPV_CORE11_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.1/spirv.core.grammar.json
131 SPV_CORE12_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.2/spirv.core.grammar.json
132 SPV_CORELATEST_GRAMMAR=$(SPV_CORE12_GRAMMAR)
133 SPV_GLSL_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.2/extinst.glsl.std.450.grammar.json
134 SPV_OPENCL_GRAMMAR=$(SPVHEADERS_LOCAL_PATH)/include/spirv/1.2/extinst.opencl.std.100.grammar.json
135 # TODO(dneto): I expect the DebugInfo grammar file to eventually migrate to SPIRV-Headers
136 SPV_DEBUGINFO_GRAMMAR=$(LOCAL_PATH)/source/extinst.debuginfo.grammar.json
137
138 define gen_spvtools_grammar_tables
139 $(call generate-file-dir,$(1)/core.insts-1.0.inc)
140 $(1)/core.insts-1.0.inc $(1)/operand.kinds-1.0.inc $(1)/glsl.std.450.insts.inc $(1)/opencl.std.insts.inc: \
141         $(LOCAL_PATH)/utils/generate_grammar_tables.py \
142         $(SPV_CORE10_GRAMMAR) \
143         $(SPV_GLSL_GRAMMAR) \
144         $(SPV_OPENCL_GRAMMAR) \
145         $(SPV_DEBUGINFO_GRAMMAR)
146                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
147                                 --spirv-core-grammar=$(SPV_CORE10_GRAMMAR) \
148                                 --extinst-glsl-grammar=$(SPV_GLSL_GRAMMAR) \
149                                 --extinst-opencl-grammar=$(SPV_OPENCL_GRAMMAR) \
150                                 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
151                                 --core-insts-output=$(1)/core.insts-1.0.inc \
152                                 --glsl-insts-output=$(1)/glsl.std.450.insts.inc \
153                                 --opencl-insts-output=$(1)/opencl.std.insts.inc \
154                                 --operand-kinds-output=$(1)/operand.kinds-1.0.inc
155                 @echo "[$(TARGET_ARCH_ABI)] Grammar v1.0   : instructions & operands <= grammar JSON files"
156 $(1)/core.insts-1.1.inc $(1)/operand.kinds-1.1.inc: \
157         $(LOCAL_PATH)/utils/generate_grammar_tables.py \
158         $(SPV_CORE11_GRAMMAR) \
159         $(SPV_DEBUGINFO_GRAMMAR)
160                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
161                                 --spirv-core-grammar=$(SPV_CORE11_GRAMMAR) \
162                                 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
163                                 --core-insts-output=$(1)/core.insts-1.1.inc \
164                                 --operand-kinds-output=$(1)/operand.kinds-1.1.inc
165                 @echo "[$(TARGET_ARCH_ABI)] Grammar v1.1   : instructions & operands <= grammar JSON files"
166 $(1)/core.insts-1.2.inc $(1)/operand.kinds-1.2.inc: \
167         $(LOCAL_PATH)/utils/generate_grammar_tables.py \
168         $(SPV_CORE12_GRAMMAR) \
169         $(SPV_DEBUGINFO_GRAMMAR)
170                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
171                                 --spirv-core-grammar=$(SPV_CORE12_GRAMMAR) \
172                                 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
173                                 --core-insts-output=$(1)/core.insts-1.2.inc \
174                                 --operand-kinds-output=$(1)/operand.kinds-1.2.inc
175                 @echo "[$(TARGET_ARCH_ABI)] Grammar v1.2   : instructions & operands <= grammar JSON files"
176 $(LOCAL_PATH)/source/opcode.cpp: $(1)/core.insts-1.0.inc $(1)/core.insts-1.1.inc $(1)/core.insts-1.2.inc
177 $(LOCAL_PATH)/source/operand.cpp: $(1)/operand.kinds-1.0.inc $(1)/operand.kinds-1.1.inc $(1)/operand.kinds-1.2.inc
178 $(LOCAL_PATH)/source/ext_inst.cpp: $(1)/glsl.std.450.insts.inc $(1)/opencl.std.insts.inc
179 endef
180 $(eval $(call gen_spvtools_grammar_tables,$(SPVTOOLS_OUT_PATH)))
181
182
183 define gen_spvtools_lang_headers
184 # Generate language-specific headers.  So far we only generate C headers
185 # $1 is the output directory.
186 # $2 is the base name of the header file, e.g. "DebugInfo".
187 # $3 is the grammar file containing token definitions.
188 $(call generate-file-dir,$(1)/$(2).h)
189 $(1)/$(2).h : \
190         $(LOCAL_PATH)/utils/generate_language_headers.py \
191         $(3)
192                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_language_headers.py \
193                     --extinst-name=$(2) \
194                     --extinst-grammar=$(3) \
195                     --extinst-output-base=$(1)/$(2)
196                 @echo "[$(TARGET_ARCH_ABI)] Generate language specific header for $(2): headers <= grammar"
197 $(LOCAL_PATH)/source/ext_inst.cpp: $(1)/$(2).h
198 endef
199 # We generate language-specific headers for DebugInfo
200 $(eval $(call gen_spvtools_lang_headers,$(SPVTOOLS_OUT_PATH),DebugInfo,$(SPV_DEBUGINFO_GRAMMAR)))
201
202
203 define gen_spvtools_vendor_tables
204 $(call generate-file-dir,$(1)/$(2).insts.inc)
205 $(1)/$(2).insts.inc : \
206         $(LOCAL_PATH)/utils/generate_grammar_tables.py \
207         $(LOCAL_PATH)/source/extinst.$(2).grammar.json
208                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
209                     --extinst-vendor-grammar=$(LOCAL_PATH)/source/extinst.$(2).grammar.json \
210                     --vendor-insts-output=$(1)/$(2).insts.inc
211                 @echo "[$(TARGET_ARCH_ABI)] Vendor extended instruction set: $(2) tables <= grammar"
212 $(LOCAL_PATH)/source/ext_inst.cpp: $(1)/$(2).insts.inc
213 endef
214 # Vendor extended instruction sets, with grammars from SPIRV-Tools source tree.
215 SPV_NONSTANDARD_EXTINST_GRAMMARS=$(foreach F,$(wildcard $(LOCAL_PATH)/source/extinst.*.grammar.json),$(patsubst extinst.%.grammar.json,%,$(notdir $F)))
216 $(foreach E,$(SPV_NONSTANDARD_EXTINST_GRAMMARS),$(eval $(call gen_spvtools_vendor_tables,$(SPVTOOLS_OUT_PATH),$E)))
217
218 define gen_spvtools_enum_string_mapping
219 $(call generate-file-dir,$(1)/extension_enum.inc.inc)
220 $(1)/extension_enum.inc $(1)/enum_string_mapping.inc: \
221         $(LOCAL_PATH)/utils/generate_grammar_tables.py \
222         $(SPV_CORELATEST_GRAMMAR)
223                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_grammar_tables.py \
224                                 --spirv-core-grammar=$(SPV_CORELATEST_GRAMMAR) \
225                                 --extinst-debuginfo-grammar=$(SPV_DEBUGINFO_GRAMMAR) \
226                                 --extension-enum-output=$(1)/extension_enum.inc \
227                                 --enum-string-mapping-output=$(1)/enum_string_mapping.inc
228                 @echo "[$(TARGET_ARCH_ABI)] Generate enum<->string mapping <= grammar JSON files"
229 # Generated header extension_enum.inc is transitively included by table.h, which is
230 # used pervasively.  Capture the pervasive dependency.
231 $(foreach F,$(SPVTOOLS_SRC_FILES) $(SPVTOOLS_OPT_SRC_FILES),$(LOCAL_PATH)/$F ) \
232   : $(1)/extension_enum.inc
233 $(LOCAL_PATH)/source/enum_string_mapping.cpp: $(1)/enum_string_mapping.inc
234 endef
235 $(eval $(call gen_spvtools_enum_string_mapping,$(SPVTOOLS_OUT_PATH)))
236
237 define gen_spvtools_build_version_inc
238 $(call generate-file-dir,$(1)/dummy_filename)
239 $(1)/build-version.inc: \
240         $(LOCAL_PATH)/utils/update_build_version.py \
241         $(LOCAL_PATH)/CHANGES
242                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/update_build_version.py \
243                                 $(LOCAL_PATH) $(1)/build-version.inc
244                 @echo "[$(TARGET_ARCH_ABI)] Generate       : build-version.inc <= CHANGES"
245 $(LOCAL_PATH)/source/software_version.cpp: $(1)/build-version.inc
246 endef
247 $(eval $(call gen_spvtools_build_version_inc,$(SPVTOOLS_OUT_PATH)))
248
249 define gen_spvtools_generators_inc
250 $(call generate-file-dir,$(1)/dummy_filename)
251 $(1)/generators.inc: \
252         $(LOCAL_PATH)/utils/generate_registry_tables.py \
253         $(SPVHEADERS_LOCAL_PATH)/include/spirv/spir-v.xml
254                 @$(HOST_PYTHON) $(LOCAL_PATH)/utils/generate_registry_tables.py \
255                                 --xml=$(SPVHEADERS_LOCAL_PATH)/include/spirv/spir-v.xml \
256                                 --generator-output=$(1)/generators.inc
257                 @echo "[$(TARGET_ARCH_ABI)] Generate       : generators.inc <= spir-v.xml"
258 $(LOCAL_PATH)/source/opcode.cpp: $(1)/generators.inc
259 endef
260 $(eval $(call gen_spvtools_generators_inc,$(SPVTOOLS_OUT_PATH)))
261
262 include $(CLEAR_VARS)
263 LOCAL_MODULE := SPIRV-Tools
264 LOCAL_C_INCLUDES := \
265                 $(LOCAL_PATH)/include \
266                 $(LOCAL_PATH)/source \
267                 $(LOCAL_PATH)/external/spirv-headers/include \
268                 $(SPVTOOLS_OUT_PATH)
269 LOCAL_EXPORT_C_INCLUDES := \
270                 $(LOCAL_PATH)/include
271 LOCAL_CXXFLAGS:=-std=c++11 -fno-exceptions -fno-rtti -Werror
272 LOCAL_SRC_FILES:= $(SPVTOOLS_SRC_FILES)
273 include $(BUILD_STATIC_LIBRARY)
274
275 include $(CLEAR_VARS)
276 LOCAL_MODULE := SPIRV-Tools-opt
277 LOCAL_C_INCLUDES := \
278                 $(LOCAL_PATH)/include \
279                 $(LOCAL_PATH)/source \
280                 $(LOCAL_PATH)/external/spirv-headers/include \
281                 $(SPVTOOLS_OUT_PATH)
282 LOCAL_CXXFLAGS:=-std=c++11 -fno-exceptions -fno-rtti -Werror
283 LOCAL_STATIC_LIBRARIES:=SPIRV-Tools
284 LOCAL_SRC_FILES:= $(SPVTOOLS_OPT_SRC_FILES)
285 include $(BUILD_STATIC_LIBRARY)