]> git.ipfire.org Git - thirdparty/gcc.git/blob - gcc/config/aarch64/t-aarch64
Update copyright years.
[thirdparty/gcc.git] / gcc / config / aarch64 / t-aarch64
1 # Machine description for AArch64 architecture.
2 # Copyright (C) 2009-2020 Free Software Foundation, Inc.
3 # Contributed by ARM Ltd.
4 #
5 # This file is part of GCC.
6 #
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.
11 #
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.
16 #
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/>.
20
21 TM_H += $(srcdir)/config/aarch64/aarch64-cores.def
22 OPTIONS_H_EXTRA += $(srcdir)/config/aarch64/aarch64-cores.def \
23 $(srcdir)/config/aarch64/aarch64-arches.def \
24 $(srcdir)/config/aarch64/aarch64-fusion-pairs.def \
25 $(srcdir)/config/aarch64/aarch64-tuning-flags.def
26
27 $(srcdir)/config/aarch64/aarch64-tune.md: $(srcdir)/config/aarch64/gentune.sh \
28 $(srcdir)/config/aarch64/aarch64-cores.def
29 $(SHELL) $(srcdir)/config/aarch64/gentune.sh \
30 $(srcdir)/config/aarch64/aarch64-cores.def > \
31 $(srcdir)/config/aarch64/aarch64-tune.md
32
33 aarch64-builtins.o: $(srcdir)/config/aarch64/aarch64-builtins.c $(CONFIG_H) \
34 $(SYSTEM_H) coretypes.h $(TM_H) \
35 $(RTL_H) $(TREE_H) expr.h $(TM_P_H) $(RECOG_H) langhooks.h \
36 $(DIAGNOSTIC_CORE_H) $(OPTABS_H) \
37 $(srcdir)/config/aarch64/aarch64-simd-builtins.def \
38 $(srcdir)/config/aarch64/aarch64-simd-builtin-types.def \
39 aarch64-builtin-iterators.h
40 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
41 $(srcdir)/config/aarch64/aarch64-builtins.c
42
43 aarch64-sve-builtins.o: $(srcdir)/config/aarch64/aarch64-sve-builtins.cc \
44 $(srcdir)/config/aarch64/aarch64-sve-builtins.def \
45 $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
46 $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) $(RECOG_H) $(DIAGNOSTIC_H) \
47 $(EXPR_H) $(BASIC_BLOCK_H) $(FUNCTION_H) fold-const.h $(GIMPLE_H) \
48 gimple-iterator.h gimplify.h explow.h $(EMIT_RTL_H) tree-vector-builder.h \
49 stor-layout.h $(REG_H) alias.h gimple-fold.h langhooks.h \
50 stringpool.h \
51 $(srcdir)/config/aarch64/aarch64-sve-builtins.h \
52 $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.h \
53 $(srcdir)/config/aarch64/aarch64-sve-builtins-base.h
54 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
55 $(srcdir)/config/aarch64/aarch64-sve-builtins.cc
56
57 aarch64-sve-builtins-shapes.o: \
58 $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.cc \
59 $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
60 $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) \
61 $(srcdir)/config/aarch64/aarch64-sve-builtins.h \
62 $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.h
63 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
64 $(srcdir)/config/aarch64/aarch64-sve-builtins-shapes.cc
65
66 aarch64-sve-builtins-base.o: \
67 $(srcdir)/config/aarch64/aarch64-sve-builtins-base.cc \
68 $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
69 $(TM_P_H) memmodel.h insn-codes.h $(OPTABS_H) $(RECOG_H) \
70 $(EXPR_H) $(BASIC_BLOCK_H) $(FUNCTION_H) fold-const.h $(GIMPLE_H) \
71 gimple-iterator.h gimplify.h explow.h $(EMIT_RTL_H) tree-vector-builder.h \
72 rtx-vector-builder.h vec-perm-indices.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-functions.h
77 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
78 $(srcdir)/config/aarch64/aarch64-sve-builtins-base.cc
79
80 aarch64-builtin-iterators.h: $(srcdir)/config/aarch64/geniterators.sh \
81 $(srcdir)/config/aarch64/iterators.md
82 $(SHELL) $(srcdir)/config/aarch64/geniterators.sh \
83 $(srcdir)/config/aarch64/iterators.md > \
84 aarch64-builtin-iterators.h
85
86 aarch-common.o: $(srcdir)/config/arm/aarch-common.c $(CONFIG_H) $(SYSTEM_H) \
87 coretypes.h $(TM_H) $(TM_P_H) $(RTL_H) $(TREE_H) output.h $(C_COMMON_H)
88 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
89 $(srcdir)/config/arm/aarch-common.c
90
91 aarch64-c.o: $(srcdir)/config/aarch64/aarch64-c.c $(CONFIG_H) $(SYSTEM_H) \
92 coretypes.h $(TM_H) $(TREE_H) output.h $(C_COMMON_H) $(TARGET_H)
93 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
94 $(srcdir)/config/aarch64/aarch64-c.c
95
96 aarch64-d.o: $(srcdir)/config/aarch64/aarch64-d.c
97 $(COMPILE) $<
98 $(POSTCOMPILE)
99
100 PASSES_EXTRA += $(srcdir)/config/aarch64/aarch64-passes.def
101
102 cortex-a57-fma-steering.o: $(srcdir)/config/aarch64/cortex-a57-fma-steering.c \
103 $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
104 dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
105 output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
106 $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
107 $(srcdir)/config/aarch64/aarch64-protos.h
108 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
109 $(srcdir)/config/aarch64/cortex-a57-fma-steering.c
110
111 aarch64-speculation.o: $(srcdir)/config/aarch64/aarch64-speculation.cc \
112 $(CONFIG_H) \
113 $(SYSTEM_H) \
114 $(TM_H) \
115 $(TARGET_H) \
116 $(RTL_BASE_H) \
117 $(TREE_PASS_H)
118 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_SPPFLAGS) $(INCLUDES) \
119 $(srcdir)/config/aarch64/aarch64-speculation.cc
120
121 falkor-tag-collision-avoidance.o: \
122 $(srcdir)/config/aarch64/falkor-tag-collision-avoidance.c \
123 $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
124 dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
125 output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
126 $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
127 $(srcdir)/config/aarch64/aarch64-protos.h
128 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
129 $(srcdir)/config/aarch64/falkor-tag-collision-avoidance.c
130
131 aarch64-bti-insert.o: $(srcdir)/config/aarch64/aarch64-bti-insert.c \
132 $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
133 dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
134 output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
135 $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
136 $(srcdir)/config/aarch64/aarch64-protos.h
137 $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
138 $(srcdir)/config/aarch64/aarch64-bti-insert.c
139
140 comma=,
141 MULTILIB_OPTIONS = $(subst $(comma),/, $(patsubst %, mabi=%, $(subst $(comma),$(comma)mabi=,$(TM_MULTILIB_CONFIG))))
142 MULTILIB_DIRNAMES = $(subst $(comma), ,$(TM_MULTILIB_CONFIG))
143
144 insn-conditions.md: s-check-sve-md
145 s-check-sve-md: $(srcdir)/config/aarch64/check-sve-md.awk \
146 $(srcdir)/config/aarch64/aarch64-sve.md
147 $(AWK) -f $(srcdir)/config/aarch64/check-sve-md.awk \
148 $(srcdir)/config/aarch64/aarch64-sve.md
149 $(STAMP) s-check-sve-md