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