annotate gcc/config/arm/t-arm-elf @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents f6334be47118
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents: 67
diff changeset
1 # Copyright (C) 1998-2017 Free Software Foundation, Inc.
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
2 #
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
3 # This file is part of GCC.
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
4 #
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
5 # GCC is free software; you can redistribute it and/or modify
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
6 # it under the terms of the GNU General Public License as published by
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
7 # the Free Software Foundation; either version 3, or (at your option)
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
8 # any later version.
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
9 #
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
10 # GCC is distributed in the hope that it will be useful,
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
13 # GNU General Public License for more details.
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
14 #
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
15 # You should have received a copy of the GNU General Public License
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
16 # along with GCC; see the file COPYING3. If not see
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
17 # <http://www.gnu.org/licenses/>.
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
18
111
kono
parents: 67
diff changeset
19 # Build a very basic set of libraries that should cater for most cases.
kono
parents: 67
diff changeset
20
kono
parents: 67
diff changeset
21 # Single-precision floating-point is NOT supported; we don't build a
kono
parents: 67
diff changeset
22 # suitable library for that. Use the rm-profile config in that case.
kono
parents: 67
diff changeset
23
kono
parents: 67
diff changeset
24 # PART 1 - Useful groups of options
kono
parents: 67
diff changeset
25
kono
parents: 67
diff changeset
26 dp_fpus := vfp vfpv2 vfpv3 vfpv3-fp16 vfpv3-d16 vfpv3-d16-fp16 \
kono
parents: 67
diff changeset
27 neon neon-vfpv3 neon-fp16 vfpv4 neon-vfpv4 vfpv4-d16 \
kono
parents: 67
diff changeset
28 fpv5-d16 fp-armv8 neon-fp-armv8 crypto-neon-fp-armv8 \
kono
parents: 67
diff changeset
29 vfp3
kono
parents: 67
diff changeset
30
kono
parents: 67
diff changeset
31 sp_fpus := vfpv3xd vfpv3xd-fp16 fpv4-sp-d16 fpv5-sp-d16
kono
parents: 67
diff changeset
32
kono
parents: 67
diff changeset
33 v7a_fps := vfpv3 vfpv3-fp16 vfpv4 simd neon-fp16 neon-vfpv4
kono
parents: 67
diff changeset
34 v7ve_fps := vfpv3-d16 vfpv3 vfpv3-d16-fp16 vfpv3-fp16 vfpv4 neon \
kono
parents: 67
diff changeset
35 neon-fp16 simd
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36
111
kono
parents: 67
diff changeset
37 # Not all these permutations exist for all architecture variants, but
kono
parents: 67
diff changeset
38 # it seems to work ok.
kono
parents: 67
diff changeset
39 v8_fps := simd fp16 crypto fp16+crypto
kono
parents: 67
diff changeset
40
kono
parents: 67
diff changeset
41 # We don't do anything special with these. Pre-v4t probably doesn't work.
kono
parents: 67
diff changeset
42 all_early_nofp := armv2 armv2a armv3 armv3m armv4 armv4t armv5 armv5t
kono
parents: 67
diff changeset
43
kono
parents: 67
diff changeset
44 all_early_arch := armv5e armv5tej armv6 armv6j armv6k armv6z armv6kz \
kono
parents: 67
diff changeset
45 armv6zk armv6t2 iwmmxt iwmmxt2
kono
parents: 67
diff changeset
46
kono
parents: 67
diff changeset
47 all_v7_a_r := armv7-a armv7ve armv7-r
kono
parents: 67
diff changeset
48
kono
parents: 67
diff changeset
49 all_v8_archs := armv8-a armv8-a+crc armv8.1-a armv8.2-a
kono
parents: 67
diff changeset
50
kono
parents: 67
diff changeset
51 # No floating point variants, require thumb1 softfp
kono
parents: 67
diff changeset
52 all_nofp_t := armv6-m armv6s-m armv8-m.base
kono
parents: 67
diff changeset
53
kono
parents: 67
diff changeset
54 all_nofp_t2 := armv7-m
kono
parents: 67
diff changeset
55
kono
parents: 67
diff changeset
56 all_sp_only := armv7e-m armv8-m.main
kono
parents: 67
diff changeset
57
kono
parents: 67
diff changeset
58 MULTILIB_OPTIONS =
kono
parents: 67
diff changeset
59 MULTILIB_DIRNAMES =
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 MULTILIB_EXCEPTIONS =
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 MULTILIB_MATCHES =
111
kono
parents: 67
diff changeset
62 MULTILIB_REUSE =
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
63
111
kono
parents: 67
diff changeset
64 # PART 2 - multilib build rules
kono
parents: 67
diff changeset
65
kono
parents: 67
diff changeset
66 MULTILIB_OPTIONS += marm/mthumb
kono
parents: 67
diff changeset
67 MULTILIB_DIRNAMES += arm thumb
kono
parents: 67
diff changeset
68
kono
parents: 67
diff changeset
69 MULTILIB_OPTIONS += mfpu=auto
kono
parents: 67
diff changeset
70 MULTILIB_DIRNAMES += autofp
kono
parents: 67
diff changeset
71
kono
parents: 67
diff changeset
72 MULTILIB_OPTIONS += march=armv5te+fp/march=armv7+fp
kono
parents: 67
diff changeset
73 MULTILIB_DIRNAMES += v5te v7
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
74
111
kono
parents: 67
diff changeset
75 MULTILIB_OPTIONS += mfloat-abi=hard
kono
parents: 67
diff changeset
76 MULTILIB_DIRNAMES += fpu
kono
parents: 67
diff changeset
77
kono
parents: 67
diff changeset
78 # Build a total of 4 library variants (base options plus the following):
kono
parents: 67
diff changeset
79 MULTILIB_REQUIRED += mthumb
kono
parents: 67
diff changeset
80 MULTILIB_REQUIRED += marm/mfpu=auto/march=armv5te+fp/mfloat-abi=hard
kono
parents: 67
diff changeset
81 MULTILIB_REQUIRED += mthumb/mfpu=auto/march=armv7+fp/mfloat-abi=hard
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
82
111
kono
parents: 67
diff changeset
83 # PART 3 - Match rules
kono
parents: 67
diff changeset
84
kono
parents: 67
diff changeset
85 # Map all supported FPUs onto mfpu=auto
kono
parents: 67
diff changeset
86 MULTILIB_MATCHES += $(foreach FPU, $(dp_fpus), \
kono
parents: 67
diff changeset
87 mfpu?auto=mfpu?$(FPU))
kono
parents: 67
diff changeset
88
kono
parents: 67
diff changeset
89 MULTILIB_MATCHES += march?armv5te+fp=march?armv5te
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
90
111
kono
parents: 67
diff changeset
91 MULTILIB_MATCHES += $(foreach ARCH, $(all_early_arch), \
kono
parents: 67
diff changeset
92 march?armv5te+fp=march?$(ARCH) \
kono
parents: 67
diff changeset
93 march?armv5te+fp=march?$(ARCH)+fp)
kono
parents: 67
diff changeset
94
kono
parents: 67
diff changeset
95 MULTILIB_MATCHES += march?armv7+fp=march?armv7
kono
parents: 67
diff changeset
96
kono
parents: 67
diff changeset
97 MULTILIB_MATCHES += $(foreach FPARCH, $(v7a_fps), \
kono
parents: 67
diff changeset
98 march?armv7+fp=march?armv7-a+$(FPARCH))
kono
parents: 67
diff changeset
99
kono
parents: 67
diff changeset
100 MULTILIB_MATCHES += $(foreach FPARCH, $(v7ve_fps), \
kono
parents: 67
diff changeset
101 march?armv7+fp=march?armv7ve+$(FPARCH))
kono
parents: 67
diff changeset
102
kono
parents: 67
diff changeset
103 MULTILIB_MATCHES += $(foreach ARCH, $(all_v7_a_r), \
kono
parents: 67
diff changeset
104 march?armv7+fp=march?$(ARCH) \
kono
parents: 67
diff changeset
105 march?armv7+fp=march?$(ARCH)+fp)
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
106
111
kono
parents: 67
diff changeset
107 MULTILIB_MATCHES += $(foreach ARCH, $(all_v8_archs), \
kono
parents: 67
diff changeset
108 march?armv7+fp=march?$(ARCH) \
kono
parents: 67
diff changeset
109 $(foreach FPARCH, $(v8_fps), \
kono
parents: 67
diff changeset
110 march?armv7+fp=march?$(ARCH)+$(FPARCH)))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
111
111
kono
parents: 67
diff changeset
112 MULTILIB_MATCHES += $(foreach ARCH, armv7e-m armv8-m.mainline, \
kono
parents: 67
diff changeset
113 march?armv7+fp=march?$(ARCH)+fp.dp)
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
114
111
kono
parents: 67
diff changeset
115 # PART 4 - Reuse rules
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
116
111
kono
parents: 67
diff changeset
117 MULTILIB_REUSE += mthumb=mthumb/mfpu.auto
kono
parents: 67
diff changeset
118 MULTILIB_REUSE += mthumb=mthumb/mfpu.auto/march.armv5te+fp
kono
parents: 67
diff changeset
119 MULTILIB_REUSE += mthumb=mthumb/march.armv5te+fp
kono
parents: 67
diff changeset
120 MULTILIB_REUSE += marm/mfpu.auto/march.armv5te+fp/mfloat-abi.hard=marm/march.armv5te+fp/mfloat-abi.hard
kono
parents: 67
diff changeset
121 MULTILIB_REUSE += marm/mfpu.auto/march.armv5te+fp/mfloat-abi.hard=march.armv5te+fp/mfloat-abi.hard
kono
parents: 67
diff changeset
122 MULTILIB_REUSE += marm/mfpu.auto/march.armv5te+fp/mfloat-abi.hard=mfpu.auto/march.armv5te+fp/mfloat-abi.hard
kono
parents: 67
diff changeset
123 MULTILIB_REUSE += mthumb/mfpu.auto/march.armv7+fp/mfloat-abi.hard=mthumb/march.armv7+fp/mfloat-abi.hard
kono
parents: 67
diff changeset
124 MULTILIB_REUSE += mthumb/mfpu.auto/march.armv7+fp/mfloat-abi.hard=mfpu.auto/march.armv7+fp/mfloat-abi.hard
kono
parents: 67
diff changeset
125 MULTILIB_REUSE += mthumb/mfpu.auto/march.armv7+fp/mfloat-abi.hard=march.armv7+fp/mfloat-abi.hard