rust: build failure after NON_DEPENDENT_EXPR removal [PR111899]
[official-gcc.git] / gcc / config / arm / t-arm-elf
blobf7fc1460d1cd3f8963a3518dfe8a65cfd31fde78
1 # Copyright (C) 1998-2023 Free Software Foundation, Inc.
3 # This file is part of GCC.
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.
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.
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/>.
19 # Build a very basic set of libraries that should cater for most cases.
21 # Single-precision floating-point is NOT supported; we don't build a
22 # suitable library for that.  Use the rm-profile config in that case.
24 # PART 1 - Useful groups of options
26 dp_fpus         := vfp vfpv2 vfpv3 vfpv3-fp16 vfpv3-d16 vfpv3-d16-fp16 \
27                    neon neon-vfpv3 neon-fp16 vfpv4 neon-vfpv4 vfpv4-d16 \
28                    fpv5-d16 fp-armv8 neon-fp-armv8 crypto-neon-fp-armv8 \
29                    vfp3
31 sp_fpus         := vfpv3xd vfpv3xd-fp16  fpv4-sp-d16 fpv5-sp-d16
33 v7a_fps         := vfpv3 vfpv3-fp16 vfpv4 simd neon-fp16 neon-vfpv4
34 v7ve_fps        := vfpv3-d16 vfpv3 vfpv3-d16-fp16 vfpv3-fp16 vfpv4 neon \
35                    neon-fp16 simd
37 # Not all these permutations exist for all architecture variants, but
38 # it seems to work ok.
39 v8_fps          := simd fp16 crypto fp16+crypto dotprod fp16fml
41 v9_fps          := simd fp16 crypto fp16+crypto dotprod fp16fml
43 # We don't do anything special with these.  Pre-v4t probably doesn't work.
44 all_early_nofp  := armv4 armv4t armv5t
46 all_early_arch  := armv5tej armv6 armv6j armv6k armv6z armv6kz \
47                    armv6zk armv6t2 iwmmxt iwmmxt2
49 all_v7_a_r      := armv7-a armv7ve armv7-r
51 all_v8_archs    := armv8-a armv8-a+crc armv8.1-a armv8.2-a armv8.3-a armv8.4-a \
52                    armv8.5-a armv8.6-a
54 all_v9_archs    := armv9-a
56 # No floating point variants, require thumb1 softfp
57 all_nofp_t      := armv6-m armv6s-m armv8-m.base
59 all_nofp_t2     := armv7-m
61 all_sp_only     := armv7e-m armv8-m.main
63 MULTILIB_OPTIONS     =
64 MULTILIB_DIRNAMES    =
65 MULTILIB_EXCEPTIONS  = 
66 MULTILIB_MATCHES     =
67 MULTILIB_REUSE       =
69 # PART 2 - multilib build rules
71 MULTILIB_OPTIONS     += marm/mthumb
72 MULTILIB_DIRNAMES    += arm thumb
74 MULTILIB_OPTIONS     += mfpu=auto
75 MULTILIB_DIRNAMES    += autofp
77 MULTILIB_OPTIONS     += march=armv5te+fp/march=armv7+fp
78 MULTILIB_DIRNAMES    += v5te v7
80 MULTILIB_OPTIONS     += mfloat-abi=hard
81 MULTILIB_DIRNAMES    += fpu
83 # Build a total of 4 library variants (base options plus the following):
84 MULTILIB_REQUIRED    += mthumb
85 MULTILIB_REQUIRED    += marm/mfpu=auto/march=armv5te+fp/mfloat-abi=hard
86 MULTILIB_REQUIRED    += mthumb/mfpu=auto/march=armv7+fp/mfloat-abi=hard
88 # PART 3 - Match rules
90 # Map all supported FPUs onto mfpu=auto
91 MULTILIB_MATCHES     += $(foreach FPU, $(dp_fpus), \
92                           mfpu?auto=mfpu?$(FPU))
94 MULTILIB_MATCHES     += march?armv5te+fp=march?armv5te
96 MULTILIB_MATCHES     += $(foreach ARCH, $(all_early_arch), \
97                           march?armv5te+fp=march?$(ARCH) \
98                           march?armv5te+fp=march?$(ARCH)+fp)
100 MULTILIB_MATCHES     += march?armv7+fp=march?armv7
102 MULTILIB_MATCHES     += $(foreach FPARCH, $(v7a_fps), \
103                           march?armv7+fp=march?armv7-a+$(FPARCH))
105 MULTILIB_MATCHES     += $(foreach FPARCH, $(v7ve_fps), \
106                           march?armv7+fp=march?armv7ve+$(FPARCH))
108 MULTILIB_MATCHES     += $(foreach ARCH, $(all_v7_a_r), \
109                           march?armv7+fp=march?$(ARCH) \
110                           march?armv7+fp=march?$(ARCH)+fp)
112 MULTILIB_MATCHES     += $(foreach ARCH, $(all_v8_archs), \
113                           march?armv7+fp=march?$(ARCH) \
114                           $(foreach FPARCH, $(v8_fps), \
115                             march?armv7+fp=march?$(ARCH)+$(FPARCH)))
117 MULTILIB_MATCHES     += $(foreach ARCH, $(all_v9_archs), \
118                           march?armv7+fp=march?$(ARCH) \
119                           $(foreach FPARCH, $(v9_fps), \
120                             march?armv7+fp=march?$(ARCH)+$(FPARCH)))
122 MULTILIB_MATCHES     += $(foreach ARCH, armv7e-m armv8-m.mainline, \
123                           march?armv7+fp=march?$(ARCH)+fp.dp)
125 # PART 4 - Reuse rules
127 MULTILIB_REUSE       += mthumb=mthumb/mfpu.auto
128 MULTILIB_REUSE       += mthumb=mthumb/mfpu.auto/march.armv5te+fp
129 MULTILIB_REUSE       += mthumb=mthumb/march.armv5te+fp
130 MULTILIB_REUSE       += marm/mfpu.auto/march.armv5te+fp/mfloat-abi.hard=marm/march.armv5te+fp/mfloat-abi.hard
131 MULTILIB_REUSE       += marm/mfpu.auto/march.armv5te+fp/mfloat-abi.hard=march.armv5te+fp/mfloat-abi.hard
132 MULTILIB_REUSE       += marm/mfpu.auto/march.armv5te+fp/mfloat-abi.hard=mfpu.auto/march.armv5te+fp/mfloat-abi.hard
133 MULTILIB_REUSE       += mthumb/mfpu.auto/march.armv7+fp/mfloat-abi.hard=mthumb/march.armv7+fp/mfloat-abi.hard
134 MULTILIB_REUSE       += mthumb/mfpu.auto/march.armv7+fp/mfloat-abi.hard=mfpu.auto/march.armv7+fp/mfloat-abi.hard
135 MULTILIB_REUSE       += mthumb/mfpu.auto/march.armv7+fp/mfloat-abi.hard=march.armv7+fp/mfloat-abi.hard