]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/config/arm/t-multilib
arm: add armv9-a architecture to -march
[thirdparty/gcc.git] / gcc / config / arm / t-multilib
CommitLineData
99dee823 1# Copyright (C) 2016-2021 Free Software Foundation, Inc.
2f738ca5
TP
2#
3# This file is part of GCC.
4#
5# GCC is free software; you can redistribute it and/or modify
6# it under the terms of the GNU General Public License as published by
7# the Free Software Foundation; either version 3, or (at your option)
8# any later version.
9#
10# GCC is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
14#
15# You should have received a copy of the GNU General Public License
16# along with GCC; see the file COPYING3. If not see
17# <http://www.gnu.org/licenses/>.
18
19# This is a target makefile fragment that attempts to get
20# multilibs built for the range of CPU's, FPU's and ABI's that
21# are relevant for the ARM architecture. It should not be used in
22# conjunction with another make file fragment and assumes --with-arch,
23# --with-cpu, --with-fpu, --with-float, --with-mode have their default
24# values during the configure step. We enforce this during the
25# top-level configury.
26
f4c8d44e
AV
27s-mlib: $(srcdir)/config/arm/t-multilib $(srcdir)/config/arm/t-aprofile $(srcdir)/config/arm/t-rmprofile
28
2f738ca5
TP
29MULTILIB_OPTIONS =
30MULTILIB_DIRNAMES =
31MULTILIB_EXCEPTIONS =
32MULTILIB_MATCHES =
33MULTILIB_REUSE =
93aa40fe 34MULTILIB_REQUIRED =
2f738ca5
TP
35
36comma := ,
37tm_multilib_list := $(subst $(comma), ,$(TM_MULTILIB_CONFIG))
38
39HAS_APROFILE := $(filter aprofile,$(tm_multilib_list))
40HAS_RMPROFILE := $(filter rmprofile,$(tm_multilib_list))
41
93aa40fe
RE
42# Produce the combinatorial list of extensions. Where there are
43# multiple permutations for a combination, the ordering is the
44# selected by the forward ordering of the original list. This matches
45# the canonical ordering generated by the canonicalizer in the driver.
46#
47# For example,
48# $(call all_feat_combs, a b)
49# will produce
50# +a +a+b +b
51# but will not include
52# +b+a
53# The rule is recursive and can be called with any (reasonable) list of
54# extensions.
55all_feat_combs = +$(firstword $(1)) \
56 $(if $(wordlist 2, $(words $(1)), $(1)), \
57 $(foreach OPT, \
58 $(call all_feat_combs, \
59 $(wordlist 2, $(words $(1)), $(1))), \
60 +$(firstword $(1))$(OPT) $(OPT)),)
61
42093880 62# Variables used.
c3f808d3 63all_early_arch := armv5tej armv6 armv6j armv6k armv6z armv6kz \
42093880 64 armv6zk armv6t2 iwmmxt iwmmxt2
cab81ec0 65v7_a_arch_variants := $(call all_feat_combs, mp sec)
42093880
RE
66v7_a_nosimd_variants := +fp +vfpv3 +vfpv3-d16-fp16 +vfpv3-fp16 +vfpv4-d16 +vfpv4
67v7_a_simd_variants := +simd +neon-fp16 +neon-vfpv4
f4c8d44e
AV
68v7_r_sp_variants := +fp.sp +fp.sp+idiv +vfpv3xd-fp16 +vfpv3xd-fp16+idiv
69v7_r_dp_variants := +fp +fp+idiv +vfpv3-d16-fp16 +vfpv3-d16-fp16+idiv
42093880
RE
70v7ve_nosimd_variants := +vfpv3-d16 +vfpv3 +vfpv3-d16-fp16 +vfpv3-fp16 +fp +vfpv4
71v7ve_vfpv3_simd_variants := +neon +neon-fp16
72v7ve_vfpv4_simd_variants := +simd
73v8_a_nosimd_variants := +crc
74v8_a_simd_variants := $(call all_feat_combs, simd crypto)
75v8_1_a_simd_variants := $(call all_feat_combs, simd crypto)
f782b667
DZ
76v8_2_a_simd_variants := $(call all_feat_combs, simd fp16 fp16fml crypto dotprod i8mm bf16)
77v8_4_a_simd_variants := $(call all_feat_combs, simd fp16 crypto i8mm bf16)
78v8_5_a_simd_variants := $(call all_feat_combs, simd fp16 crypto i8mm bf16)
79v8_6_a_simd_variants := $(call all_feat_combs, simd fp16 crypto i8mm bf16)
9029d342 80v8_r_nosimd_variants := +crc
32ba7860
PW
81v9_a_nosimd_variants := +crc
82v9_a_simd_variants := $(call all_feat_combs, simd fp16 crypto i8mm bf16)
42093880 83
2f738ca5
TP
84ifneq (,$(HAS_APROFILE))
85include $(srcdir)/config/arm/t-aprofile
86endif
87ifneq (,$(HAS_RMPROFILE))
88include $(srcdir)/config/arm/t-rmprofile
89endif
90SEP := $(and $(HAS_APROFILE),$(HAS_RMPROFILE),/)
91
92
42093880
RE
93MULTILIB_OPTIONS += marm/mthumb
94MULTILIB_DIRNAMES += arm thumb
95
f4c8d44e
AV
96MULTILIB_OPTIONS += march=armv5te+fp/march=armv7/march=armv7+fp/march=armv7-r+fp.sp/$(MULTI_ARCH_OPTS_A)$(SEP)$(MULTI_ARCH_OPTS_RM)
97MULTILIB_DIRNAMES += v5te v7 v7+fp v7-r+fp.sp $(MULTI_ARCH_DIRS_A) $(MULTI_ARCH_DIRS_RM)
42093880
RE
98
99MULTILIB_OPTIONS += mfloat-abi=soft/mfloat-abi=softfp/mfloat-abi=hard
100MULTILIB_DIRNAMES += nofp softfp hard
101
102MULTILIB_REQUIRED += mthumb/mfloat-abi=soft
103MULTILIB_REQUIRED += marm/march=armv5te+fp/mfloat-abi=softfp
104MULTILIB_REQUIRED += marm/march=armv5te+fp/mfloat-abi=hard
105
106MULTILIB_REQUIRED += mthumb/march=armv7/mfloat-abi=soft
107MULTILIB_REQUIRED += mthumb/march=armv7+fp/mfloat-abi=softfp
108MULTILIB_REQUIRED += mthumb/march=armv7+fp/mfloat-abi=hard
109
f4c8d44e
AV
110MULTILIB_REQUIRED += mthumb/march=armv7-r+fp.sp/mfloat-abi=softfp
111MULTILIB_REQUIRED += mthumb/march=armv7-r+fp.sp/mfloat-abi=hard
112
113# Map v7-r with double precision down onto common v7 code.
42093880
RE
114MULTILIB_MATCHES += march?armv7=march?armv7-r
115MULTILIB_MATCHES += march?armv7=march?armv7-r+idiv
f4c8d44e
AV
116MULTILIB_MATCHES += $(foreach ARCH, $(v7_r_dp_variants), \
117 march?armv7+fp=march?armv7-r$(ARCH))
118
119# Map v7-r single precision variants to v7-r with single precision.
120MULTILIB_MATCHES += $(foreach ARCH, \
121 $(filter-out +fp.sp, $(v7_r_sp_variants)), \
122 march?armv7-r+fp.sp=march?armv7-r$(ARCH))
42093880
RE
123
124MULTILIB_MATCHES += $(foreach ARCH, $(all_early_arch), \
125 march?armv5te+fp=march?$(ARCH)+fp)
f4c8d44e 126# Map v8-r down onto common v7 code or v7-r sp.
9029d342
TP
127MULTILIB_MATCHES += march?armv7=march?armv8-r
128MULTILIB_MATCHES += $(foreach ARCH, $(v8_r_nosimd_variants), \
129 march?armv7=march?armv8-r$(ARCH))
130MULTILIB_MATCHES += $(foreach ARCH,+simd +crypto, \
131 march?armv7+fp=march?armv8-r$(ARCH) \
132 march?armv7+fp=march?armv8-r+crc$(ARCH))
f4c8d44e
AV
133MULTILIB_MATCHES += march?armv7-r+fp.sp=march?armv8-r+fp.sp
134MULTILIB_MATCHES += march?armv7-r+fp.sp=march?armv8-r+crc+fp.sp
42093880
RE
135
136ifeq (,$(HAS_APROFILE))
137# Map all v7-a
d5bc1808 138
42093880 139MULTILIB_MATCHES += march?armv7=march?armv7-a
d5bc1808
RE
140
141MULTILIB_MATCHES += $(foreach ARCH, $(v7_a_arch_variants), \
142 march?armv7=march?armv7-a$(ARCH))
143
42093880
RE
144MULTILIB_MATCHES += $(foreach ARCH, $(v7_a_nosimd_variants) $(v7_a_simd_variants), \
145 march?armv7+fp=march?armv7-a$(ARCH))
146
d5bc1808
RE
147MULTILIB_MATCHES += $(foreach ARCHVAR, $(v7_a_arch_variants), \
148 $(foreach ARCH, $(v7_a_nosimd_variants) $(v7_a_simd_variants), \
149 march?armv7+fp=march?armv7-a$(ARCHVAR)$(ARCH)))
150
42093880
RE
151MULTILIB_MATCHES += march?armv7=march?armv7ve
152
153# ARMv7ve FP/SIMD variants: map down to v7+fp
154MULTILIB_MATCHES += $(foreach ARCH, $(v7ve_nosimd_variants) $(v7ve_vfpv3_simd_variants) $(v7ve_vfpv4_simd_variants), \
155 march?armv7+fp=march?armv7ve$(ARCH))
156
157# ARMv8
158MULTILIB_MATCHES += march?armv7=march?armv8-a
159MULTILIB_MATCHES += $(foreach ARCH, $(v8_a_nosimd_variants), \
160 march?armv7=march?armv8-a$(ARCH))
161
162# ARMv8 with SIMD
163MULTILIB_MATCHES += march?armv7+fp=march?armv8-a+crc+simd \
164 $(foreach ARCH, $(v8_a_simd_variants), \
165 march?armv7+fp=march?armv8-a$(ARCH) \
166 march?armv7+fp=march?armv8-a+crc$(ARCH))
167
168# Baseline v8.1-a
169MULTILIB_MATCHES += march?armv7=march?armv8.1-a
170
171# Map all v8.1-a SIMD variants
172MULTILIB_MATCHES += $(foreach ARCH, $(v8_1_a_simd_variants), \
173 march?armv7+fp=march?armv8.1-a$(ARCH))
174
175# Baseline v8.2-a: map down to baseline v8-a
176MULTILIB_MATCHES += march?armv7=march?armv8.2-a
177
a00a4222
KT
178# Baseline v8.3-a: map down to baseline v8-a
179MULTILIB_MATCHES += march?armv7=march?armv8.3-a
180
181# Map all v8.2-a SIMD variants. v8.3-a SIMD variants have the same mappings
42093880 182MULTILIB_MATCHES += $(foreach ARCH, $(v8_2_a_simd_variants), \
a00a4222
KT
183 march?armv7+fp=march?armv8.2-a$(ARCH) \
184 march?armv7+fp=march?armv8.3-a$(ARCH))
42093880 185
946c6c45
KT
186# Baseline v8.4-a: map down to baseline v8-a
187MULTILIB_MATCHES += march?armv7=march?armv8.4-a
188
189# Map all v8.4-a SIMD variants
190MULTILIB_MATCHES += $(foreach ARCH, $(v8_4_a_simd_variants), \
191 march?armv7+fp=march?armv8.4-a$(ARCH))
192
ae78a89f
SD
193# Baseline v8.5-a: map down to baseline v8-a
194MULTILIB_MATCHES += march?armv7=march?armv8.5-a
195
196# Map all v8.5-a SIMD variants
197MULTILIB_MATCHES += $(foreach ARCH, $(v8_5_a_simd_variants), \
198 march?armv7+fp=march?armv8.5-a$(ARCH))
199
f782b667
DZ
200# Baseline v8.6-a: map down to baseline v8-a
201MULTILIB_MATCHES += march?armv7=march?armv8.6-a
202
203# Map all v8.6-a SIMD variants
204MULTILIB_MATCHES += $(foreach ARCH, $(v8_6_a_simd_variants), \
205 march?armv7+fp=march?armv8.6-a$(ARCH))
206
32ba7860
PW
207# Armv9
208MULTILIB_MATCHES += march?armv7=march?armv9-a
209MULTILIB_MATCHES += $(foreach ARCH, $(v9_a_nosimd_variants), \
210 march?armv7=march?armv9-a$(ARCH))
211
212# Armv9 with SIMD
213MULTILIB_MATCHES += march?armv7+fp=march?armv9-a+crc+simd \
214 $(foreach ARCH, $(v9_a_simd_variants), \
215 march?armv7+fp=march?armv9-a$(ARCH) \
216 march?armv7+fp=march?armv9-a+crc$(ARCH))
8d106dd5
RE
217endif # Not APROFILE.
218
42093880
RE
219# Use Thumb libraries for everything.
220
221MULTILIB_REUSE += mthumb/march.armv7/mfloat-abi.soft=marm/march.armv7/mfloat-abi.soft
2f738ca5 222
42093880 223MULTILIB_REUSE += $(foreach ABI, hard softfp, \
f4c8d44e 224 $(foreach ARCH, armv7+fp armv7-r+fp\.sp, \
42093880 225 mthumb/march.$(ARCH)/mfloat-abi.$(ABI)=marm/march.$(ARCH)/mfloat-abi.$(ABI)))
2f738ca5 226
42093880
RE
227# Softfp but no FP, use the soft-float libraries.
228MULTILIB_REUSE += $(foreach MODE, arm thumb, \
229 $(foreach ARCH, armv7, \
230 mthumb/march.$(ARCH)/mfloat-abi.soft=m$(MODE)/march.$(ARCH)/mfloat-abi.softfp))
2f738ca5 231