1ba8a5d1c518737d94da665429f0973aaa31fbed
[platform/upstream/linaro-gcc.git] / gcc / config / aarch64 / t-aarch64
1 # Machine description for AArch64 architecture.
2 #  Copyright (C) 2009-2016 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-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
49 aarch-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
54 aarch64-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
59 cortex-a57-fma-steering.o: $(srcdir)/config/aarch64/cortex-a57-fma-steering.c \
60     $(CONFIG_H) $(SYSTEM_H) $(TM_H) $(REGS_H) insn-config.h $(RTL_BASE_H) \
61     dominance.h cfg.h cfganal.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(RECOG_H) \
62     output.h hash-map.h $(DF_H) $(OBSTACK_H) $(TARGET_H) $(RTL_H) \
63     $(CONTEXT_H) $(TREE_PASS_H) regrename.h \
64     $(srcdir)/config/aarch64/cortex-a57-fma-steering.h \
65     $(srcdir)/config/aarch64/aarch64-protos.h
66         $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
67                 $(srcdir)/config/aarch64/cortex-a57-fma-steering.c
68
69 comma=,
70 MULTILIB_OPTIONS    = $(subst $(comma),/, $(patsubst %, mabi=%, $(subst $(comma),$(comma)mabi=,$(TM_MULTILIB_CONFIG))))
71 MULTILIB_DIRNAMES   = $(subst $(comma), ,$(TM_MULTILIB_CONFIG))