1 1.1 mrg /* IBM RS/6000 CPU names.. 2 1.10 mrg Copyright (C) 1991-2022 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.9 mrg /* For ISA 2.05, don't add ALTIVEC, since in general it isn't a win on 28 1.9 mrg power6. In ISA 2.04, fsel, fre, fsqrt, etc. were no longer documented 29 1.9 mrg as optional. Group masks by server and embedded. */ 30 1.1 mrg #define ISA_2_5_MASKS_EMBEDDED (ISA_2_4_MASKS \ 31 1.1 mrg | OPTION_MASK_CMPB \ 32 1.1 mrg | OPTION_MASK_RECIP_PRECISION \ 33 1.1 mrg | OPTION_MASK_PPC_GFXOPT \ 34 1.1 mrg | OPTION_MASK_PPC_GPOPT) 35 1.1 mrg 36 1.1 mrg #define ISA_2_5_MASKS_SERVER (ISA_2_5_MASKS_EMBEDDED | OPTION_MASK_DFP) 37 1.1 mrg 38 1.1 mrg /* For ISA 2.06, don't add ISEL, since in general it isn't a win, but 39 1.1 mrg altivec is a win so enable it. */ 40 1.1 mrg #define ISA_2_6_MASKS_EMBEDDED (ISA_2_5_MASKS_EMBEDDED | OPTION_MASK_POPCNTD) 41 1.1 mrg #define ISA_2_6_MASKS_SERVER (ISA_2_5_MASKS_SERVER \ 42 1.1 mrg | OPTION_MASK_POPCNTD \ 43 1.1 mrg | OPTION_MASK_ALTIVEC \ 44 1.7 mrg | OPTION_MASK_VSX) 45 1.1 mrg 46 1.8 mrg /* For now, don't provide an embedded version of ISA 2.07. Do not set power8 47 1.10 mrg fusion here, instead set it in rs6000.cc if we are tuning for a power8 48 1.8 mrg system. */ 49 1.1 mrg #define ISA_2_7_MASKS_SERVER (ISA_2_6_MASKS_SERVER \ 50 1.10 mrg | OPTION_MASK_POWER8 \ 51 1.1 mrg | OPTION_MASK_P8_VECTOR \ 52 1.1 mrg | OPTION_MASK_CRYPTO \ 53 1.3 mrg | OPTION_MASK_EFFICIENT_UNALIGNED_VSX \ 54 1.1 mrg | OPTION_MASK_QUAD_MEMORY \ 55 1.7 mrg | OPTION_MASK_QUAD_MEMORY_ATOMIC) 56 1.1 mrg 57 1.9 mrg /* ISA masks setting fusion options. */ 58 1.9 mrg #define OTHER_FUSION_MASKS (OPTION_MASK_P8_FUSION \ 59 1.9 mrg | OPTION_MASK_P8_FUSION_SIGN) 60 1.9 mrg 61 1.4 mrg /* Add ISEL back into ISA 3.0, since it is supposed to be a win. Do not add 62 1.4 mrg FLOAT128_HW here until we are ready to make -mfloat128 on by default. */ 63 1.9 mrg #define ISA_3_0_MASKS_SERVER ((ISA_2_7_MASKS_SERVER \ 64 1.9 mrg | OPTION_MASK_ISEL \ 65 1.9 mrg | OPTION_MASK_MODULO \ 66 1.9 mrg | OPTION_MASK_P9_MINMAX \ 67 1.9 mrg | OPTION_MASK_P9_MISC \ 68 1.9 mrg | OPTION_MASK_P9_VECTOR) \ 69 1.9 mrg & ~OTHER_FUSION_MASKS) 70 1.4 mrg 71 1.4 mrg /* Support for the IEEE 128-bit floating point hardware requires a lot of the 72 1.4 mrg VSX instructions that are part of ISA 3.0. */ 73 1.4 mrg #define ISA_3_0_MASKS_IEEE (OPTION_MASK_VSX \ 74 1.4 mrg | OPTION_MASK_P8_VECTOR \ 75 1.9 mrg | OPTION_MASK_P9_VECTOR) 76 1.9 mrg 77 1.9 mrg /* Flags that need to be turned off if -mno-power10. */ 78 1.10 mrg /* We comment out PCREL_OPT here to disable it by default because SPEC2017 79 1.10 mrg performance was degraded by it. */ 80 1.9 mrg #define OTHER_POWER10_MASKS (OPTION_MASK_MMA \ 81 1.9 mrg | OPTION_MASK_PCREL \ 82 1.10 mrg /* | OPTION_MASK_PCREL_OPT */ \ 83 1.9 mrg | OPTION_MASK_PREFIXED) 84 1.9 mrg 85 1.9 mrg #define ISA_3_1_MASKS_SERVER (ISA_3_0_MASKS_SERVER \ 86 1.9 mrg | OPTION_MASK_POWER10 \ 87 1.10 mrg | OTHER_POWER10_MASKS \ 88 1.10 mrg | OPTION_MASK_P10_FUSION) 89 1.6 mrg 90 1.6 mrg /* Flags that need to be turned off if -mno-power9-vector. */ 91 1.6 mrg #define OTHER_P9_VECTOR_MASKS (OPTION_MASK_FLOAT128_HW \ 92 1.6 mrg | OPTION_MASK_P9_MINMAX) 93 1.6 mrg 94 1.6 mrg /* Flags that need to be turned off if -mno-power8-vector. */ 95 1.6 mrg #define OTHER_P8_VECTOR_MASKS (OTHER_P9_VECTOR_MASKS \ 96 1.6 mrg | OPTION_MASK_P9_VECTOR \ 97 1.7 mrg | OPTION_MASK_CRYPTO) 98 1.6 mrg 99 1.6 mrg /* Flags that need to be turned off if -mno-vsx. */ 100 1.6 mrg #define OTHER_VSX_VECTOR_MASKS (OTHER_P8_VECTOR_MASKS \ 101 1.6 mrg | OPTION_MASK_EFFICIENT_UNALIGNED_VSX \ 102 1.6 mrg | OPTION_MASK_FLOAT128_KEYWORD \ 103 1.7 mrg | OPTION_MASK_P8_VECTOR) 104 1.4 mrg 105 1.9 mrg /* Flags that need to be turned off if -mno-altivec. */ 106 1.9 mrg #define OTHER_ALTIVEC_MASKS (OTHER_VSX_VECTOR_MASKS \ 107 1.9 mrg | OPTION_MASK_VSX) 108 1.9 mrg 109 1.1 mrg #define POWERPC_7400_MASK (OPTION_MASK_PPC_GFXOPT | OPTION_MASK_ALTIVEC) 110 1.1 mrg 111 1.1 mrg /* Deal with ports that do not have -mstrict-align. */ 112 1.1 mrg #ifdef OPTION_MASK_STRICT_ALIGN 113 1.1 mrg #define OPTION_MASK_STRICT_ALIGN_OPTIONAL OPTION_MASK_STRICT_ALIGN 114 1.1 mrg #else 115 1.1 mrg #define OPTION_MASK_STRICT_ALIGN 0 116 1.1 mrg #define OPTION_MASK_STRICT_ALIGN_OPTIONAL 0 117 1.1 mrg #ifndef MASK_STRICT_ALIGN 118 1.1 mrg #define MASK_STRICT_ALIGN 0 119 1.1 mrg #endif 120 1.1 mrg #endif 121 1.1 mrg 122 1.1 mrg /* Mask of all options to set the default isa flags based on -mcpu=<xxx>. */ 123 1.1 mrg #define POWERPC_MASKS (OPTION_MASK_ALTIVEC \ 124 1.1 mrg | OPTION_MASK_CMPB \ 125 1.1 mrg | OPTION_MASK_CRYPTO \ 126 1.1 mrg | OPTION_MASK_DFP \ 127 1.1 mrg | OPTION_MASK_DLMZB \ 128 1.3 mrg | OPTION_MASK_EFFICIENT_UNALIGNED_VSX \ 129 1.6 mrg | OPTION_MASK_FLOAT128_HW \ 130 1.6 mrg | OPTION_MASK_FLOAT128_KEYWORD \ 131 1.1 mrg | OPTION_MASK_FPRND \ 132 1.9 mrg | OPTION_MASK_POWER10 \ 133 1.10 mrg | OPTION_MASK_P10_FUSION \ 134 1.1 mrg | OPTION_MASK_HTM \ 135 1.1 mrg | OPTION_MASK_ISEL \ 136 1.1 mrg | OPTION_MASK_MFCRF \ 137 1.9 mrg | OPTION_MASK_MMA \ 138 1.4 mrg | OPTION_MASK_MODULO \ 139 1.1 mrg | OPTION_MASK_MULHW \ 140 1.1 mrg | OPTION_MASK_NO_UPDATE \ 141 1.10 mrg | OPTION_MASK_POWER8 \ 142 1.1 mrg | OPTION_MASK_P8_FUSION \ 143 1.1 mrg | OPTION_MASK_P8_VECTOR \ 144 1.4 mrg | OPTION_MASK_P9_MINMAX \ 145 1.4 mrg | OPTION_MASK_P9_MISC \ 146 1.4 mrg | OPTION_MASK_P9_VECTOR \ 147 1.9 mrg | OPTION_MASK_PCREL \ 148 1.10 mrg | OPTION_MASK_PCREL_OPT \ 149 1.1 mrg | OPTION_MASK_POPCNTB \ 150 1.1 mrg | OPTION_MASK_POPCNTD \ 151 1.1 mrg | OPTION_MASK_POWERPC64 \ 152 1.1 mrg | OPTION_MASK_PPC_GFXOPT \ 153 1.1 mrg | OPTION_MASK_PPC_GPOPT \ 154 1.9 mrg | OPTION_MASK_PREFIXED \ 155 1.1 mrg | OPTION_MASK_QUAD_MEMORY \ 156 1.1 mrg | OPTION_MASK_QUAD_MEMORY_ATOMIC \ 157 1.1 mrg | OPTION_MASK_RECIP_PRECISION \ 158 1.1 mrg | OPTION_MASK_SOFT_FLOAT \ 159 1.1 mrg | OPTION_MASK_STRICT_ALIGN_OPTIONAL \ 160 1.7 mrg | OPTION_MASK_VSX) 161 1.1 mrg 162 1.1 mrg #endif 163 1.1 mrg 164 1.1 mrg /* This table occasionally claims that a processor does not support a 165 1.1 mrg particular feature even though it does, but the feature is slower than the 166 1.1 mrg alternative. Thus, it shouldn't be relied on as a complete description of 167 1.1 mrg the processor's support. 168 1.1 mrg 169 1.1 mrg Please keep this list in order, and don't forget to update the documentation 170 1.1 mrg in invoke.texi when adding a new processor or flag. 171 1.1 mrg 172 1.1 mrg Before including this file, define a macro: 173 1.1 mrg 174 1.1 mrg RS6000_CPU (NAME, CPU, FLAGS) 175 1.1 mrg 176 1.1 mrg where the arguments are the fields of struct rs6000_ptt. */ 177 1.1 mrg 178 1.1 mrg RS6000_CPU ("401", PROCESSOR_PPC403, MASK_SOFT_FLOAT) 179 1.1 mrg RS6000_CPU ("403", PROCESSOR_PPC403, MASK_SOFT_FLOAT | MASK_STRICT_ALIGN) 180 1.1 mrg RS6000_CPU ("405", PROCESSOR_PPC405, MASK_SOFT_FLOAT | MASK_MULHW | MASK_DLMZB) 181 1.1 mrg RS6000_CPU ("405fp", PROCESSOR_PPC405, MASK_MULHW | MASK_DLMZB) 182 1.1 mrg RS6000_CPU ("440", PROCESSOR_PPC440, MASK_SOFT_FLOAT | MASK_MULHW | MASK_DLMZB) 183 1.1 mrg RS6000_CPU ("440fp", PROCESSOR_PPC440, MASK_MULHW | MASK_DLMZB) 184 1.1 mrg RS6000_CPU ("464", PROCESSOR_PPC440, MASK_SOFT_FLOAT | MASK_MULHW | MASK_DLMZB) 185 1.1 mrg RS6000_CPU ("464fp", PROCESSOR_PPC440, MASK_MULHW | MASK_DLMZB) 186 1.1 mrg RS6000_CPU ("476", PROCESSOR_PPC476, 187 1.1 mrg MASK_SOFT_FLOAT | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB 188 1.1 mrg | MASK_FPRND | MASK_CMPB | MASK_MULHW | MASK_DLMZB) 189 1.1 mrg RS6000_CPU ("476fp", PROCESSOR_PPC476, 190 1.1 mrg MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND 191 1.1 mrg | MASK_CMPB | MASK_MULHW | MASK_DLMZB) 192 1.1 mrg RS6000_CPU ("505", PROCESSOR_MPCCORE, 0) 193 1.7 mrg RS6000_CPU ("601", PROCESSOR_PPC601, MASK_MULTIPLE) 194 1.1 mrg RS6000_CPU ("602", PROCESSOR_PPC603, MASK_PPC_GFXOPT) 195 1.1 mrg RS6000_CPU ("603", PROCESSOR_PPC603, MASK_PPC_GFXOPT) 196 1.1 mrg RS6000_CPU ("603e", PROCESSOR_PPC603, MASK_PPC_GFXOPT) 197 1.1 mrg RS6000_CPU ("604", PROCESSOR_PPC604, MASK_PPC_GFXOPT) 198 1.1 mrg RS6000_CPU ("604e", PROCESSOR_PPC604e, MASK_PPC_GFXOPT) 199 1.1 mrg RS6000_CPU ("620", PROCESSOR_PPC620, MASK_PPC_GFXOPT | MASK_POWERPC64) 200 1.1 mrg RS6000_CPU ("630", PROCESSOR_PPC630, MASK_PPC_GFXOPT | MASK_POWERPC64) 201 1.1 mrg RS6000_CPU ("740", PROCESSOR_PPC750, MASK_PPC_GFXOPT) 202 1.1 mrg RS6000_CPU ("7400", PROCESSOR_PPC7400, POWERPC_7400_MASK) 203 1.1 mrg RS6000_CPU ("7450", PROCESSOR_PPC7450, POWERPC_7400_MASK) 204 1.1 mrg RS6000_CPU ("750", PROCESSOR_PPC750, MASK_PPC_GFXOPT) 205 1.1 mrg RS6000_CPU ("801", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT) 206 1.1 mrg RS6000_CPU ("821", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT) 207 1.1 mrg RS6000_CPU ("823", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT) 208 1.1 mrg RS6000_CPU ("8540", PROCESSOR_PPC8540, MASK_STRICT_ALIGN | MASK_ISEL) 209 1.1 mrg RS6000_CPU ("8548", PROCESSOR_PPC8548, MASK_STRICT_ALIGN | MASK_ISEL) 210 1.1 mrg RS6000_CPU ("a2", PROCESSOR_PPCA2, 211 1.1 mrg MASK_PPC_GFXOPT | MASK_POWERPC64 | MASK_POPCNTB | MASK_CMPB 212 1.1 mrg | MASK_NO_UPDATE) 213 1.1 mrg RS6000_CPU ("e300c2", PROCESSOR_PPCE300C2, MASK_SOFT_FLOAT) 214 1.1 mrg RS6000_CPU ("e300c3", PROCESSOR_PPCE300C3, 0) 215 1.1 mrg RS6000_CPU ("e500mc", PROCESSOR_PPCE500MC, MASK_PPC_GFXOPT | MASK_ISEL) 216 1.1 mrg RS6000_CPU ("e500mc64", PROCESSOR_PPCE500MC64, 217 1.1 mrg MASK_POWERPC64 | MASK_PPC_GFXOPT | MASK_ISEL) 218 1.1 mrg RS6000_CPU ("e5500", PROCESSOR_PPCE5500, 219 1.1 mrg MASK_POWERPC64 | MASK_PPC_GFXOPT | MASK_ISEL) 220 1.1 mrg RS6000_CPU ("e6500", PROCESSOR_PPCE6500, POWERPC_7400_MASK | MASK_POWERPC64 221 1.1 mrg | MASK_MFCRF | MASK_ISEL) 222 1.1 mrg RS6000_CPU ("860", PROCESSOR_MPCCORE, MASK_SOFT_FLOAT) 223 1.1 mrg RS6000_CPU ("970", PROCESSOR_POWER4, 224 1.1 mrg POWERPC_7400_MASK | MASK_PPC_GPOPT | MASK_MFCRF | MASK_POWERPC64) 225 1.1 mrg RS6000_CPU ("cell", PROCESSOR_CELL, 226 1.1 mrg POWERPC_7400_MASK | MASK_PPC_GPOPT | MASK_MFCRF | MASK_POWERPC64) 227 1.1 mrg RS6000_CPU ("ec603e", PROCESSOR_PPC603, MASK_SOFT_FLOAT) 228 1.1 mrg RS6000_CPU ("G3", PROCESSOR_PPC750, MASK_PPC_GFXOPT) 229 1.1 mrg RS6000_CPU ("G4", PROCESSOR_PPC7450, POWERPC_7400_MASK) 230 1.1 mrg RS6000_CPU ("G5", PROCESSOR_POWER4, 231 1.1 mrg POWERPC_7400_MASK | MASK_PPC_GPOPT | MASK_MFCRF | MASK_POWERPC64) 232 1.1 mrg RS6000_CPU ("titan", PROCESSOR_TITAN, MASK_MULHW | MASK_DLMZB) 233 1.1 mrg RS6000_CPU ("power3", PROCESSOR_PPC630, MASK_PPC_GFXOPT | MASK_POWERPC64) 234 1.1 mrg RS6000_CPU ("power4", PROCESSOR_POWER4, MASK_POWERPC64 | MASK_PPC_GPOPT 235 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF) 236 1.1 mrg RS6000_CPU ("power5", PROCESSOR_POWER5, MASK_POWERPC64 | MASK_PPC_GPOPT 237 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB) 238 1.1 mrg RS6000_CPU ("power5+", PROCESSOR_POWER5, MASK_POWERPC64 | MASK_PPC_GPOPT 239 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND) 240 1.1 mrg RS6000_CPU ("power6", PROCESSOR_POWER6, MASK_POWERPC64 | MASK_PPC_GPOPT 241 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND 242 1.1 mrg | MASK_CMPB | MASK_DFP | MASK_RECIP_PRECISION) 243 1.1 mrg RS6000_CPU ("power6x", PROCESSOR_POWER6, MASK_POWERPC64 | MASK_PPC_GPOPT 244 1.1 mrg | MASK_PPC_GFXOPT | MASK_MFCRF | MASK_POPCNTB | MASK_FPRND 245 1.9 mrg | MASK_CMPB | MASK_DFP | MASK_RECIP_PRECISION) 246 1.7 mrg RS6000_CPU ("power7", PROCESSOR_POWER7, MASK_POWERPC64 | ISA_2_6_MASKS_SERVER) 247 1.10 mrg RS6000_CPU ("power8", PROCESSOR_POWER8, MASK_POWERPC64 | ISA_2_7_MASKS_SERVER 248 1.10 mrg | OPTION_MASK_HTM) 249 1.10 mrg RS6000_CPU ("power9", PROCESSOR_POWER9, MASK_POWERPC64 | ISA_3_0_MASKS_SERVER 250 1.10 mrg | OPTION_MASK_HTM) 251 1.9 mrg RS6000_CPU ("power10", PROCESSOR_POWER10, MASK_POWERPC64 | ISA_3_1_MASKS_SERVER) 252 1.1 mrg RS6000_CPU ("powerpc", PROCESSOR_POWERPC, 0) 253 1.1 mrg RS6000_CPU ("powerpc64", PROCESSOR_POWERPC64, MASK_PPC_GFXOPT | MASK_POWERPC64) 254 1.10 mrg RS6000_CPU ("powerpc64le", PROCESSOR_POWER8, MASK_POWERPC64 | ISA_2_7_MASKS_SERVER 255 1.10 mrg | OPTION_MASK_HTM) 256 1.1 mrg RS6000_CPU ("rs64", PROCESSOR_RS64A, MASK_PPC_GFXOPT | MASK_POWERPC64) 257