1# Machine description for AArch64 architecture.
2#  Copyright (C) 2009-2018 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
21TM_H += $(srcdir)/config/aarch64/aarch64-cores.def
22OPTIONS_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
33aarch64-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
43aarch64-builtin-iterators.h: $(srcdir)/config/aarch64/geniterators.sh \
44	$(srcdir)/config/aarch64/iterators.md
45	$(SHELL) $(srcdir)/config/aarch64/geniterators.sh \
46		$(srcdir)/config/aarch64/iterators.md > \
47		aarch64-builtin-iterators.h
48
49aarch-common.o: $(srcdir)/config/arm/aarch-common.c $(CONFIG_H) $(SYSTEM_H) \
50    coretypes.h $(TM_H) $(TM_P_H) $(RTL_H) $(TREE_H) output.h $(C_COMMON_H)
51	$(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
52		$(srcdir)/config/arm/aarch-common.c
53
54aarch64-c.o: $(srcdir)/config/aarch64/aarch64-c.c $(CONFIG_H) $(SYSTEM_H) \
55    coretypes.h $(TM_H) $(TREE_H) output.h $(C_COMMON_H) $(TARGET_H)
56	$(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
57		$(srcdir)/config/aarch64/aarch64-c.c
58
59PASSES_EXTRA += $(srcdir)/config/aarch64/aarch64-passes.def
60
61cortex-a57-fma-steering.o: $(srcdir)/config/aarch64/cortex-a57-fma-steering.c \
62    $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
63    dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
64    output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
65    $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
66    $(srcdir)/config/aarch64/aarch64-protos.h
67	$(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
68		$(srcdir)/config/aarch64/cortex-a57-fma-steering.c
69
70comma=,
71MULTILIB_OPTIONS    = $(subst $(comma),/, $(patsubst %, mabi=%, $(subst $(comma),$(comma)mabi=,$(TM_MULTILIB_CONFIG))))
72MULTILIB_DIRNAMES   = $(subst $(comma), ,$(TM_MULTILIB_CONFIG))
73