tree-optimization/115537 - ICE with SLP condition reduction vectorization
[official-gcc.git] / gcc / config / aarch64 / t-aarch64
blobc2a0715e9ab47da10fa1b046a211047b4fd8febd
1 # Machine description for AArch64 architecture.
2 #  Copyright (C) 2009-2024 Free Software Foundation, Inc.
3 #  Contributed by ARM Ltd.
5 #  This file is part of GCC.
7 #  GCC is free software; you can redistribute it and/or modify it
8 #  under the terms of the GNU General Public License as published by
9 #  the Free Software Foundation; either version 3, or (at your option)
10 #  any later version.
12 #  GCC is distributed in the hope that it will be useful, but
13 #  WITHOUT ANY WARRANTY; without even the implied warranty of
14 #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15 #  General Public License for more details.
17 #  You should have received a copy of the GNU General Public License
18 #  along with GCC; see the file COPYING3.  If not see
19 #  <http://www.gnu.org/licenses/>.
21 TM_H += $(srcdir)/config/aarch64/aarch64-fusion-pairs.def \
22         $(srcdir)/config/aarch64/aarch64-tuning-flags.def \
23         $(srcdir)/config/aarch64/aarch64-option-extensions.def \
24         $(srcdir)/config/aarch64/aarch64-cores.def \
25         $(srcdir)/config/aarch64/aarch64-isa-modes.def \
26         $(srcdir)/config/aarch64/aarch64-arches.def
27 OPTIONS_H_EXTRA += $(srcdir)/config/aarch64/aarch64-cores.def \
28                    $(srcdir)/config/aarch64/aarch64-arches.def
30 $(srcdir)/config/aarch64/aarch64-tune.md: s-aarch64-tune-md; @true
31 s-aarch64-tune-md: $(srcdir)/config/aarch64/gentune.sh \
32         $(srcdir)/config/aarch64/aarch64-cores.def
33         $(SHELL) $(srcdir)/config/aarch64/gentune.sh \
34                 $(srcdir)/config/aarch64/aarch64-cores.def > \
35                 tmp-aarch64-tune.md
36 ifneq ($(strip $(ENABLE_MAINTAINER_RULES)),)
37         $(SHELL) $(srcdir)/../move-if-change tmp-aarch64-tune.md \
38                 $(srcdir)/config/aarch64/aarch64-tune.md
39 else
40         @if ! cmp -s tmp-aarch64-tune.md \
41           $(srcdir)/config/aarch64/aarch64-tune.md; then \
42           echo "aarch64-tune.md has changed; either"; \
43           echo "configure with --enable-maintainer-mode"; \
44           echo "or copy tmp-aarch64-tune.md to $(srcdir)/config/aarch64/aarch64-tune.md"; \
45           exit 1; \
46         fi
47 endif
48         $(STAMP) s-aarch64-tune-md
50 s-mddeps: s-aarch64-tune-md
52 aarch64-builtins.o: $(srcdir)/config/aarch64/aarch64-builtins.cc $(CONFIG_H) \
53   $(SYSTEM_H) coretypes.h $(TM_H) \
54   $(RTL_H) $(TREE_H) expr.h $(TM_P_H) $(RECOG_H) langhooks.h \
55   $(DIAGNOSTIC_CORE_H) $(OPTABS_H) \
56   $(srcdir)/config/aarch64/aarch64-simd-builtins.def \
57   $(srcdir)/config/aarch64/aarch64-simd-builtin-types.def \
58   aarch64-builtin-iterators.h
59         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
60                 $(srcdir)/config/aarch64/aarch64-builtins.cc
62 aarch64-sve-builtins.o: $(srcdir)/config/aarch64/aarch64-sve-builtins.cc \
63   $(srcdir)/config/aarch64/aarch64-sve-builtins.def \
64   $(srcdir)/config/aarch64/aarch64-sve-builtins-base.def \
65   $(srcdir)/config/aarch64/aarch64-sve-builtins-sve2.def \
66   $(srcdir)/config/aarch64/aarch64-sve-builtins-sme.def \
67   $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
68   $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) $(RECOG_H) $(DIAGNOSTIC_H) \
69   $(EXPR_H) $(BASIC_BLOCK_H) $(FUNCTION_H) fold-const.h $(GIMPLE_H) \
70   gimple-iterator.h gimplify.h explow.h $(EMIT_RTL_H) tree-vector-builder.h \
71   stor-layout.h $(REG_H) alias.h gimple-fold.h langhooks.h \
72   stringpool.h \
73   $(srcdir)/config/aarch64/aarch64-sve-builtins.h \
74   $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.h \
75   $(srcdir)/config/aarch64/aarch64-sve-builtins-base.h \
76   $(srcdir)/config/aarch64/aarch64-sve-builtins-sve2.h \
77   $(srcdir)/config/aarch64/aarch64-sve-builtins-sme.h
78         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
79                 $(srcdir)/config/aarch64/aarch64-sve-builtins.cc
81 aarch64-sve-builtins-shapes.o: \
82   $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.cc \
83   $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
84   $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) \
85   $(srcdir)/config/aarch64/aarch64-sve-builtins.h \
86   $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.h
87         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
88                 $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.cc
90 aarch64-sve-builtins-base.o: \
91   $(srcdir)/config/aarch64/aarch64-sve-builtins-base.cc \
92   $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
93   $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) $(RECOG_H) \
94   $(EXPR_H) $(BASIC_BLOCK_H) $(FUNCTION_H) fold-const.h $(GIMPLE_H) \
95   gimple-iterator.h gimplify.h explow.h $(EMIT_RTL_H) tree-vector-builder.h \
96   rtx-vector-builder.h vec-perm-indices.h \
97   $(srcdir)/config/aarch64/aarch64-sve-builtins.h \
98   $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.h \
99   $(srcdir)/config/aarch64/aarch64-sve-builtins-base.h \
100   $(srcdir)/config/aarch64/aarch64-sve-builtins-functions.h
101         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
102                 $(srcdir)/config/aarch64/aarch64-sve-builtins-base.cc
104 aarch64-sve-builtins-sve2.o: \
105   $(srcdir)/config/aarch64/aarch64-sve-builtins-sve2.cc \
106   $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
107   $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) $(RECOG_H) \
108   $(EXPR_H) $(BASIC_BLOCK_H) $(FUNCTION_H) fold-const.h $(GIMPLE_H) \
109   gimple-iterator.h gimplify.h explow.h $(EMIT_RTL_H) tree-vector-builder.h \
110   rtx-vector-builder.h vec-perm-indices.h \
111   $(srcdir)/config/aarch64/aarch64-sve-builtins.h \
112   $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.h \
113   $(srcdir)/config/aarch64/aarch64-sve-builtins-sve2.h \
114   $(srcdir)/config/aarch64/aarch64-sve-builtins-functions.h
115         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
116                 $(srcdir)/config/aarch64/aarch64-sve-builtins-sve2.cc
118 aarch64-sve-builtins-sme.o: \
119   $(srcdir)/config/aarch64/aarch64-sve-builtins-sme.cc \
120   $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
121   $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) $(RECOG_H) \
122   $(EXPR_H) $(BASIC_BLOCK_H) $(FUNCTION_H) fold-const.h $(GIMPLE_H) \
123   gimple-iterator.h gimplify.h explow.h $(EMIT_RTL_H) \
124   $(srcdir)/config/aarch64/aarch64-sve-builtins.h \
125   $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.h \
126   $(srcdir)/config/aarch64/aarch64-sve-builtins-sme.h \
127   $(srcdir)/config/aarch64/aarch64-sve-builtins-functions.h
128         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
129                 $(srcdir)/config/aarch64/aarch64-sve-builtins-sme.cc
131 aarch64-builtin-iterators.h: $(srcdir)/config/aarch64/geniterators.sh \
132         $(srcdir)/config/aarch64/iterators.md
133         $(SHELL) $(srcdir)/config/aarch64/geniterators.sh \
134                 $(srcdir)/config/aarch64/iterators.md > \
135                 aarch64-builtin-iterators.h
137 aarch-common.o: $(srcdir)/config/arm/aarch-common.cc $(CONFIG_H) $(SYSTEM_H) \
138     coretypes.h $(TM_H) $(TM_P_H) $(RTL_H) $(TREE_H) output.h $(C_COMMON_H)
139         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
140                 $(srcdir)/config/arm/aarch-common.cc
142 aarch64-c.o: $(srcdir)/config/aarch64/aarch64-c.cc $(CONFIG_H) $(SYSTEM_H) \
143     coretypes.h $(TM_H) $(TREE_H) output.h $(C_COMMON_H) $(TARGET_H)
144         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
145                 $(srcdir)/config/aarch64/aarch64-c.cc
147 aarch64-d.o: $(srcdir)/config/aarch64/aarch64-d.cc
148         $(COMPILE) $<
149         $(POSTCOMPILE)
151 PASSES_EXTRA += $(srcdir)/config/aarch64/aarch64-passes.def
153 cortex-a57-fma-steering.o: $(srcdir)/config/aarch64/cortex-a57-fma-steering.cc \
154     $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
155     dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
156     output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
157     $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
158     $(srcdir)/config/aarch64/aarch64-protos.h
159         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
160                 $(srcdir)/config/aarch64/cortex-a57-fma-steering.cc
162 aarch64-speculation.o: $(srcdir)/config/aarch64/aarch64-speculation.cc \
163     $(CONFIG_H) \
164     $(SYSTEM_H) \
165     $(TM_H) \
166     $(TARGET_H) \
167     $(RTL_BASE_H) \
168     $(TREE_PASS_H)
169         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_SPPFLAGS) $(INCLUDES) \
170           $(srcdir)/config/aarch64/aarch64-speculation.cc
172 falkor-tag-collision-avoidance.o: \
173     $(srcdir)/config/aarch64/falkor-tag-collision-avoidance.cc \
174     $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
175     dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
176     output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
177     $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
178     $(srcdir)/config/aarch64/aarch64-protos.h
179         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
180                 $(srcdir)/config/aarch64/falkor-tag-collision-avoidance.cc
182 aarch-bti-insert.o: $(srcdir)/config/arm/aarch-bti-insert.cc \
183     $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
184     dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
185     output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
186     $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
187     $(srcdir)/config/aarch64/aarch64-protos.h
188         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
189                 $(srcdir)/config/arm/aarch-bti-insert.cc
191 aarch64-cc-fusion.o: $(srcdir)/config/aarch64/aarch64-cc-fusion.cc \
192     $(CONFIG_H) $(SYSTEM_H) $(CORETYPES_H) $(BACKEND_H) $(RTL_H) $(DF_H) \
193     $(RTL_SSA_H) tree-pass.h
194         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
195                 $(srcdir)/config/aarch64/aarch64-cc-fusion.cc
197 aarch64-early-ra.o: $(srcdir)/config/aarch64/aarch64-early-ra.cc \
198     $(CONFIG_H) $(SYSTEM_H) $(CORETYPES_H) $(BACKEND_H) $(RTL_H) $(DF_H) \
199     $(RTL_SSA_H) tree-pass.h
200         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
201                 $(srcdir)/config/aarch64/aarch64-early-ra.cc
203 aarch64-ldp-fusion.o: $(srcdir)/config/aarch64/aarch64-ldp-fusion.cc \
204     $(CONFIG_H) $(SYSTEM_H) $(CORETYPES_H) $(BACKEND_H) $(RTL_H) \
205     tree-pass.h pair-fusion.h
206         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
207                 $(srcdir)/config/aarch64/aarch64-ldp-fusion.cc
209 comma=,
210 MULTILIB_OPTIONS    = $(subst $(comma),/, $(patsubst %, mabi=%, $(subst $(comma),$(comma)mabi=,$(TM_MULTILIB_CONFIG))))
211 MULTILIB_DIRNAMES   = $(subst $(comma), ,$(TM_MULTILIB_CONFIG))
213 insn-conditions.md: s-check-sve-md
214 s-check-sve-md: $(srcdir)/config/aarch64/check-sve-md.awk \
215                 $(srcdir)/config/aarch64/aarch64-sve.md \
216                 $(srcdir)/config/aarch64/aarch64-sve2.md \
217                 $(srcdir)/config/aarch64/aarch64-sme.md
218         $(AWK) -f $(srcdir)/config/aarch64/check-sve-md.awk \
219           $(srcdir)/config/aarch64/aarch64-sve.md
220         $(AWK) -f $(srcdir)/config/aarch64/check-sve-md.awk \
221           $(srcdir)/config/aarch64/aarch64-sve2.md
222         $(AWK) -f $(srcdir)/config/aarch64/check-sve-md.awk \
223           $(srcdir)/config/aarch64/aarch64-sme.md
224         $(STAMP) s-check-sve-md