rs6000-cpus.def revision 1.4 1 1.1 mrg /* IBM RS/6000 CPU names..
2 1.4 mrg Copyright (C) 1991-2016 Free Software Foundation, Inc.
3 1.1 mrg Contributed by Richard Kenner (kenner (at) vlsi1.ultra.nyu.edu)
4 1.1 mrg
5 1.1 mrg This file is part of GCC.
6 1.1 mrg
7 1.1 mrg GCC is free software; you can redistribute it and/or modify it
8 1.1 mrg under the terms of the GNU General Public License as published
9 1.1 mrg by the Free Software Foundation; either version 3, or (at your
10 1.1 mrg option) any later version.
11 1.1 mrg
12 1.1 mrg GCC is distributed in the hope that it will be useful, but WITHOUT
13 1.1 mrg ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 1.1 mrg or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
15 1.1 mrg License for more details.
16 1.1 mrg
17 1.1 mrg You should have received a copy of the GNU General Public License
18 1.1 mrg along with GCC; see the file COPYING3. If not see
19 1.1 mrg <http://www.gnu.org/licenses/>. */
20 1.1 mrg
21 1.1 mrg /* ISA masks. */
22 1.1 mrg #ifndef ISA_2_1_MASKS
23 1.1 mrg #define ISA_2_1_MASKS OPTION_MASK_MFCRF
24 1.1 mrg #define ISA_2_2_MASKS (ISA_2_1_MASKS | OPTION_MASK_POPCNTB)
25 1.1 mrg #define ISA_2_4_MASKS (ISA_2_2_MASKS | OPTION_MASK_FPRND)
26 1.1 mrg
27 1.1 mrg /* For ISA 2.05, do not add MFPGPR, since it isn't in ISA 2.06, and don't add
28 1.1 mrg ALTIVEC, since in general it isn't a win on power6. In ISA 2.04, fsel,
29 1.1 mrg fre, fsqrt, etc. were no longer documented as optional. Group masks by
30 1.1 mrg server and embedded. */
31 1.1 mrg #define ISA_2_5_MASKS_EMBEDDED (ISA_2_4_MASKS \
32 1.1 mrg | OPTION_MASK_CMPB \
33 1.1 mrg | OPTION_MASK_RECIP_PRECISION \
34 1.1 mrg | OPTION_MASK_PPC_GFXOPT \
35 1.1 mrg | OPTION_MASK_PPC_GPOPT)
36 1.1 mrg
37 1.1 mrg #define ISA_2_5_MASKS_SERVER (ISA_2_5_MASKS_EMBEDDED | OPTION_MASK_DFP)
38 1.1 mrg
39 1.1 mrg /* For ISA 2.06, don't add ISEL, since in general it isn't a win, but
40 1.1 mrg altivec is a win so enable it. */
41 1.1 mrg /* OPTION_MASK_VSX_TIMODE should be set, but disable it for now until
42 1.1 mrg PR 58587 is fixed. */
43 1.1 mrg #define ISA_2_6_MASKS_EMBEDDED (ISA_2_5_MASKS_EMBEDDED | OPTION_MASK_POPCNTD)
44 1.1 mrg #define ISA_2_6_MASKS_SERVER (ISA_2_5_MASKS_SERVER \
45 1.1 mrg | OPTION_MASK_POPCNTD \
46 1.1 mrg | OPTION_MASK_ALTIVEC \
47 1.3 mrg | OPTION_MASK_VSX \
48 1.3 mrg | OPTION_MASK_UPPER_REGS_DF)
49 1.1 mrg
50 1.1 mrg /* For now, don't provide an embedded version of ISA 2.07. */
51 1.1 mrg #define ISA_2_7_MASKS_SERVER (ISA_2_6_MASKS_SERVER \
52 1.1 mrg | OPTION_MASK_P8_FUSION \
53 1.1 mrg | OPTION_MASK_P8_VECTOR \
54 1.1 mrg | OPTION_MASK_CRYPTO \
55 1.1 mrg | OPTION_MASK_DIRECT_MOVE \
56 1.3 mrg | OPTION_MASK_EFFICIENT_UNALIGNED_VSX \
57 1.1 mrg | OPTION_MASK_HTM \
58 1.1 mrg | OPTION_MASK_QUAD_MEMORY \
59 1.3 mrg | OPTION_MASK_QUAD_MEMORY_ATOMIC \
60 1.3 mrg | OPTION_MASK_UPPER_REGS_SF)
61 1.1 mrg
62 1.4 mrg /* Add ISEL back into ISA 3.0, since it is supposed to be a win. Do not add
63 1.4 mrg P9_MINMAX until the hardware that supports it is available. Do not add
64 1.4 mrg FLOAT128_HW here until we are ready to make -mfloat128 on by default. */
65 1.4 mrg #define ISA_3_0_MASKS_SERVER (ISA_2_7_MASKS_SERVER \
66 1.4 mrg | OPTION_MASK_ISEL \
67 1.4 mrg | OPTION_MASK_MODULO \
68 1.4 mrg | OPTION_MASK_P9_FUSION \
69 1.4 mrg | OPTION_MASK_P9_DFORM_SCALAR \
70 1.4 mrg | OPTION_MASK_P9_DFORM_VECTOR \
71 1.4 mrg | OPTION_MASK_P9_MISC \
72 1.4 mrg | OPTION_MASK_P9_VECTOR)
73 1.4 mrg
74 1.4 mrg /* Support for the IEEE 128-bit floating point hardware requires a lot of the
75 1.4 mrg VSX instructions that are part of ISA 3.0. */
76 1.4 mrg #define ISA_3_0_MASKS_IEEE (OPTION_MASK_VSX \
77 1.4 mrg | OPTION_MASK_P8_VECTOR \
78 1.4 mrg | OPTION_MASK_P9_VECTOR \
79 1.4 mrg | OPTION_MASK_DIRECT_MOVE \
80 1.4 mrg | OPTION_MASK_UPPER_REGS_DF \
81 1.4 mrg | OPTION_MASK_UPPER_REGS_SF)
82 1.4 mrg
83 1.1 mrg #define POWERPC_7400_MASK (OPTION_MASK_PPC_GFXOPT | OPTION_MASK_ALTIVEC)
84 1.1 mrg
85 1.1 mrg /* Deal with ports that do not have -mstrict-align. */
86 1.1 mrg #ifdef OPTION_MASK_STRICT_ALIGN
87 1.1 mrg #define OPTION_MASK_STRICT_ALIGN_OPTIONAL OPTION_MASK_STRICT_ALIGN
88 1.1 mrg #else
89 1.1 mrg #define OPTION_MASK_STRICT_ALIGN 0
90 1.1 mrg #define OPTION_MASK_STRICT_ALIGN_OPTIONAL 0
91 1.1 mrg #ifndef MASK_STRICT_ALIGN
92 1.1 mrg #define MASK_STRICT_ALIGN 0
93 1.1 mrg #endif
94 1.1 mrg #endif
95 1.1 mrg
96 1.1 mrg /* Mask of all options to set the default isa flags based on -mcpu=<xxx>. */
97 1.1 mrg #define POWERPC_MASKS (OPTION_MASK_ALTIVEC \
98 1.1 mrg | OPTION_MASK_CMPB \
99 1.1 mrg | OPTION_MASK_CRYPTO \
100 1.1 mrg | OPTION_MASK_DFP \
101 1.1 mrg | OPTION_MASK_DIRECT_MOVE \
102 1.1 mrg | OPTION_MASK_DLMZB \
103 1.3 mrg | OPTION_MASK_EFFICIENT_UNALIGNED_VSX \
104 1.4 mrg | OPTION_MASK_FLOAT128 \
105 1.1 mrg | OPTION_MASK_FPRND \
106 1.1 mrg | OPTION_MASK_HTM \
107 1.1 mrg | OPTION_MASK_ISEL \
108 1.4 mrg | OPTION_MASK_LRA \
109 1.1 mrg | OPTION_MASK_MFCRF \
110 1.1 mrg | OPTION_MASK_MFPGPR \
111 1.4 mrg | OPTION_MASK_MODULO \
112 1.1 mrg | OPTION_MASK_MULHW \
113 1.1 mrg | OPTION_MASK_NO_UPDATE \
114 1.1 mrg | OPTION_MASK_P8_FUSION \
115 1.1 mrg | OPTION_MASK_P8_VECTOR \
116 1.4 mrg | OPTION_MASK_P9_DFORM_SCALAR \
117 1.4 mrg | OPTION_MASK_P9_DFORM_VECTOR \
118 1.4 mrg | OPTION_MASK_P9_FUSION \
119 1.4 mrg | OPTION_MASK_P9_MINMAX \
120 1.4 mrg | OPTION_MASK_P9_MISC \
121 1.4 mrg | OPTION_MASK_P9_VECTOR \
122 1.1 mrg | OPTION_MASK_POPCNTB \
123 1.1 mrg | OPTION_MASK_POPCNTD \
124 1.1 mrg | OPTION_MASK_POWERPC64 \
125 1.1 mrg | OPTION_MASK_PPC_GFXOPT \
126 1.1 mrg | OPTION_MASK_PPC_GPOPT \
127 1.1 mrg | OPTION_MASK_QUAD_MEMORY \
128 1.1 mrg | OPTION_MASK_QUAD_MEMORY_ATOMIC \
129 1.1 mrg | OPTION_MASK_RECIP_PRECISION \
130 1.1 mrg | OPTION_MASK_SOFT_FLOAT \
131 1.1 mrg | OPTION_MASK_STRICT_ALIGN_OPTIONAL \
132 1.4 mrg | OPTION_MASK_TOC_FUSION \
133 1.3 mrg | OPTION_MASK_UPPER_REGS_DF \
134 1.3 mrg | OPTION_MASK_UPPER_REGS_SF \
135 1.1 mrg | OPTION_MASK_VSX \
136 1.1 mrg | OPTION_MASK_VSX_TIMODE)
137 1.1 mrg
138 1.1 mrg #endif
139 1.1 mrg
140 1.1 mrg /* This table occasionally claims that a processor does not support a
141 1.1 mrg particular feature even though it does, but the feature is slower than the
142 1.1 mrg alternative. Thus, it shouldn't be relied on as a complete description of
143 1.1 mrg the processor's support.
144 1.1 mrg
145 1.1 mrg Please keep this list in order, and don't forget to update the documentation
146 1.1 mrg in invoke.texi when adding a new processor or flag.
147 1.1 mrg
148 1.1 mrg Before including this file, define a macro:
149 1.1 mrg
150 1.1 mrg RS6000_CPU (NAME, CPU, FLAGS)
151 1.1 mrg
152 1.1 mrg where the arguments are the fields of struct rs6000_ptt. */
153 1.1 mrg
154 1.1 mrg RS6000_CPU ("401", PROCESSOR_PPC403, MASK_SOFT_FLOAT)
155 1.1 mrg RS6000_CPU ("403", PROCESSOR_PPC403, MASK_SOFT_FLOAT | MASK_STRICT_ALIGN)
156 1.1 mrg RS6000_CPU ("405", PROCESSOR_PPC405, MASK_SOFT_FLOAT | MASK_MULHW | MASK_DLMZB)
157 1.1 mrg RS6000_CPU ("405fp", PROCESSOR_PPC405, MASK_MULHW | MASK_DLMZB)
158 1.1 mrg RS6000_CPU ("440", PROCESSOR_PPC440, MASK_SOFT_FLOAT | MASK_MULHW | MASK_DLMZB)
159 1.1 mrg RS6000_CPU ("440fp", PROCESSOR_PPC440, MASK_MULHW | MASK_DLMZB)
160 1.1 mrg RS6000_CPU ("464", PROCESSOR_PPC440, MASK_SOFT_FLOAT | MASK_MULHW | MASK_DLMZB)
161 1.1 mrg RS6000_CPU ("464fp", PROCESSOR_PPC440, MASK_MULHW | MASK_DLMZB)
162 1.1 mrg RS6000_CPU ("476", PROCESSOR_PPC476,
163 1.1 mrg MASK_SOFT_FLOAT | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB
164 1.1 mrg | MASK_FPRND | MASK_CMPB | MASK_MULHW | MASK_DLMZB)
165 1.1 mrg RS6000_CPU ("476fp", PROCESSOR_PPC476,
166 1.1 mrg MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND
167 1.1 mrg | MASK_CMPB | MASK_MULHW | MASK_DLMZB)
168 1.1 mrg RS6000_CPU ("505", PROCESSOR_MPCCORE, 0)
169 1.1 mrg RS6000_CPU ("601", PROCESSOR_PPC601, MASK_MULTIPLE | MASK_STRING)
170 1.1 mrg RS6000_CPU ("602", PROCESSOR_PPC603, MASK_PPC_GFXOPT)
171 1.1 mrg RS6000_CPU ("603", PROCESSOR_PPC603, MASK_PPC_GFXOPT)
172 1.1 mrg RS6000_CPU ("603e", PROCESSOR_PPC603, MASK_PPC_GFXOPT)
173 1.1 mrg RS6000_CPU ("604", PROCESSOR_PPC604, MASK_PPC_GFXOPT)
174 1.1 mrg RS6000_CPU ("604e", PROCESSOR_PPC604e, MASK_PPC_GFXOPT)
175 1.1 mrg RS6000_CPU ("620", PROCESSOR_PPC620, MASK_PPC_GFXOPT | MASK_POWERPC64)
176 1.1 mrg RS6000_CPU ("630", PROCESSOR_PPC630, MASK_PPC_GFXOPT | MASK_POWERPC64)
177 1.1 mrg RS6000_CPU ("740", PROCESSOR_PPC750, MASK_PPC_GFXOPT)
178 1.1 mrg RS6000_CPU ("7400", PROCESSOR_PPC7400, POWERPC_7400_MASK)
179 1.1 mrg RS6000_CPU ("7450", PROCESSOR_PPC7450, POWERPC_7400_MASK)
180 1.1 mrg RS6000_CPU ("750", PROCESSOR_PPC750, MASK_PPC_GFXOPT)
181 1.1 mrg RS6000_CPU ("801", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT)
182 1.1 mrg RS6000_CPU ("821", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT)
183 1.1 mrg RS6000_CPU ("823", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT)
184 1.1 mrg RS6000_CPU ("8540", PROCESSOR_PPC8540, MASK_STRICT_ALIGN | MASK_ISEL)
185 1.1 mrg RS6000_CPU ("8548", PROCESSOR_PPC8548, MASK_STRICT_ALIGN | MASK_ISEL)
186 1.1 mrg RS6000_CPU ("a2", PROCESSOR_PPCA2,
187 1.1 mrg MASK_PPC_GFXOPT | MASK_POWERPC64 | MASK_POPCNTB | MASK_CMPB
188 1.1 mrg | MASK_NO_UPDATE)
189 1.1 mrg RS6000_CPU ("e300c2", PROCESSOR_PPCE300C2, MASK_SOFT_FLOAT)
190 1.1 mrg RS6000_CPU ("e300c3", PROCESSOR_PPCE300C3, 0)
191 1.1 mrg RS6000_CPU ("e500mc", PROCESSOR_PPCE500MC, MASK_PPC_GFXOPT | MASK_ISEL)
192 1.1 mrg RS6000_CPU ("e500mc64", PROCESSOR_PPCE500MC64,
193 1.1 mrg MASK_POWERPC64 | MASK_PPC_GFXOPT | MASK_ISEL)
194 1.1 mrg RS6000_CPU ("e5500", PROCESSOR_PPCE5500,
195 1.1 mrg MASK_POWERPC64 | MASK_PPC_GFXOPT | MASK_ISEL)
196 1.1 mrg RS6000_CPU ("e6500", PROCESSOR_PPCE6500, POWERPC_7400_MASK | MASK_POWERPC64
197 1.1 mrg | MASK_MFCRF | MASK_ISEL)
198 1.1 mrg RS6000_CPU ("860", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT)
199 1.1 mrg RS6000_CPU ("970", PROCESSOR_POWER4,
200 1.1 mrg POWERPC_7400_MASK | MASK_PPC_GPOPT | MASK_MFCRF | MASK_POWERPC64)
201 1.1 mrg RS6000_CPU ("cell", PROCESSOR_CELL,
202 1.1 mrg POWERPC_7400_MASK | MASK_PPC_GPOPT | MASK_MFCRF | MASK_POWERPC64)
203 1.1 mrg RS6000_CPU ("ec603e", PROCESSOR_PPC603, MASK_SOFT_FLOAT)
204 1.1 mrg RS6000_CPU ("G3", PROCESSOR_PPC750, MASK_PPC_GFXOPT)
205 1.1 mrg RS6000_CPU ("G4", PROCESSOR_PPC7450, POWERPC_7400_MASK)
206 1.1 mrg RS6000_CPU ("G5", PROCESSOR_POWER4,
207 1.1 mrg POWERPC_7400_MASK | MASK_PPC_GPOPT | MASK_MFCRF | MASK_POWERPC64)
208 1.1 mrg RS6000_CPU ("titan", PROCESSOR_TITAN, MASK_MULHW | MASK_DLMZB)
209 1.1 mrg RS6000_CPU ("power3", PROCESSOR_PPC630, MASK_PPC_GFXOPT | MASK_POWERPC64)
210 1.1 mrg RS6000_CPU ("power4", PROCESSOR_POWER4, MASK_POWERPC64 | MASK_PPC_GPOPT
211 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF)
212 1.1 mrg RS6000_CPU ("power5", PROCESSOR_POWER5, MASK_POWERPC64 | MASK_PPC_GPOPT
213 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB)
214 1.1 mrg RS6000_CPU ("power5+", PROCESSOR_POWER5, MASK_POWERPC64 | MASK_PPC_GPOPT
215 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND)
216 1.1 mrg RS6000_CPU ("power6", PROCESSOR_POWER6, MASK_POWERPC64 | MASK_PPC_GPOPT
217 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND
218 1.1 mrg | MASK_CMPB | MASK_DFP | MASK_RECIP_PRECISION)
219 1.1 mrg RS6000_CPU ("power6x", PROCESSOR_POWER6, MASK_POWERPC64 | MASK_PPC_GPOPT
220 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND
221 1.1 mrg | MASK_CMPB | MASK_DFP | MASK_MFPGPR | MASK_RECIP_PRECISION)
222 1.1 mrg RS6000_CPU ("power7", PROCESSOR_POWER7, /* Don't add MASK_ISEL by default */
223 1.1 mrg POWERPC_7400_MASK | MASK_POWERPC64 | MASK_PPC_GPOPT | MASK_MFCRF
224 1.1 mrg | MASK_POPCNTB | MASK_FPRND | MASK_CMPB | MASK_DFP | MASK_POPCNTD
225 1.3 mrg | MASK_VSX | MASK_RECIP_PRECISION | OPTION_MASK_UPPER_REGS_DF)
226 1.1 mrg RS6000_CPU ("power8", PROCESSOR_POWER8, MASK_POWERPC64 | ISA_2_7_MASKS_SERVER)
227 1.4 mrg RS6000_CPU ("power9", PROCESSOR_POWER9, MASK_POWERPC64 | ISA_3_0_MASKS_SERVER)
228 1.1 mrg RS6000_CPU ("powerpc", PROCESSOR_POWERPC, 0)
229 1.1 mrg RS6000_CPU ("powerpc64", PROCESSOR_POWERPC64, MASK_PPC_GFXOPT | MASK_POWERPC64)
230 1.1 mrg RS6000_CPU ("powerpc64le", PROCESSOR_POWER8, MASK_POWERPC64 | ISA_2_7_MASKS_SERVER)
231 1.1 mrg RS6000_CPU ("rs64", PROCESSOR_RS64A, MASK_PPC_GFXOPT | MASK_POWERPC64)
232