[PATCH 16/57][Arm][GAS] Add support for MVE instructions: vdup, vddup, vdwdup, vidup...
[binutils-gdb.git] / gas / configure.tgt
blob2d08c09de91e503fb63f025264c7e3cce2f35545
1 # gas target specific configuration file.  This is a -*- sh -*- file.
3 #   Copyright (C) 2012-2019 Free Software Foundation, Inc.
5 # This file 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 of the License, or
8 # (at your option) any later version.
9
10 # This program 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 this program; see the file COPYING3.  If not see
17 # <http://www.gnu.org/licenses/>.
20 # This is invoked by configure.  Putting it in a separate shell file
21 # lets us skip running autoconf when modifying target specific
22 # information.
24 # Input shell variables:
25 #   targ        a configuration target name, such as i686-pc-linux-gnu.
27 # Output shell variables:
28 #   cpu_type    canonical gas cpu type; identifies the config/tc-* files
29 #   fmt         output format; identifies the config/obj-* files
30 #   em          emulation; identifies the config/te-* files
32 # Optional output shell variables; these are not always set:
33 #   arch        the default architecture; sets DEFAULT_ARCH on some systems
34 #   endian      "big" or "little"; used on bi-endian systems
36 cpu_type=
37 fmt=
38 em=generic
39 bfd_gas=no
40 arch=
41 endian=
43 eval `echo $targ | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/cpu=\1 vendor=\2 os=\3/'`
45 # Check for architecture variants.  Set cpu_type and, optionally,
46 # endian and arch.
47 # Note: This table is alpha-sorted, please try to keep it that way.
48 case ${cpu} in
49   aarch64)              cpu_type=aarch64 endian=little arch=aarch64;;
50   aarch64_be)           cpu_type=aarch64 endian=big arch=aarch64;;
51   alpha*)               cpu_type=alpha ;;
52   am33_2.0)             cpu_type=mn10300 endian=little ;;
53   arc*eb)               cpu_type=arc endian=big ;;
54   arm*be|arm*b)         cpu_type=arm endian=big ;;
55   arm*)                 cpu_type=arm endian=little ;;
56   bfin*)                cpu_type=bfin endian=little ;;
57   c4x*)                 cpu_type=tic4x ;;
58   cr16*)                cpu_type=cr16 endian=little ;;
59   crisv32)              cpu_type=cris arch=crisv32 ;;
60   crx*)                 cpu_type=crx endian=little ;;
61   epiphany*)            cpu_type=epiphany endian=little ;;
62   fido)                 cpu_type=m68k ;;
63   hppa*)                cpu_type=hppa ;;
64   i[3-7]86)             cpu_type=i386 arch=i386;;
65   ia16)                 cpu_type=i386 arch=i386;;
66   ia64)                 cpu_type=ia64 ;;
67   ip2k)                 cpu_type=ip2k endian=big ;;
68   iq2000)               cpu_type=iq2000 endian=big ;;
69   lm32)                 cpu_type=lm32 ;;
70   m32c)                 cpu_type=m32c endian=little ;;
71   m32r)                 cpu_type=m32r endian=big ;;
72   m32rle)               cpu_type=m32r endian=little ;;
73   m5200)                cpu_type=m68k ;;
74   m68008)               cpu_type=m68k ;;
75   m680[012346]0)        cpu_type=m68k ;;
76   m6811|m6812|m68hc12)  cpu_type=m68hc11 ;;
77   m683??)               cpu_type=m68k ;;
78   s12z)               cpu_type=s12z ;;
79   mep)                  cpu_type=mep endian=little ;;
80   microblazeel*)        cpu_type=microblaze endian=little;;
81   microblaze*)          cpu_type=microblaze endian=big;;
82   mips*el)              cpu_type=mips endian=little ;;
83   mips*)                cpu_type=mips endian=big ;;
84   mt)                   cpu_type=mt endian=big ;;
85   nds32be)              cpu_type=nds32 endian=big ;;
86   nds32le)              cpu_type=nds32 endian=little ;;
87   or1k* | or1knd*)      cpu_type=or1k endian=big ;;
88   pjl*)                 cpu_type=pj endian=little ;;
89   pj*)                  cpu_type=pj endian=big ;;
90   powerpc*le*)          cpu_type=ppc endian=little ;;
91   powerpc*)             cpu_type=ppc endian=big ;;
92   riscv64*)             cpu_type=riscv endian=little arch=riscv64 ;;
93   riscv32* | riscv*)    cpu_type=riscv endian=little arch=riscv32 ;;
94   rs6000*)              cpu_type=ppc ;;
95   rl78*)                cpu_type=rl78 ;;
96   rx)                   cpu_type=rx ;;
97   s390x*)               cpu_type=s390 arch=s390x ;;
98   s390*)                cpu_type=s390 arch=s390 ;;
99   score*l)              cpu_type=score endian=little ;;
100   score*)               cpu_type=score endian=big ;;
101   sh*le)                cpu_type=sh endian=little ;;
102   sh*)                  cpu_type=sh endian=big ;;
103   sparc64* | sparcv9*)  cpu_type=sparc arch=v9-64 ;;
104   sparc86x*)            cpu_type=sparc arch=sparc86x  ;;
105   sparclet*)            cpu_type=sparc arch=sparclet ;;
106   sparclite*)           cpu_type=sparc arch=sparclite ;;
107   sparc*)               cpu_type=sparc arch=sparclite ;; # ??? See tc-sparc.c.
108   tilegx*be)            cpu_type=tilegx endian=big ;;
109   tilegx*)              cpu_type=tilegx endian=little ;;
110   v850*)                cpu_type=v850 ;;
111   visium)               cpu_type=visium endian=big ;;
112   wasm32)               cpu_type=wasm32 endian=little ;;
113   x86_64*)              cpu_type=i386 arch=x86_64;;
114   xgate)                cpu_type=xgate ;;
115   xtensa*)              cpu_type=xtensa arch=xtensa ;;
116   *)                    cpu_type=${cpu} ;;
117 esac
120 # Assign object format.  Set fmt, em, and bfd_gas.
121 generic_target=${cpu_type}-$vendor-$os
122 # Note: This table is alpha-sorted, please try to keep it that way.
123 case ${generic_target} in
124   aarch64*-*-elf*)                      fmt=elf;;
125   aarch64*-*-fuchsia*)                  fmt=elf;;
126   aarch64*-*-linux*)                    fmt=elf em=linux
127     case ${cpu}-${os} in
128       aarch64*-linux-gnu_ilp32)         arch=aarch64:32 ;;
129     esac ;;
131   alpha-*-*vms*)                        fmt=evax ;;
132   alpha-*-osf*)                         fmt=ecoff ;;
133   alpha-*-linux*ecoff*)                 fmt=ecoff ;;
134   alpha-*-linux-*)                      fmt=elf em=linux ;;
135   alpha-*-netbsd* | alpha-*-openbsd*)   fmt=elf em=nbsd ;;
137   arc-*-elf*)                           fmt=elf ;;
138   arc*-*-linux*)                        fmt=elf bfd_gas=yes ;;
140   arm-*-phoenix*)                       fmt=elf ;;
141   arm-*-elf)                            fmt=elf ;;
142   arm-*-eabi* | arm-*-rtems*)           fmt=elf em=armeabi ;;
143   arm-*-symbianelf*)                    fmt=elf em=symbian ;;
144   arm-*-kaos*)                          fmt=elf ;;
145   arm-*-conix*)                         fmt=elf ;;
146   arm-*-freebsd[89].* | armeb-*-freebsd[89].*)
147                                         fmt=elf  em=freebsd ;;
148   arm-*-freebsd* | armeb-*-freebsd*)    fmt=elf  em=armfbsdeabi ;;
149   arm*-*-freebsd*)                      fmt=elf  em=armfbsdvfp ;;
150   arm-*-linux-*eabi*)                   fmt=elf  em=armlinuxeabi ;;
151   arm-*-linux-*)                        fmt=elf  em=linux ;;
152   arm-*-uclinux*eabi*)                  fmt=elf  em=armlinuxeabi ;;
153   arm-*-uclinux*)                       fmt=elf  em=linux ;;
154   arm-*-nacl*)                          fmt=elf  em=nacl ;;
155   arm-*-netbsdelf*)                     fmt=elf  em=nbsd ;;
156   arm-*-nto*)                           fmt=elf ;;
157   arm-wince-pe | arm-*-wince | arm*-*-mingw32ce* | arm*-*-cegcc*)
158                                         fmt=coff em=wince-pe ;;
159   arm-*-pe)                             fmt=coff em=pe ;;
160   arm-*-fuchsia*)                       fmt=elf ;;
162   avr-*-*)                              fmt=elf bfd_gas=yes ;;
164   bfin-*-linux-uclibc)                  fmt=fdpicelf em=linux ;;
165   bfin-*-uclinux*)                      fmt=elf em=linux ;;
166   bfin-*elf)                            fmt=elf ;;
168   cr16-*-elf*)                          fmt=elf ;;
170   cris-*-linux-* | crisv32-*-linux-*)
171                                         fmt=multi em=linux ;;
172   cris-*-* | crisv32-*-*)               fmt=multi ;;
174   crx-*-elf*)                           fmt=elf ;;
176   csky-*-elf*abiv1)                     fmt=elf em=csky_abiv1 ;;
177   csky-*-elf*)                          fmt=elf em=csky_abiv2 ;;
178   csky-*-linux*abiv1)                   fmt=elf em=csky_abiv1_linux ;;
179   csky-*-linux*)                        fmt=elf em=csky_abiv2_linux ;;
181   d10v-*-*)                             fmt=elf ;;
182   d30v-*-*)                             fmt=elf ;;
183   dlx-*-*)                              fmt=elf ;;
185   epiphany-*-*)                         fmt=elf ;;
187   fr30-*-*)                             fmt=elf ;;
188   frv-*-*linux*)                        fmt=elf em=linux;;
189   frv-*-*)                              fmt=elf ;;
191   ft32-*-*)                             fmt=elf ;;
193   hppa-*-linux*)
194     case ${cpu} in
195       hppa*64*)                         fmt=elf em=hppalinux64 ;;
196       hppa*)                            fmt=elf em=linux ;;
197     esac ;;
198   hppa-*-*elf*)                         fmt=elf em=hppa ;;
199   hppa-*-lites*)                        fmt=elf em=hppa ;;
200   hppa-*-netbsd*)                       fmt=elf em=nbsd ;;
201   hppa-*-openbsd*)                      fmt=elf em=hppa ;;
202   hppa-*-osf*)                          fmt=som em=hppa ;;
203   hppa-*-hpux11*)
204     case ${cpu} in
205       hppa*64*)                         fmt=elf em=hppa64 ;;
206       hppa*)                            fmt=som em=hppa ;;
207     esac ;;
208   hppa-*-hpux*)                         fmt=som em=hppa ;;
209   hppa-*-mpeix*)                        fmt=som em=hppa ;;
210   hppa-*-bsd*)                          fmt=som em=hppa ;;
211   hppa-*-hiux*)                         fmt=som em=hppa ;;
213   h8300-*-elf)                          fmt=elf ;;
214   h8300-*-linux*)                       fmt=elf em=linux ;;
216   i386-*-beospe*)                       fmt=coff em=pe ;;
217   i386-*-beos*)                         fmt=elf ;;
218   i386-*-elfiamcu)                      fmt=elf arch=iamcu ;;
219   i386-*-elf*)                          fmt=elf ;;
220   i386-*-fuchsia*)                      fmt=elf ;;
221   i386-*-bsd*)                          fmt=aout em=386bsd ;;
222   i386-*-nacl*)                         fmt=elf em=nacl
223     case ${cpu} in
224       x86_64*)                          arch=x86_64:32 ;;
225     esac ;;
226   i386-*-netbsdpe*)                     fmt=coff em=pe ;;
227   i386-*-netbsd*-gnu* | \
228   i386-*-knetbsd*-gnu | \
229   i386-*-netbsd* | \
230   i386-*-openbsd*)                      fmt=elf em=nbsd ;;
231   i386-*-linux-*)                       fmt=elf em=linux
232     case ${cpu}-${os} in
233       x86_64*-linux-gnux32)             arch=x86_64:32 ;;
234     esac ;;
235   i386-*-lynxos*)                       fmt=elf em=lynx ;;
236   i386-*-redox*)                        fmt=elf ;;
237   i386-*-solaris*)                      fmt=elf em=solaris ;;
238   i386-*-freebsd* \
239   | i386-*-kfreebsd*-gnu)               fmt=elf em=freebsd ;;
240   i386-*-msdosdjgpp* \
241   | i386-*-go32*)                       fmt=coff em=go32 ;;
242   i386-*-gnu*)                          fmt=elf em=gnu ;;
243   i386-*-msdos*)                        fmt=aout ;;
244   i386-*-moss*)                         fmt=elf ;;
245   i386-*-pe)                            fmt=coff em=pe ;;
246   i386-*-cygwin*)
247    case ${cpu} in
248      x86_64*)                           fmt=coff em=pep ;;
249      i*)                                fmt=coff em=pe ;;
250    esac ;;
251   i386-*-interix*)                      fmt=coff em=interix ;;
252   i386-*-mingw*)
253     case ${cpu} in
254       x86_64*)                          fmt=coff em=pep ;;
255       i*)                               fmt=coff em=pe ;;
256     esac ;;
257   i386-*-nto-qnx*)                      fmt=elf ;;
258   i386-*-*nt*)                          fmt=coff em=pe ;;
259   i386-*-rdos*)                         fmt=elf ;;
260   i386-*-darwin*)                       fmt=macho ;;
262   ia16-*-elf*)                          fmt=elf ;;
264   ia64-*-elf*)                          fmt=elf ;;
265   ia64-*-*vms*)                         fmt=elf em=vms ;;
266   ia64-*-aix*)                          fmt=elf em=ia64aix ;;
267   ia64-*-linux-*)                       fmt=elf em=linux ;;
268   ia64-*-hpux*)                         fmt=elf em=hpux ;;
269   ia64-*-netbsd*)                       fmt=elf em=nbsd ;;
271   ip2k-*-*)                             fmt=elf ;;
273   iq2000-*-elf)                         fmt=elf ;;
275   lm32-*-*)                             fmt=elf ;;
277   m32c-*-elf)                           fmt=elf ;;
279   m32r-*-elf*)                          fmt=elf ;;
280   m32r-*-linux*)                        fmt=elf em=linux;;
282   m68hc11-*-* | m6811-*-*)              fmt=elf ;;
283   m68hc12-*-* | m6812-*-*)              fmt=elf ;;
285   m68k-*-elf*)                          fmt=elf ;;
286   m68k-*-sysv4*)                        fmt=elf em=svr4 ;;
287   m68k-*-linux-*)                       fmt=elf em=linux ;;
288   m68k-*-uclinux*)                      fmt=elf em=uclinux ;;
289   m68k-*-gnu*)                          fmt=elf ;;
290   m68k-*-netbsdelf*)                    fmt=elf em=nbsd ;;
292   s12z-*-*)                             fmt=elf ;;
294   mep-*-elf)                            fmt=elf ;;
296   metag-*-elf)                          fmt=elf ;;
297   metag-*-linux*)                       fmt=elf em=linux ;;
299   mcore-*-elf)                          fmt=elf ;;
300   mcore-*-pe)                           fmt=coff em=pe bfd_gas=yes ;;
302   microblaze-*-*)                       fmt=elf ;;
304   mips-*-irix6*)                        fmt=elf em=irix ;;
305   mips-*-irix5*)                        fmt=elf em=irix ;;
306   mips*-*-linux*)                       fmt=elf em=tmips ;;
307   mips*-*-freebsd* | mips*-*-kfreebsd*-gnu)
308                                         fmt=elf em=freebsd ;;
309   mips-*-sysv4* | mips-*-gnu*)          fmt=elf em=tmips ;;
310   mips*-sde-elf* | mips*-mti-elf* | mips*-img-elf*)
311                                         fmt=elf em=tmips ;;
312   mips-*-elf*)                          fmt=elf ;;
313   mips-*-netbsd*)                       fmt=elf em=tmips ;;
314   mips-*-openbsd*)                      fmt=elf em=tmips ;;
315   mips-*-windiss)                       fmt=elf ;;
317   mmix-*-*)                             fmt=elf ;;
319   mn10200-*-*)                          fmt=elf ;;
321   # cpu_type for am33_2.0 is set to mn10300
322   mn10300-*-linux*)                     fmt=elf em=linux ;;
323   mn10300-*-*)                          fmt=elf ;;
325   moxie-*-uclinux)                      fmt=elf em=linux ;;
326   moxie-*-moxiebox*)                    fmt=elf endian=little ;;
327   moxie-*-*)                            fmt=elf ;;
328     
329   mt-*-elf)                             fmt=elf bfd_gas=yes ;;
331   msp430-*-*)                           fmt=elf ;;
333   nds32-*-elf*)                         fmt=elf ;;
334   nds32-*-linux*)                       fmt=elf em=linux ;;
336   nios2*-linux*)                        fmt=elf em=linux ;;
338   ns32k-pc532-mach*)                    fmt=aout em=pc532mach ;;
339   ns32k-pc532-ux*)                      fmt=aout em=pc532mach ;;
340   ns32k-pc532-lites*)                   fmt=aout em=nbsd532 ;;
341   ns32k-*-*n*bsd*)                      fmt=aout em=nbsd532 ;;
343   or1k*-*-elf | or1k*-*-rtems*)         fmt=elf endian=big ;;
344   or1k*-*-linux*)                       fmt=elf em=linux endian=big ;;
346   pj*)                                  fmt=elf ;;
348   ppc-*-pe | ppc-*-cygwin*)             fmt=coff em=pe ;;
349   ppc-*-winnt*)                         fmt=coff em=pe ;;
350   ppc-*-aix5.[01])                      fmt=coff em=aix5 ;;
351   ppc-*-aix[5-9].*)                     fmt=coff em=aix5 ;;
352   ppc-*-aix*)                           fmt=coff em=aix ;;
353   ppc-*-beos*)                          fmt=coff ;;
354   ppc-*-*n*bsd* | ppc-*-elf*)           fmt=elf ;;
355   ppc-*-eabi* | ppc-*-sysv4*)           fmt=elf ;;
356   ppc-*-linux-*)                        fmt=elf em=linux ;;
357   ppc-*-solaris*)                       fmt=elf em=solaris ;;
358   ppc-*-macos*)                         fmt=coff em=macos ;;
359   ppc-*-nto*)                           fmt=elf ;;
360   ppc-*-kaos*)                          fmt=elf ;;
361   ppc-*-lynxos*)                        fmt=elf em=lynx ;;
363   pru-*-*)                              fmt=elf ;;
365   riscv*-*-*)                           fmt=elf endian=little ;;
367   rx-*-linux*)                          fmt=elf em=linux ;;
369   s390-*-linux-*)                       fmt=elf em=linux ;;
370   s390-*-tpf*)                          fmt=elf ;;
372   score-*-elf)                          fmt=elf ;;
374   sh*-*-linux*)                         fmt=elf em=linux
375     case ${cpu} in
376       sh*eb)    endian=big ;;
377       *)        endian=little ;;
378     esac ;;
379   sh*-*-netbsdelf*)                     fmt=elf em=nbsd
380     case ${cpu} in
381       sh*l*)    endian=little ;;
382       *)        endian=big ;;
383     esac ;;
384   sh-*-elf*)                            fmt=elf ;;
385   sh-*-uclinux* | sh[12]-*-uclinux*)    fmt=elf em=uclinux ;;
386   sh-*-coff*)                           fmt=coff ;;
387   sh-*-nto*)                            fmt=elf ;;
388   sh-*-pe*)                             fmt=coff em=pe bfd_gas=yes endian=little ;;
389   sh-*-kaos*)                           fmt=elf ;;
390   shle*-*-kaos*)                        fmt=elf ;;
392   sparc-*-linux-*)                      fmt=elf em=linux ;;
393   sparc-*-solaris*)                     fmt=elf em=solaris ;;
394   sparc-*-*bsd*)                        fmt=elf em=nbsd ;;
396   spu-*-elf)                            fmt=elf ;;
398   tic30-*-*aout*)                       fmt=aout bfd_gas=yes ;;
399   tic30-*-*coff*)                       fmt=coff bfd_gas=yes ;;
400   tic4x-*-* | c4x-*-*)                  fmt=coff bfd_gas=yes ;;
401   tic54x-*-* | c54x*-*-*)               fmt=coff bfd_gas=yes need_libm=yes;;
402   tic6x-*-*)                            fmt=elf ;;
404   tilepro-*-* | tilegx*-*-*)            fmt=elf ;;
406   v850*-*-*)                            fmt=elf ;;
408   vax-*-netbsdelf*)                     fmt=elf em=nbsd ;;
409   vax-*-linux-*)                        fmt=elf em=linux ;;
411   visium-*-elf)                         fmt=elf ;;
413   wasm32-*-*)                           fmt=elf ;;
415   xstormy16-*-*)                        fmt=elf ;;
416   
417   xgate-*-*)                            fmt=elf ;;
419   xtensa*-*-*)                          fmt=elf ;;
421   z80-*-coff)                           fmt=coff ;;
423   z8k-*-coff | z8k-*-sim)               fmt=coff ;;
425   *-*-aout | *-*-scout)                 fmt=aout ;;
426   *-*-cloudabi*)                        fmt=elf em=cloudabi ;;
427   *-*-dragonfly*)                       fmt=elf em=dragonfly ;;
428   *-*-freebsd* | *-*-kfreebsd*-gnu)     fmt=elf em=freebsd ;;
429   *-*-generic)                          fmt=generic ;;
430   *-*-xray | *-*-hms)                   fmt=coff ;;
431   *-*-sim)                              fmt=coff ;;
432   *-*-elf | *-*-rtems* | *-*-sysv4*)    fmt=elf ;;
433   *-*-solaris*)                         fmt=elf em=solaris ;;
434   *-*-aros*)                            fmt=elf em=linux ;;
435   *-*-vxworks* | *-*-windiss)           fmt=elf em=vxworks ;;
436 esac
438 case ${cpu_type} in
439   aarch64 | alpha | arm | csky | i386 | ia64 | microblaze | mips | ns32k | or1k | or1knd | pdp11 | ppc | riscv | sparc | z80 | z8k)
440     bfd_gas=yes
441     ;;
442 esac
443 case ${fmt} in
444   elf | ecoff | fdpicelf | multi | som)
445     bfd_gas=yes
446     ;;
447 esac
449 if test $bfd_gas != yes; then
450   echo This target is no longer supported in gas
451   exit 1
454 case ${cpu_type}-${fmt}-${os} in
455 i386-elf-linux*)
456   # Default to compress DWARF debug sections for Linux/x86.
457   if test ${ac_default_compressed_debug_sections} = unset; then
458     ac_default_compressed_debug_sections=yes
459   fi
460   ;;
461 esac