/src/keystone/llvm/lib/Support/Triple.cpp
| Line | Count | Source (jump to first uncovered line) | 
| 1 |  | //===--- Triple.cpp - Target triple helper class --------------------------===// | 
| 2 |  | // | 
| 3 |  | //                     The LLVM Compiler Infrastructure | 
| 4 |  | // | 
| 5 |  | // This file is distributed under the University of Illinois Open Source | 
| 6 |  | // License. See LICENSE.TXT for details. | 
| 7 |  | // | 
| 8 |  | //===----------------------------------------------------------------------===// | 
| 9 |  |  | 
| 10 |  | #include "llvm/ADT/Triple.h" | 
| 11 |  | #include "llvm/ADT/STLExtras.h" | 
| 12 |  | #include "llvm/ADT/SmallString.h" | 
| 13 |  | #include "llvm/ADT/StringSwitch.h" | 
| 14 |  | #include "llvm/Support/ErrorHandling.h" | 
| 15 |  | #include "llvm/Support/TargetParser.h" | 
| 16 |  | #include "llvm/Support/Host.h" | 
| 17 |  | #include <cstring> | 
| 18 |  | using namespace llvm_ks; | 
| 19 |  |  | 
| 20 | 0 | const char *Triple::getArchTypeName(ArchType Kind) { | 
| 21 | 0 |   switch (Kind) { | 
| 22 | 0 |   case UnknownArch: return "unknown"; | 
| 23 |  |  | 
| 24 | 0 |   case aarch64:     return "aarch64"; | 
| 25 | 0 |   case aarch64_be:  return "aarch64_be"; | 
| 26 | 0 |   case arm:         return "arm"; | 
| 27 | 0 |   case armeb:       return "armeb"; | 
| 28 | 0 |   case avr:         return "avr"; | 
| 29 | 0 |   case bpfel:       return "bpfel"; | 
| 30 | 0 |   case bpfeb:       return "bpfeb"; | 
| 31 | 0 |   case hexagon:     return "hexagon"; | 
| 32 | 0 |   case mips:        return "mips"; | 
| 33 | 0 |   case mipsel:      return "mipsel"; | 
| 34 | 0 |   case mips64:      return "mips64"; | 
| 35 | 0 |   case mips64el:    return "mips64el"; | 
| 36 | 0 |   case msp430:      return "msp430"; | 
| 37 | 0 |   case ppc64:       return "powerpc64"; | 
| 38 | 0 |   case ppc64le:     return "powerpc64le"; | 
| 39 | 0 |   case ppc:         return "powerpc"; | 
| 40 | 0 |   case r600:        return "r600"; | 
| 41 | 0 |   case amdgcn:      return "amdgcn"; | 
| 42 | 0 |   case riscv32:     return "riscv32"; | 
| 43 | 0 |   case riscv64:     return "riscv64"; | 
| 44 | 0 |   case sparc:       return "sparc"; | 
| 45 | 0 |   case sparcv9:     return "sparcv9"; | 
| 46 | 0 |   case sparcel:     return "sparcel"; | 
| 47 | 0 |   case systemz:     return "s390x"; | 
| 48 | 0 |   case tce:         return "tce"; | 
| 49 | 0 |   case thumb:       return "thumb"; | 
| 50 | 0 |   case thumbeb:     return "thumbeb"; | 
| 51 | 0 |   case x86:         return "i386"; | 
| 52 | 0 |   case x86_64:      return "x86_64"; | 
| 53 | 0 |   case xcore:       return "xcore"; | 
| 54 | 0 |   case nvptx:       return "nvptx"; | 
| 55 | 0 |   case nvptx64:     return "nvptx64"; | 
| 56 | 0 |   case le32:        return "le32"; | 
| 57 | 0 |   case le64:        return "le64"; | 
| 58 | 0 |   case amdil:       return "amdil"; | 
| 59 | 0 |   case amdil64:     return "amdil64"; | 
| 60 | 0 |   case hsail:       return "hsail"; | 
| 61 | 0 |   case hsail64:     return "hsail64"; | 
| 62 | 0 |   case spir:        return "spir"; | 
| 63 | 0 |   case spir64:      return "spir64"; | 
| 64 | 0 |   case kalimba:     return "kalimba"; | 
| 65 | 0 |   case shave:       return "shave"; | 
| 66 | 0 |   case wasm32:      return "wasm32"; | 
| 67 | 0 |   case wasm64:      return "wasm64"; | 
| 68 | 0 |   } | 
| 69 |  |  | 
| 70 | 0 |   llvm_unreachable("Invalid ArchType!"); | 
| 71 | 0 | } | 
| 72 |  |  | 
| 73 | 0 | const char *Triple::getArchTypePrefix(ArchType Kind) { | 
| 74 | 0 |   switch (Kind) { | 
| 75 | 0 |   default: | 
| 76 | 0 |     return nullptr; | 
| 77 |  |  | 
| 78 | 0 |   case aarch64: | 
| 79 | 0 |   case aarch64_be:  return "aarch64"; | 
| 80 |  |  | 
| 81 | 0 |   case arm: | 
| 82 | 0 |   case armeb: | 
| 83 | 0 |   case thumb: | 
| 84 | 0 |   case thumbeb:     return "arm"; | 
| 85 |  |  | 
| 86 | 0 |   case avr:         return "avr"; | 
| 87 |  |  | 
| 88 | 0 |   case ppc64: | 
| 89 | 0 |   case ppc64le: | 
| 90 | 0 |   case ppc:         return "ppc"; | 
| 91 |  |  | 
| 92 | 0 |   case mips: | 
| 93 | 0 |   case mipsel: | 
| 94 | 0 |   case mips64: | 
| 95 | 0 |   case mips64el:    return "mips"; | 
| 96 |  |  | 
| 97 | 0 |   case hexagon:     return "hexagon"; | 
| 98 |  |  | 
| 99 | 0 |   case amdgcn:      return "amdgcn"; | 
| 100 | 0 |   case r600:        return "r600"; | 
| 101 |  |  | 
| 102 | 0 |   case bpfel: | 
| 103 | 0 |   case bpfeb:       return "bpf"; | 
| 104 |  |  | 
| 105 | 0 |   case sparcv9: | 
| 106 | 0 |   case sparcel: | 
| 107 | 0 |   case sparc:       return "sparc"; | 
| 108 |  |  | 
| 109 | 0 |   case systemz:     return "s390"; | 
| 110 |  |  | 
| 111 | 0 |   case x86: | 
| 112 | 0 |   case x86_64:      return "x86"; | 
| 113 |  |  | 
| 114 | 0 |   case xcore:       return "xcore"; | 
| 115 |  |  | 
| 116 | 0 |   case nvptx:       return "nvptx"; | 
| 117 | 0 |   case nvptx64:     return "nvptx"; | 
| 118 |  |  | 
| 119 | 0 |   case le32:        return "le32"; | 
| 120 | 0 |   case le64:        return "le64"; | 
| 121 |  |  | 
| 122 | 0 |   case amdil: | 
| 123 | 0 |   case amdil64:     return "amdil"; | 
| 124 |  |  | 
| 125 | 0 |   case hsail: | 
| 126 | 0 |   case hsail64:     return "hsail"; | 
| 127 |  |  | 
| 128 | 0 |   case spir: | 
| 129 | 0 |   case spir64:      return "spir"; | 
| 130 | 0 |   case kalimba:     return "kalimba"; | 
| 131 | 0 |   case shave:       return "shave"; | 
| 132 | 0 |   case wasm32: | 
| 133 | 0 |   case wasm64:      return "wasm"; | 
| 134 | 0 |   case riscv32: | 
| 135 | 0 |   case riscv64:     return "riscv"; | 
| 136 | 0 |   } | 
| 137 | 0 | } | 
| 138 |  |  | 
| 139 | 0 | const char *Triple::getVendorTypeName(VendorType Kind) { | 
| 140 | 0 |   switch (Kind) { | 
| 141 | 0 |   case UnknownVendor: return "unknown"; | 
| 142 |  |  | 
| 143 | 0 |   case Apple: return "apple"; | 
| 144 | 0 |   case PC: return "pc"; | 
| 145 | 0 |   case SCEI: return "scei"; | 
| 146 | 0 |   case BGP: return "bgp"; | 
| 147 | 0 |   case BGQ: return "bgq"; | 
| 148 | 0 |   case Freescale: return "fsl"; | 
| 149 | 0 |   case IBM: return "ibm"; | 
| 150 | 0 |   case ImaginationTechnologies: return "img"; | 
| 151 | 0 |   case MipsTechnologies: return "mti"; | 
| 152 | 0 |   case NVIDIA: return "nvidia"; | 
| 153 | 0 |   case CSR: return "csr"; | 
| 154 | 0 |   case Myriad: return "myriad"; | 
| 155 | 0 |   } | 
| 156 |  |  | 
| 157 | 0 |   llvm_unreachable("Invalid VendorType!"); | 
| 158 | 0 | } | 
| 159 |  |  | 
| 160 | 0 | const char *Triple::getOSTypeName(OSType Kind) { | 
| 161 | 0 |   switch (Kind) { | 
| 162 | 0 |   case UnknownOS: return "unknown"; | 
| 163 |  |  | 
| 164 | 0 |   case CloudABI: return "cloudabi"; | 
| 165 | 0 |   case Darwin: return "darwin"; | 
| 166 | 0 |   case DragonFly: return "dragonfly"; | 
| 167 | 0 |   case FreeBSD: return "freebsd"; | 
| 168 | 0 |   case IOS: return "ios"; | 
| 169 | 0 |   case KFreeBSD: return "kfreebsd"; | 
| 170 | 0 |   case Linux: return "linux"; | 
| 171 | 0 |   case Lv2: return "lv2"; | 
| 172 | 0 |   case MacOSX: return "macosx"; | 
| 173 | 0 |   case NetBSD: return "netbsd"; | 
| 174 | 0 |   case OpenBSD: return "openbsd"; | 
| 175 | 0 |   case Solaris: return "solaris"; | 
| 176 | 0 |   case Win32: return "windows"; | 
| 177 | 0 |   case Haiku: return "haiku"; | 
| 178 | 0 |   case Minix: return "minix"; | 
| 179 | 0 |   case RTEMS: return "rtems"; | 
| 180 | 0 |   case NaCl: return "nacl"; | 
| 181 | 0 |   case CNK: return "cnk"; | 
| 182 | 0 |   case Bitrig: return "bitrig"; | 
| 183 | 0 |   case AIX: return "aix"; | 
| 184 | 0 |   case CUDA: return "cuda"; | 
| 185 | 0 |   case NVCL: return "nvcl"; | 
| 186 | 0 |   case AMDHSA: return "amdhsa"; | 
| 187 | 0 |   case PS4: return "ps4"; | 
| 188 | 0 |   case ELFIAMCU: return "elfiamcu"; | 
| 189 | 0 |   case TvOS: return "tvos"; | 
| 190 | 0 |   case WatchOS: return "watchos"; | 
| 191 | 0 |   } | 
| 192 |  |  | 
| 193 | 0 |   llvm_unreachable("Invalid OSType"); | 
| 194 | 0 | } | 
| 195 |  |  | 
| 196 | 0 | const char *Triple::getEnvironmentTypeName(EnvironmentType Kind) { | 
| 197 | 0 |   switch (Kind) { | 
| 198 | 0 |   case UnknownEnvironment: return "unknown"; | 
| 199 | 0 |   case GNU: return "gnu"; | 
| 200 | 0 |   case GNUEABIHF: return "gnueabihf"; | 
| 201 | 0 |   case GNUEABI: return "gnueabi"; | 
| 202 | 0 |   case GNUX32: return "gnux32"; | 
| 203 | 0 |   case CODE16: return "code16"; | 
| 204 | 0 |   case EABI: return "eabi"; | 
| 205 | 0 |   case EABIHF: return "eabihf"; | 
| 206 | 0 |   case Android: return "android"; | 
| 207 | 0 |   case MSVC: return "msvc"; | 
| 208 | 0 |   case Itanium: return "itanium"; | 
| 209 | 0 |   case Cygnus: return "cygnus"; | 
| 210 | 0 |   case AMDOpenCL: return "amdopencl"; | 
| 211 | 0 |   case CoreCLR: return "coreclr"; | 
| 212 | 0 |   } | 
| 213 |  |  | 
| 214 | 0 |   llvm_unreachable("Invalid EnvironmentType!"); | 
| 215 | 0 | } | 
| 216 |  |  | 
| 217 | 0 | static Triple::ArchType parseBPFArch(StringRef ArchName) { | 
| 218 | 0 |   if (ArchName.equals("bpf")) { | 
| 219 | 0 |     if (sys::IsLittleEndianHost) | 
| 220 | 0 |       return Triple::bpfel; | 
| 221 | 0 |     else | 
| 222 | 0 |       return Triple::bpfeb; | 
| 223 | 0 |   } else if (ArchName.equals("bpf_be") || ArchName.equals("bpfeb")) { | 
| 224 | 0 |     return Triple::bpfeb; | 
| 225 | 0 |   } else if (ArchName.equals("bpf_le") || ArchName.equals("bpfel")) { | 
| 226 | 0 |     return Triple::bpfel; | 
| 227 | 0 |   } else { | 
| 228 | 0 |     return Triple::UnknownArch; | 
| 229 | 0 |   } | 
| 230 | 0 | } | 
| 231 |  |  | 
| 232 | 0 | Triple::ArchType Triple::getArchTypeForLLVMName(StringRef Name) { | 
| 233 | 0 |   Triple::ArchType BPFArch(parseBPFArch(Name)); | 
| 234 | 0 |   return StringSwitch<Triple::ArchType>(Name) | 
| 235 | 0 |     .Case("aarch64", aarch64) | 
| 236 | 0 |     .Case("aarch64_be", aarch64_be) | 
| 237 | 0 |     .Case("arm64", aarch64) // "arm64" is an alias for "aarch64" | 
| 238 | 0 |     .Case("arm", arm) | 
| 239 | 0 |     .Case("armeb", armeb) | 
| 240 | 0 |     .Case("avr", avr) | 
| 241 | 0 |     .StartsWith("bpf", BPFArch) | 
| 242 | 0 |     .Case("mips", mips) | 
| 243 | 0 |     .Case("mipsel", mipsel) | 
| 244 | 0 |     .Case("mips64", mips64) | 
| 245 | 0 |     .Case("mips64el", mips64el) | 
| 246 | 0 |     .Case("msp430", msp430) | 
| 247 | 0 |     .Case("ppc64", ppc64) | 
| 248 | 0 |     .Case("ppc32", ppc) | 
| 249 | 0 |     .Case("ppc", ppc) | 
| 250 | 0 |     .Case("ppc64le", ppc64le) | 
| 251 | 0 |     .Case("r600", r600) | 
| 252 | 0 |     .Case("amdgcn", amdgcn) | 
| 253 | 0 |     .Case("riscv32", riscv32) | 
| 254 | 0 |     .Case("riscv64", riscv64) | 
| 255 | 0 |     .Case("hexagon", hexagon) | 
| 256 | 0 |     .Case("sparc", sparc) | 
| 257 | 0 |     .Case("sparcel", sparcel) | 
| 258 | 0 |     .Case("sparcv9", sparcv9) | 
| 259 | 0 |     .Case("systemz", systemz) | 
| 260 | 0 |     .Case("tce", tce) | 
| 261 | 0 |     .Case("thumb", thumb) | 
| 262 | 0 |     .Case("thumbeb", thumbeb) | 
| 263 | 0 |     .Case("x86", x86) | 
| 264 | 0 |     .Case("x86-64", x86_64) | 
| 265 | 0 |     .Case("xcore", xcore) | 
| 266 | 0 |     .Case("nvptx", nvptx) | 
| 267 | 0 |     .Case("nvptx64", nvptx64) | 
| 268 | 0 |     .Case("le32", le32) | 
| 269 | 0 |     .Case("le64", le64) | 
| 270 | 0 |     .Case("amdil", amdil) | 
| 271 | 0 |     .Case("amdil64", amdil64) | 
| 272 | 0 |     .Case("hsail", hsail) | 
| 273 | 0 |     .Case("hsail64", hsail64) | 
| 274 | 0 |     .Case("spir", spir) | 
| 275 | 0 |     .Case("spir64", spir64) | 
| 276 | 0 |     .Case("kalimba", kalimba) | 
| 277 | 0 |     .Case("shave", shave) | 
| 278 | 0 |     .Case("wasm32", wasm32) | 
| 279 | 0 |     .Case("wasm64", wasm64) | 
| 280 | 0 |     .Default(UnknownArch); | 
| 281 | 0 | } | 
| 282 |  |  | 
| 283 | 496k | static Triple::ArchType parseARMArch(StringRef ArchName) { | 
| 284 | 496k |   unsigned ISA = ARM::parseArchISA(ArchName); | 
| 285 | 496k |   unsigned ENDIAN = ARM::parseArchEndian(ArchName); | 
| 286 |  |  | 
| 287 | 496k |   Triple::ArchType arch = Triple::UnknownArch; | 
| 288 | 496k |   switch (ENDIAN) { | 
| 289 | 303k |   case ARM::EK_LITTLE: { | 
| 290 | 303k |     switch (ISA) { | 
| 291 | 151k |     case ARM::IK_ARM: | 
| 292 | 151k |       arch = Triple::arm; | 
| 293 | 151k |       break; | 
| 294 | 152k |     case ARM::IK_THUMB: | 
| 295 | 152k |       arch = Triple::thumb; | 
| 296 | 152k |       break; | 
| 297 | 0 |     case ARM::IK_AARCH64: | 
| 298 | 0 |       arch = Triple::aarch64; | 
| 299 | 0 |       break; | 
| 300 | 303k |     } | 
| 301 | 303k |     break; | 
| 302 | 303k |   } | 
| 303 | 303k |   case ARM::EK_BIG: { | 
| 304 | 193k |     switch (ISA) { | 
| 305 | 77.5k |     case ARM::IK_ARM: | 
| 306 | 77.5k |       arch = Triple::armeb; | 
| 307 | 77.5k |       break; | 
| 308 | 115k |     case ARM::IK_THUMB: | 
| 309 | 115k |       arch = Triple::thumbeb; | 
| 310 | 115k |       break; | 
| 311 | 0 |     case ARM::IK_AARCH64: | 
| 312 | 0 |       arch = Triple::aarch64_be; | 
| 313 | 0 |       break; | 
| 314 | 193k |     } | 
| 315 | 193k |     break; | 
| 316 | 193k |   } | 
| 317 | 496k |   } | 
| 318 |  |  | 
| 319 | 496k |   ArchName = ARM::getCanonicalArchName(ArchName); | 
| 320 | 496k |   if (ArchName.empty()) | 
| 321 | 0 |     return Triple::UnknownArch; | 
| 322 |  |  | 
| 323 |  |   // Thumb only exists in v4+ | 
| 324 | 496k |   if (ISA == ARM::IK_THUMB && | 
| 325 | 496k |       (ArchName.startswith("v2") || ArchName.startswith("v3"))) | 
| 326 | 0 |     return Triple::UnknownArch; | 
| 327 |  |  | 
| 328 |  |   // Thumb only for v6m | 
| 329 | 496k |   unsigned Profile = ARM::parseArchProfile(ArchName); | 
| 330 | 496k |   unsigned Version = ARM::parseArchVersion(ArchName); | 
| 331 | 496k |   if (Profile == ARM::PK_M && Version == 6) { | 
| 332 | 0 |     if (ENDIAN == ARM::EK_BIG) | 
| 333 | 0 |       return Triple::thumbeb; | 
| 334 | 0 |     else | 
| 335 | 0 |       return Triple::thumb; | 
| 336 | 0 |   } | 
| 337 |  |  | 
| 338 | 496k |   return arch; | 
| 339 | 496k | } | 
| 340 |  |  | 
| 341 | 1.11M | static Triple::ArchType parseArch(StringRef ArchName) { | 
| 342 | 1.11M |   auto AT = StringSwitch<Triple::ArchType>(ArchName) | 
| 343 | 1.11M |     .Cases("i386", "i486", "i586", "i686", Triple::x86) | 
| 344 |  |     // FIXME: Do we need to support these? | 
| 345 | 1.11M |     .Cases("i786", "i886", "i986", Triple::x86) | 
| 346 | 1.11M |     .Cases("amd64", "x86_64", "x86_64h", Triple::x86_64) | 
| 347 | 1.11M |     .Cases("powerpc", "ppc32", Triple::ppc) | 
| 348 | 1.11M |     .Cases("powerpc64", "ppu", "ppc64", Triple::ppc64) | 
| 349 | 1.11M |     .Cases("powerpc64le", "ppc64le", Triple::ppc64le) | 
| 350 | 1.11M |     .Case("xscale", Triple::arm) | 
| 351 | 1.11M |     .Case("xscaleeb", Triple::armeb) | 
| 352 | 1.11M |     .Case("aarch64", Triple::aarch64) | 
| 353 | 1.11M |     .Case("aarch64_be", Triple::aarch64_be) | 
| 354 | 1.11M |     .Case("arm64", Triple::aarch64) | 
| 355 | 1.11M |     .Case("arm", Triple::arm) | 
| 356 | 1.11M |     .Case("armeb", Triple::armeb) | 
| 357 | 1.11M |     .Case("thumb", Triple::thumb) | 
| 358 | 1.11M |     .Case("thumbeb", Triple::thumbeb) | 
| 359 | 1.11M |     .Case("avr", Triple::avr) | 
| 360 | 1.11M |     .Case("msp430", Triple::msp430) | 
| 361 | 1.11M |     .Cases("mips", "mipseb", "mipsallegrex", Triple::mips) | 
| 362 | 1.11M |     .Cases("mipsel", "mipsallegrexel", Triple::mipsel) | 
| 363 | 1.11M |     .Cases("mips64", "mips64eb", Triple::mips64) | 
| 364 | 1.11M |     .Case("mips64el", Triple::mips64el) | 
| 365 | 1.11M |     .Case("r600", Triple::r600) | 
| 366 | 1.11M |     .Case("amdgcn", Triple::amdgcn) | 
| 367 | 1.11M |     .Case("riscv32", Triple::riscv32) | 
| 368 | 1.11M |     .Case("riscv64", Triple::riscv64) | 
| 369 | 1.11M |     .Case("hexagon", Triple::hexagon) | 
| 370 | 1.11M |     .Cases("s390x", "systemz", Triple::systemz) | 
| 371 | 1.11M |     .Case("sparc", Triple::sparc) | 
| 372 | 1.11M |     .Case("sparcel", Triple::sparcel) | 
| 373 | 1.11M |     .Cases("sparcv9", "sparc64", Triple::sparcv9) | 
| 374 | 1.11M |     .Case("tce", Triple::tce) | 
| 375 | 1.11M |     .Case("xcore", Triple::xcore) | 
| 376 | 1.11M |     .Case("nvptx", Triple::nvptx) | 
| 377 | 1.11M |     .Case("nvptx64", Triple::nvptx64) | 
| 378 | 1.11M |     .Case("le32", Triple::le32) | 
| 379 | 1.11M |     .Case("le64", Triple::le64) | 
| 380 | 1.11M |     .Case("amdil", Triple::amdil) | 
| 381 | 1.11M |     .Case("amdil64", Triple::amdil64) | 
| 382 | 1.11M |     .Case("hsail", Triple::hsail) | 
| 383 | 1.11M |     .Case("hsail64", Triple::hsail64) | 
| 384 | 1.11M |     .Case("spir", Triple::spir) | 
| 385 | 1.11M |     .Case("spir64", Triple::spir64) | 
| 386 | 1.11M |     .StartsWith("kalimba", Triple::kalimba) | 
| 387 | 1.11M |     .Case("shave", Triple::shave) | 
| 388 | 1.11M |     .Case("wasm32", Triple::wasm32) | 
| 389 | 1.11M |     .Case("wasm64", Triple::wasm64) | 
| 390 | 1.11M |     .Default(Triple::UnknownArch); | 
| 391 |  |  | 
| 392 |  |   // Some architectures require special parsing logic just to compute the | 
| 393 |  |   // ArchType result. | 
| 394 | 1.11M |   if (AT == Triple::UnknownArch) { | 
| 395 | 496k |     if (ArchName.startswith("arm") || ArchName.startswith("thumb") || | 
| 396 | 496k |         ArchName.startswith("aarch64")) | 
| 397 | 496k |       return parseARMArch(ArchName); | 
| 398 | 0 |     if (ArchName.startswith("bpf")) | 
| 399 | 0 |       return parseBPFArch(ArchName); | 
| 400 | 0 |   } | 
| 401 |  |  | 
| 402 | 616k |   return AT; | 
| 403 | 1.11M | } | 
| 404 |  |  | 
| 405 | 131k | static Triple::VendorType parseVendor(StringRef VendorName) { | 
| 406 | 131k |   return StringSwitch<Triple::VendorType>(VendorName) | 
| 407 | 131k |     .Case("apple", Triple::Apple) | 
| 408 | 131k |     .Case("pc", Triple::PC) | 
| 409 | 131k |     .Case("scei", Triple::SCEI) | 
| 410 | 131k |     .Case("bgp", Triple::BGP) | 
| 411 | 131k |     .Case("bgq", Triple::BGQ) | 
| 412 | 131k |     .Case("fsl", Triple::Freescale) | 
| 413 | 131k |     .Case("ibm", Triple::IBM) | 
| 414 | 131k |     .Case("img", Triple::ImaginationTechnologies) | 
| 415 | 131k |     .Case("mti", Triple::MipsTechnologies) | 
| 416 | 131k |     .Case("nvidia", Triple::NVIDIA) | 
| 417 | 131k |     .Case("csr", Triple::CSR) | 
| 418 | 131k |     .Case("myriad", Triple::Myriad) | 
| 419 | 131k |     .Default(Triple::UnknownVendor); | 
| 420 | 131k | } | 
| 421 |  |  | 
| 422 | 131k | static Triple::OSType parseOS(StringRef OSName) { | 
| 423 | 131k |   return StringSwitch<Triple::OSType>(OSName) | 
| 424 | 131k |     .StartsWith("cloudabi", Triple::CloudABI) | 
| 425 | 131k |     .StartsWith("darwin", Triple::Darwin) | 
| 426 | 131k |     .StartsWith("dragonfly", Triple::DragonFly) | 
| 427 | 131k |     .StartsWith("freebsd", Triple::FreeBSD) | 
| 428 | 131k |     .StartsWith("ios", Triple::IOS) | 
| 429 | 131k |     .StartsWith("kfreebsd", Triple::KFreeBSD) | 
| 430 | 131k |     .StartsWith("linux", Triple::Linux) | 
| 431 | 131k |     .StartsWith("lv2", Triple::Lv2) | 
| 432 | 131k |     .StartsWith("macosx", Triple::MacOSX) | 
| 433 | 131k |     .StartsWith("netbsd", Triple::NetBSD) | 
| 434 | 131k |     .StartsWith("openbsd", Triple::OpenBSD) | 
| 435 | 131k |     .StartsWith("solaris", Triple::Solaris) | 
| 436 | 131k |     .StartsWith("win32", Triple::Win32) | 
| 437 | 131k |     .StartsWith("windows", Triple::Win32) | 
| 438 | 131k |     .StartsWith("haiku", Triple::Haiku) | 
| 439 | 131k |     .StartsWith("minix", Triple::Minix) | 
| 440 | 131k |     .StartsWith("rtems", Triple::RTEMS) | 
| 441 | 131k |     .StartsWith("nacl", Triple::NaCl) | 
| 442 | 131k |     .StartsWith("cnk", Triple::CNK) | 
| 443 | 131k |     .StartsWith("bitrig", Triple::Bitrig) | 
| 444 | 131k |     .StartsWith("aix", Triple::AIX) | 
| 445 | 131k |     .StartsWith("cuda", Triple::CUDA) | 
| 446 | 131k |     .StartsWith("nvcl", Triple::NVCL) | 
| 447 | 131k |     .StartsWith("amdhsa", Triple::AMDHSA) | 
| 448 | 131k |     .StartsWith("ps4", Triple::PS4) | 
| 449 | 131k |     .StartsWith("elfiamcu", Triple::ELFIAMCU) | 
| 450 | 131k |     .StartsWith("tvos", Triple::TvOS) | 
| 451 | 131k |     .StartsWith("watchos", Triple::WatchOS) | 
| 452 | 131k |     .Default(Triple::UnknownOS); | 
| 453 | 131k | } | 
| 454 |  |  | 
| 455 | 109k | static Triple::EnvironmentType parseEnvironment(StringRef EnvironmentName) { | 
| 456 | 109k |   return StringSwitch<Triple::EnvironmentType>(EnvironmentName) | 
| 457 | 109k |     .StartsWith("eabihf", Triple::EABIHF) | 
| 458 | 109k |     .StartsWith("eabi", Triple::EABI) | 
| 459 | 109k |     .StartsWith("gnueabihf", Triple::GNUEABIHF) | 
| 460 | 109k |     .StartsWith("gnueabi", Triple::GNUEABI) | 
| 461 | 109k |     .StartsWith("gnux32", Triple::GNUX32) | 
| 462 | 109k |     .StartsWith("code16", Triple::CODE16) | 
| 463 | 109k |     .StartsWith("gnu", Triple::GNU) | 
| 464 | 109k |     .StartsWith("android", Triple::Android) | 
| 465 | 109k |     .StartsWith("msvc", Triple::MSVC) | 
| 466 | 109k |     .StartsWith("itanium", Triple::Itanium) | 
| 467 | 109k |     .StartsWith("cygnus", Triple::Cygnus) | 
| 468 | 109k |     .StartsWith("amdopencl", Triple::AMDOpenCL) | 
| 469 | 109k |     .StartsWith("coreclr", Triple::CoreCLR) | 
| 470 | 109k |     .Default(Triple::UnknownEnvironment); | 
| 471 | 109k | } | 
| 472 |  |  | 
| 473 | 98.6k | static Triple::ObjectFormatType parseFormat(StringRef EnvironmentName) { | 
| 474 | 98.6k |   return StringSwitch<Triple::ObjectFormatType>(EnvironmentName) | 
| 475 | 98.6k |     .EndsWith("coff", Triple::COFF) | 
| 476 | 98.6k |     .EndsWith("elf", Triple::ELF) | 
| 477 | 98.6k |     .EndsWith("macho", Triple::MachO) | 
| 478 | 98.6k |     .Default(Triple::UnknownObjectFormat); | 
| 479 | 98.6k | } | 
| 480 |  |  | 
| 481 | 1.00M | static Triple::SubArchType parseSubArch(StringRef SubArchName) { | 
| 482 | 1.00M |   StringRef ARMSubArch = ARM::getCanonicalArchName(SubArchName); | 
| 483 |  |  | 
| 484 |  |   // For now, this is the small part. Early return. | 
| 485 | 1.00M |   if (ARMSubArch.empty()) | 
| 486 | 0 |     return StringSwitch<Triple::SubArchType>(SubArchName) | 
| 487 | 0 |       .EndsWith("kalimba3", Triple::KalimbaSubArch_v3) | 
| 488 | 0 |       .EndsWith("kalimba4", Triple::KalimbaSubArch_v4) | 
| 489 | 0 |       .EndsWith("kalimba5", Triple::KalimbaSubArch_v5) | 
| 490 | 0 |       .Default(Triple::NoSubArch); | 
| 491 |  |  | 
| 492 |  |   // ARM sub arch. | 
| 493 | 1.00M |   switch(ARM::parseArch(ARMSubArch)) { | 
| 494 | 0 |   case ARM::AK_ARMV4: | 
| 495 | 0 |     return Triple::NoSubArch; | 
| 496 | 0 |   case ARM::AK_ARMV4T: | 
| 497 | 0 |     return Triple::ARMSubArch_v4t; | 
| 498 | 0 |   case ARM::AK_ARMV5T: | 
| 499 | 0 |     return Triple::ARMSubArch_v5; | 
| 500 | 0 |   case ARM::AK_ARMV5TE: | 
| 501 | 0 |   case ARM::AK_IWMMXT: | 
| 502 | 0 |   case ARM::AK_IWMMXT2: | 
| 503 | 0 |   case ARM::AK_XSCALE: | 
| 504 | 0 |   case ARM::AK_ARMV5TEJ: | 
| 505 | 0 |     return Triple::ARMSubArch_v5te; | 
| 506 | 0 |   case ARM::AK_ARMV6: | 
| 507 | 0 |     return Triple::ARMSubArch_v6; | 
| 508 | 0 |   case ARM::AK_ARMV6K: | 
| 509 | 0 |   case ARM::AK_ARMV6KZ: | 
| 510 | 0 |     return Triple::ARMSubArch_v6k; | 
| 511 | 0 |   case ARM::AK_ARMV6T2: | 
| 512 | 0 |     return Triple::ARMSubArch_v6t2; | 
| 513 | 0 |   case ARM::AK_ARMV6M: | 
| 514 | 0 |     return Triple::ARMSubArch_v6m; | 
| 515 | 355k |   case ARM::AK_ARMV7A: | 
| 516 | 355k |   case ARM::AK_ARMV7R: | 
| 517 | 355k |     return Triple::ARMSubArch_v7; | 
| 518 | 0 |   case ARM::AK_ARMV7K: | 
| 519 | 0 |     return Triple::ARMSubArch_v7k; | 
| 520 | 0 |   case ARM::AK_ARMV7M: | 
| 521 | 0 |     return Triple::ARMSubArch_v7m; | 
| 522 | 0 |   case ARM::AK_ARMV7S: | 
| 523 | 0 |     return Triple::ARMSubArch_v7s; | 
| 524 | 0 |   case ARM::AK_ARMV7EM: | 
| 525 | 0 |     return Triple::ARMSubArch_v7em; | 
| 526 | 109k |   case ARM::AK_ARMV8A: | 
| 527 | 109k |     return Triple::ARMSubArch_v8; | 
| 528 | 0 |   case ARM::AK_ARMV8_1A: | 
| 529 | 0 |     return Triple::ARMSubArch_v8_1a; | 
| 530 | 0 |   case ARM::AK_ARMV8_2A: | 
| 531 | 0 |     return Triple::ARMSubArch_v8_2a; | 
| 532 | 0 |   case ARM::AK_ARMV8MBaseline: | 
| 533 | 0 |     return Triple::ARMSubArch_v8m_baseline; | 
| 534 | 0 |   case ARM::AK_ARMV8MMainline: | 
| 535 | 0 |     return Triple::ARMSubArch_v8m_mainline; | 
| 536 | 536k |   default: | 
| 537 | 536k |     return Triple::NoSubArch; | 
| 538 | 1.00M |   } | 
| 539 | 1.00M | } | 
| 540 |  |  | 
| 541 | 0 | static const char *getObjectFormatTypeName(Triple::ObjectFormatType Kind) { | 
| 542 | 0 |   switch (Kind) { | 
| 543 | 0 |   case Triple::UnknownObjectFormat: return ""; | 
| 544 | 0 |   case Triple::COFF: return "coff"; | 
| 545 | 0 |   case Triple::ELF: return "elf"; | 
| 546 | 0 |   case Triple::MachO: return "macho"; | 
| 547 | 0 |   } | 
| 548 | 0 |   llvm_unreachable("unknown object format type"); | 
| 549 | 0 | } | 
| 550 |  |  | 
| 551 | 1.00M | static Triple::ObjectFormatType getDefaultFormat(const Triple &T) { | 
| 552 | 1.00M |   switch (T.getArch()) { | 
| 553 | 0 |   case Triple::UnknownArch: | 
| 554 | 18.3k |   case Triple::aarch64: | 
| 555 | 154k |   case Triple::arm: | 
| 556 | 291k |   case Triple::thumb: | 
| 557 | 407k |   case Triple::x86: | 
| 558 | 410k |   case Triple::x86_64: | 
| 559 | 410k |     if (T.isOSDarwin()) | 
| 560 | 0 |       return Triple::MachO; | 
| 561 | 410k |     else if (T.isOSWindows()) | 
| 562 | 0 |       return Triple::COFF; | 
| 563 | 410k |     return Triple::ELF; | 
| 564 |  |  | 
| 565 | 0 |   case Triple::aarch64_be: | 
| 566 | 0 |   case Triple::amdgcn: | 
| 567 | 0 |   case Triple::amdil: | 
| 568 | 0 |   case Triple::amdil64: | 
| 569 | 69.7k |   case Triple::armeb: | 
| 570 | 69.7k |   case Triple::avr: | 
| 571 | 69.7k |   case Triple::bpfeb: | 
| 572 | 69.7k |   case Triple::bpfel: | 
| 573 | 98.3k |   case Triple::hexagon: | 
| 574 | 98.3k |   case Triple::hsail: | 
| 575 | 98.3k |   case Triple::hsail64: | 
| 576 | 98.3k |   case Triple::kalimba: | 
| 577 | 98.3k |   case Triple::le32: | 
| 578 | 98.3k |   case Triple::le64: | 
| 579 | 104k |   case Triple::mips: | 
| 580 | 105k |   case Triple::mips64: | 
| 581 | 142k |   case Triple::mips64el: | 
| 582 | 144k |   case Triple::mipsel: | 
| 583 | 144k |   case Triple::msp430: | 
| 584 | 144k |   case Triple::nvptx: | 
| 585 | 144k |   case Triple::nvptx64: | 
| 586 | 148k |   case Triple::ppc64le: | 
| 587 | 148k |   case Triple::r600: | 
| 588 | 251k |   case Triple::riscv32: | 
| 589 | 345k |   case Triple::riscv64: | 
| 590 | 345k |   case Triple::shave: | 
| 591 | 347k |   case Triple::sparc: | 
| 592 | 435k |   case Triple::sparcel: | 
| 593 | 439k |   case Triple::sparcv9: | 
| 594 | 439k |   case Triple::spir: | 
| 595 | 439k |   case Triple::spir64: | 
| 596 | 440k |   case Triple::systemz: | 
| 597 | 440k |   case Triple::tce: | 
| 598 | 544k |   case Triple::thumbeb: | 
| 599 | 544k |   case Triple::wasm32: | 
| 600 | 544k |   case Triple::wasm64: | 
| 601 | 544k |   case Triple::xcore: | 
| 602 | 544k |     return Triple::ELF; | 
| 603 |  |  | 
| 604 | 17.1k |   case Triple::ppc: | 
| 605 | 47.0k |   case Triple::ppc64: | 
| 606 | 47.0k |     if (T.isOSDarwin()) | 
| 607 | 0 |       return Triple::MachO; | 
| 608 | 47.0k |     return Triple::ELF; | 
| 609 | 1.00M |   } | 
| 610 | 1.00M |   llvm_unreachable("unknown architecture"); | 
| 611 | 1.00M | } | 
| 612 |  |  | 
| 613 |  | /// \brief Construct a triple from the string representation provided. | 
| 614 |  | /// | 
| 615 |  | /// This stores the string representation and parses the various pieces into | 
| 616 |  | /// enum members. | 
| 617 |  | Triple::Triple(const Twine &Str) | 
| 618 |  |     : Data(Str.str()), Arch(UnknownArch), SubArch(NoSubArch), | 
| 619 |  |       Vendor(UnknownVendor), OS(UnknownOS), Environment(UnknownEnvironment), | 
| 620 | 1.00M |       ObjectFormat(UnknownObjectFormat) { | 
| 621 |  |   // Do minimal parsing by hand here. | 
| 622 | 1.00M |   SmallVector<StringRef, 4> Components; | 
| 623 | 1.00M |   StringRef(Data).split(Components, '-', /*MaxSplit*/ 3); | 
| 624 | 1.00M |   if (Components.size() > 0) { | 
| 625 | 1.00M |     Arch = parseArch(Components[0]); | 
| 626 | 1.00M |     SubArch = parseSubArch(Components[0]); | 
| 627 | 1.00M |     if (Components.size() > 1) { | 
| 628 | 98.6k |       Vendor = parseVendor(Components[1]); | 
| 629 | 98.6k |       if (Components.size() > 2) { | 
| 630 | 98.6k |         OS = parseOS(Components[2]); | 
| 631 | 98.6k |         if (Components.size() > 3) { | 
| 632 | 98.6k |           Environment = parseEnvironment(Components[3]); | 
| 633 | 98.6k |           ObjectFormat = parseFormat(Components[3]); | 
| 634 | 98.6k |         } | 
| 635 | 98.6k |       } | 
| 636 | 98.6k |     } | 
| 637 | 1.00M |   } | 
| 638 | 1.00M |   if (ObjectFormat == UnknownObjectFormat) | 
| 639 | 1.00M |     ObjectFormat = getDefaultFormat(*this); | 
| 640 | 1.00M | } | 
| 641 |  |  | 
| 642 |  | /// \brief Construct a triple from string representations of the architecture, | 
| 643 |  | /// vendor, and OS. | 
| 644 |  | /// | 
| 645 |  | /// This joins each argument into a canonical string representation and parses | 
| 646 |  | /// them into enum members. It leaves the environment unknown and omits it from | 
| 647 |  | /// the string representation. | 
| 648 |  | Triple::Triple(const Twine &ArchStr, const Twine &VendorStr, const Twine &OSStr) | 
| 649 |  |     : Data((ArchStr + Twine('-') + VendorStr + Twine('-') + OSStr).str()), | 
| 650 |  |       Arch(parseArch(ArchStr.str())), | 
| 651 |  |       SubArch(parseSubArch(ArchStr.str())), | 
| 652 |  |       Vendor(parseVendor(VendorStr.str())), | 
| 653 |  |       OS(parseOS(OSStr.str())), | 
| 654 | 0 |       Environment(), ObjectFormat(Triple::UnknownObjectFormat) { | 
| 655 | 0 |   ObjectFormat = getDefaultFormat(*this); | 
| 656 | 0 | } | 
| 657 |  |  | 
| 658 |  | /// \brief Construct a triple from string representations of the architecture, | 
| 659 |  | /// vendor, OS, and environment. | 
| 660 |  | /// | 
| 661 |  | /// This joins each argument into a canonical string representation and parses | 
| 662 |  | /// them into enum members. | 
| 663 |  | Triple::Triple(const Twine &ArchStr, const Twine &VendorStr, const Twine &OSStr, | 
| 664 |  |                const Twine &EnvironmentStr) | 
| 665 |  |     : Data((ArchStr + Twine('-') + VendorStr + Twine('-') + OSStr + Twine('-') + | 
| 666 |  |             EnvironmentStr).str()), | 
| 667 |  |       Arch(parseArch(ArchStr.str())), | 
| 668 |  |       SubArch(parseSubArch(ArchStr.str())), | 
| 669 |  |       Vendor(parseVendor(VendorStr.str())), | 
| 670 |  |       OS(parseOS(OSStr.str())), | 
| 671 |  |       Environment(parseEnvironment(EnvironmentStr.str())), | 
| 672 | 0 |       ObjectFormat(parseFormat(EnvironmentStr.str())) { | 
| 673 | 0 |   if (ObjectFormat == Triple::UnknownObjectFormat) | 
| 674 | 0 |     ObjectFormat = getDefaultFormat(*this); | 
| 675 | 0 | } | 
| 676 |  |  | 
| 677 | 111k | std::string Triple::normalize(StringRef Str) { | 
| 678 | 111k |   bool IsMinGW32 = false; | 
| 679 | 111k |   bool IsCygwin = false; | 
| 680 |  |  | 
| 681 |  |   // Parse into components. | 
| 682 | 111k |   SmallVector<StringRef, 4> Components; | 
| 683 | 111k |   Str.split(Components, '-'); | 
| 684 |  |  | 
| 685 |  |   // If the first component corresponds to a known architecture, preferentially | 
| 686 |  |   // use it for the architecture.  If the second component corresponds to a | 
| 687 |  |   // known vendor, preferentially use it for the vendor, etc.  This avoids silly | 
| 688 |  |   // component movement when a component parses as (eg) both a valid arch and a | 
| 689 |  |   // valid os. | 
| 690 | 111k |   ArchType Arch = UnknownArch; | 
| 691 | 111k |   if (Components.size() > 0) | 
| 692 | 111k |     Arch = parseArch(Components[0]); | 
| 693 | 111k |   VendorType Vendor = UnknownVendor; | 
| 694 | 111k |   if (Components.size() > 1) | 
| 695 | 10.9k |     Vendor = parseVendor(Components[1]); | 
| 696 | 111k |   OSType OS = UnknownOS; | 
| 697 | 111k |   if (Components.size() > 2) { | 
| 698 | 10.9k |     OS = parseOS(Components[2]); | 
| 699 | 10.9k |     IsCygwin = Components[2].startswith("cygwin"); | 
| 700 | 10.9k |     IsMinGW32 = Components[2].startswith("mingw"); | 
| 701 | 10.9k |   } | 
| 702 | 111k |   EnvironmentType Environment = UnknownEnvironment; | 
| 703 | 111k |   if (Components.size() > 3) | 
| 704 | 10.9k |     Environment = parseEnvironment(Components[3]); | 
| 705 | 111k |   ObjectFormatType ObjectFormat = UnknownObjectFormat; | 
| 706 | 111k |   if (Components.size() > 4) | 
| 707 | 0 |     ObjectFormat = parseFormat(Components[4]); | 
| 708 |  |  | 
| 709 |  |   // Note which components are already in their final position.  These will not | 
| 710 |  |   // be moved. | 
| 711 | 111k |   bool Found[4]; | 
| 712 | 111k |   Found[0] = Arch != UnknownArch; | 
| 713 | 111k |   Found[1] = Vendor != UnknownVendor; | 
| 714 | 111k |   Found[2] = OS != UnknownOS; | 
| 715 | 111k |   Found[3] = Environment != UnknownEnvironment; | 
| 716 |  |  | 
| 717 |  |   // If they are not there already, permute the components into their canonical | 
| 718 |  |   // positions by seeing if they parse as a valid architecture, and if so moving | 
| 719 |  |   // the component to the architecture position etc. | 
| 720 | 556k |   for (unsigned Pos = 0; Pos != array_lengthof(Found); ++Pos) { | 
| 721 | 445k |     if (Found[Pos]) | 
| 722 | 122k |       continue; // Already in the canonical position. | 
| 723 |  |  | 
| 724 | 711k |     for (unsigned Idx = 0; Idx != Components.size(); ++Idx) { | 
| 725 |  |       // Do not reparse any components that already matched. | 
| 726 | 388k |       if (Idx < array_lengthof(Found) && Found[Idx]) | 
| 727 | 344k |         continue; | 
| 728 |  |  | 
| 729 |  |       // Does this component parse as valid for the target position? | 
| 730 | 43.8k |       bool Valid = false; | 
| 731 | 43.8k |       StringRef Comp = Components[Idx]; | 
| 732 | 43.8k |       switch (Pos) { | 
| 733 | 0 |       default: llvm_unreachable("unexpected component type!"); | 
| 734 | 0 |       case 0: | 
| 735 | 0 |         Arch = parseArch(Comp); | 
| 736 | 0 |         Valid = Arch != UnknownArch; | 
| 737 | 0 |         break; | 
| 738 | 21.9k |       case 1: | 
| 739 | 21.9k |         Vendor = parseVendor(Comp); | 
| 740 | 21.9k |         Valid = Vendor != UnknownVendor; | 
| 741 | 21.9k |         break; | 
| 742 | 21.9k |       case 2: | 
| 743 | 21.9k |         OS = parseOS(Comp); | 
| 744 | 21.9k |         IsCygwin = Comp.startswith("cygwin"); | 
| 745 | 21.9k |         IsMinGW32 = Comp.startswith("mingw"); | 
| 746 | 21.9k |         Valid = OS != UnknownOS || IsCygwin || IsMinGW32; | 
| 747 | 21.9k |         break; | 
| 748 | 0 |       case 3: | 
| 749 | 0 |         Environment = parseEnvironment(Comp); | 
| 750 | 0 |         Valid = Environment != UnknownEnvironment; | 
| 751 | 0 |         if (!Valid) { | 
| 752 | 0 |           ObjectFormat = parseFormat(Comp); | 
| 753 | 0 |           Valid = ObjectFormat != UnknownObjectFormat; | 
| 754 | 0 |         } | 
| 755 | 0 |         break; | 
| 756 | 43.8k |       } | 
| 757 | 43.8k |       if (!Valid) | 
| 758 | 43.8k |         continue; // Nope, try the next component. | 
| 759 |  |  | 
| 760 |  |       // Move the component to the target position, pushing any non-fixed | 
| 761 |  |       // components that are in the way to the right.  This tends to give | 
| 762 |  |       // good results in the common cases of a forgotten vendor component | 
| 763 |  |       // or a wrongly positioned environment. | 
| 764 | 0 |       if (Pos < Idx) { | 
| 765 |  |         // Insert left, pushing the existing components to the right.  For | 
| 766 |  |         // example, a-b-i386 -> i386-a-b when moving i386 to the front. | 
| 767 | 0 |         StringRef CurrentComponent(""); // The empty component. | 
| 768 |  |         // Replace the component we are moving with an empty component. | 
| 769 | 0 |         std::swap(CurrentComponent, Components[Idx]); | 
| 770 |  |         // Insert the component being moved at Pos, displacing any existing | 
| 771 |  |         // components to the right. | 
| 772 | 0 |         for (unsigned i = Pos; !CurrentComponent.empty(); ++i) { | 
| 773 |  |           // Skip over any fixed components. | 
| 774 | 0 |           while (i < array_lengthof(Found) && Found[i]) | 
| 775 | 0 |             ++i; | 
| 776 |  |           // Place the component at the new position, getting the component | 
| 777 |  |           // that was at this position - it will be moved right. | 
| 778 | 0 |           std::swap(CurrentComponent, Components[i]); | 
| 779 | 0 |         } | 
| 780 | 0 |       } else if (Pos > Idx) { | 
| 781 |  |         // Push right by inserting empty components until the component at Idx | 
| 782 |  |         // reaches the target position Pos.  For example, pc-a -> -pc-a when | 
| 783 |  |         // moving pc to the second position. | 
| 784 | 0 |         do { | 
| 785 |  |           // Insert one empty component at Idx. | 
| 786 | 0 |           StringRef CurrentComponent(""); // The empty component. | 
| 787 | 0 |           for (unsigned i = Idx; i < Components.size();) { | 
| 788 |  |             // Place the component at the new position, getting the component | 
| 789 |  |             // that was at this position - it will be moved right. | 
| 790 | 0 |             std::swap(CurrentComponent, Components[i]); | 
| 791 |  |             // If it was placed on top of an empty component then we are done. | 
| 792 | 0 |             if (CurrentComponent.empty()) | 
| 793 | 0 |               break; | 
| 794 |  |             // Advance to the next component, skipping any fixed components. | 
| 795 | 0 |             while (++i < array_lengthof(Found) && Found[i]) | 
| 796 | 0 |               ; | 
| 797 | 0 |           } | 
| 798 |  |           // The last component was pushed off the end - append it. | 
| 799 | 0 |           if (!CurrentComponent.empty()) | 
| 800 | 0 |             Components.push_back(CurrentComponent); | 
| 801 |  |  | 
| 802 |  |           // Advance Idx to the component's new position. | 
| 803 | 0 |           while (++Idx < array_lengthof(Found) && Found[Idx]) | 
| 804 | 0 |             ; | 
| 805 | 0 |         } while (Idx < Pos); // Add more until the final position is reached. | 
| 806 | 0 |       } | 
| 807 | 0 |       assert(Pos < Components.size() && Components[Pos] == Comp && | 
| 808 | 0 |              "Component moved wrong!"); | 
| 809 | 0 |       Found[Pos] = true; | 
| 810 | 0 |       break; | 
| 811 | 43.8k |     } | 
| 812 | 322k |   } | 
| 813 |  |  | 
| 814 |  |   // Special case logic goes here.  At this point Arch, Vendor and OS have the | 
| 815 |  |   // correct values for the computed components. | 
| 816 | 111k |   std::string NormalizedEnvironment; | 
| 817 | 111k |   if (Environment == Triple::Android && Components[3].startswith("androideabi")) { | 
| 818 | 0 |     StringRef AndroidVersion = Components[3].drop_front(strlen("androideabi")); | 
| 819 | 0 |     if (AndroidVersion.empty()) { | 
| 820 | 0 |       Components[3] = "android"; | 
| 821 | 0 |     } else { | 
| 822 | 0 |       NormalizedEnvironment = Twine("android", AndroidVersion).str(); | 
| 823 | 0 |       Components[3] = NormalizedEnvironment; | 
| 824 | 0 |     } | 
| 825 | 0 |   } | 
| 826 |  |  | 
| 827 | 111k |   if (OS == Triple::Win32) { | 
| 828 | 0 |     Components.resize(4); | 
| 829 | 0 |     Components[2] = "windows"; | 
| 830 | 0 |     if (Environment == UnknownEnvironment) { | 
| 831 | 0 |       if (ObjectFormat == UnknownObjectFormat || ObjectFormat == Triple::COFF) | 
| 832 | 0 |         Components[3] = "msvc"; | 
| 833 | 0 |       else | 
| 834 | 0 |         Components[3] = getObjectFormatTypeName(ObjectFormat); | 
| 835 | 0 |     } | 
| 836 | 111k |   } else if (IsMinGW32) { | 
| 837 | 0 |     Components.resize(4); | 
| 838 | 0 |     Components[2] = "windows"; | 
| 839 | 0 |     Components[3] = "gnu"; | 
| 840 | 111k |   } else if (IsCygwin) { | 
| 841 | 0 |     Components.resize(4); | 
| 842 | 0 |     Components[2] = "windows"; | 
| 843 | 0 |     Components[3] = "cygnus"; | 
| 844 | 0 |   } | 
| 845 | 111k |   if (IsMinGW32 || IsCygwin || | 
| 846 | 111k |       (OS == Triple::Win32 && Environment != UnknownEnvironment)) { | 
| 847 | 0 |     if (ObjectFormat != UnknownObjectFormat && ObjectFormat != Triple::COFF) { | 
| 848 | 0 |       Components.resize(5); | 
| 849 | 0 |       Components[4] = getObjectFormatTypeName(ObjectFormat); | 
| 850 | 0 |     } | 
| 851 | 0 |   } | 
| 852 |  |  | 
| 853 |  |   // Stick the corrected components back together to form the normalized string. | 
| 854 | 111k |   std::string Normalized; | 
| 855 | 255k |   for (unsigned i = 0, e = Components.size(); i != e; ++i) { | 
| 856 | 144k |     if (i) Normalized += '-'; | 
| 857 | 144k |     Normalized += Components[i]; | 
| 858 | 144k |   } | 
| 859 | 111k |   return Normalized; | 
| 860 | 111k | } | 
| 861 |  |  | 
| 862 | 148k | StringRef Triple::getArchName() const { | 
| 863 | 148k |   return StringRef(Data).split('-').first;           // Isolate first component | 
| 864 | 148k | } | 
| 865 |  |  | 
| 866 | 0 | StringRef Triple::getVendorName() const { | 
| 867 | 0 |   StringRef Tmp = StringRef(Data).split('-').second; // Strip first component | 
| 868 | 0 |   return Tmp.split('-').first;                       // Isolate second component | 
| 869 | 0 | } | 
| 870 |  |  | 
| 871 | 0 | StringRef Triple::getOSName() const { | 
| 872 | 0 |   StringRef Tmp = StringRef(Data).split('-').second; // Strip first component | 
| 873 | 0 |   Tmp = Tmp.split('-').second;                       // Strip second component | 
| 874 | 0 |   return Tmp.split('-').first;                       // Isolate third component | 
| 875 | 0 | } | 
| 876 |  |  | 
| 877 | 0 | StringRef Triple::getEnvironmentName() const { | 
| 878 | 0 |   StringRef Tmp = StringRef(Data).split('-').second; // Strip first component | 
| 879 | 0 |   Tmp = Tmp.split('-').second;                       // Strip second component | 
| 880 | 0 |   return Tmp.split('-').second;                      // Strip third component | 
| 881 | 0 | } | 
| 882 |  |  | 
| 883 | 0 | StringRef Triple::getOSAndEnvironmentName() const { | 
| 884 | 0 |   StringRef Tmp = StringRef(Data).split('-').second; // Strip first component | 
| 885 | 0 |   return Tmp.split('-').second;                      // Strip second component | 
| 886 | 0 | } | 
| 887 |  |  | 
| 888 | 0 | static unsigned EatNumber(StringRef &Str) { | 
| 889 | 0 |   assert(!Str.empty() && Str[0] >= '0' && Str[0] <= '9' && "Not a number"); | 
| 890 | 0 |   unsigned Result = 0; | 
| 891 |  | 
 | 
| 892 | 0 |   do { | 
| 893 |  |     // Consume the leading digit. | 
| 894 | 0 |     Result = Result*10 + (Str[0] - '0'); | 
| 895 |  |  | 
| 896 |  |     // Eat the digit. | 
| 897 | 0 |     Str = Str.substr(1); | 
| 898 | 0 |   } while (!Str.empty() && Str[0] >= '0' && Str[0] <= '9'); | 
| 899 |  | 
 | 
| 900 | 0 |   return Result; | 
| 901 | 0 | } | 
| 902 |  |  | 
| 903 |  | static void parseVersionFromName(StringRef Name, unsigned &Major, | 
| 904 | 0 |                                  unsigned &Minor, unsigned &Micro) { | 
| 905 |  |   // Any unset version defaults to 0. | 
| 906 | 0 |   Major = Minor = Micro = 0; | 
| 907 |  |  | 
| 908 |  |   // Parse up to three components. | 
| 909 | 0 |   unsigned *Components[3] = {&Major, &Minor, &Micro}; | 
| 910 | 0 |   for (unsigned i = 0; i != 3; ++i) { | 
| 911 | 0 |     if (Name.empty() || Name[0] < '0' || Name[0] > '9') | 
| 912 | 0 |       break; | 
| 913 |  |  | 
| 914 |  |     // Consume the leading number. | 
| 915 | 0 |     *Components[i] = EatNumber(Name); | 
| 916 |  |  | 
| 917 |  |     // Consume the separator, if present. | 
| 918 | 0 |     if (Name.startswith(".")) | 
| 919 | 0 |       Name = Name.substr(1); | 
| 920 | 0 |   } | 
| 921 | 0 | } | 
| 922 |  |  | 
| 923 |  | void Triple::getEnvironmentVersion(unsigned &Major, unsigned &Minor, | 
| 924 | 0 |                                    unsigned &Micro) const { | 
| 925 | 0 |   StringRef EnvironmentName = getEnvironmentName(); | 
| 926 | 0 |   StringRef EnvironmentTypeName = getEnvironmentTypeName(getEnvironment()); | 
| 927 | 0 |   if (EnvironmentName.startswith(EnvironmentTypeName)) | 
| 928 | 0 |     EnvironmentName = EnvironmentName.substr(EnvironmentTypeName.size()); | 
| 929 |  | 
 | 
| 930 | 0 |   parseVersionFromName(EnvironmentName, Major, Minor, Micro); | 
| 931 | 0 | } | 
| 932 |  |  | 
| 933 |  | void Triple::getOSVersion(unsigned &Major, unsigned &Minor, | 
| 934 | 0 |                           unsigned &Micro) const { | 
| 935 | 0 |   StringRef OSName = getOSName(); | 
| 936 |  |   // Assume that the OS portion of the triple starts with the canonical name. | 
| 937 | 0 |   StringRef OSTypeName = getOSTypeName(getOS()); | 
| 938 | 0 |   if (OSName.startswith(OSTypeName)) | 
| 939 | 0 |     OSName = OSName.substr(OSTypeName.size()); | 
| 940 |  | 
 | 
| 941 | 0 |   parseVersionFromName(OSName, Major, Minor, Micro); | 
| 942 | 0 | } | 
| 943 |  |  | 
| 944 |  | bool Triple::getMacOSXVersion(unsigned &Major, unsigned &Minor, | 
| 945 | 0 |                               unsigned &Micro) const { | 
| 946 | 0 |   getOSVersion(Major, Minor, Micro); | 
| 947 |  | 
 | 
| 948 | 0 |   switch (getOS()) { | 
| 949 | 0 |   default: llvm_unreachable("unexpected OS for Darwin triple"); | 
| 950 | 0 |   case Darwin: | 
| 951 |  |     // Default to darwin8, i.e., MacOSX 10.4. | 
| 952 | 0 |     if (Major == 0) | 
| 953 | 0 |       Major = 8; | 
| 954 |  |     // Darwin version numbers are skewed from OS X versions. | 
| 955 | 0 |     if (Major < 4) | 
| 956 | 0 |       return false; | 
| 957 | 0 |     Micro = 0; | 
| 958 | 0 |     Minor = Major - 4; | 
| 959 | 0 |     Major = 10; | 
| 960 | 0 |     break; | 
| 961 | 0 |   case MacOSX: | 
| 962 |  |     // Default to 10.4. | 
| 963 | 0 |     if (Major == 0) { | 
| 964 | 0 |       Major = 10; | 
| 965 | 0 |       Minor = 4; | 
| 966 | 0 |     } | 
| 967 | 0 |     if (Major != 10) | 
| 968 | 0 |       return false; | 
| 969 | 0 |     break; | 
| 970 | 0 |   case IOS: | 
| 971 | 0 |   case TvOS: | 
| 972 | 0 |   case WatchOS: | 
| 973 |  |     // Ignore the version from the triple.  This is only handled because the | 
| 974 |  |     // the clang driver combines OS X and IOS support into a common Darwin | 
| 975 |  |     // toolchain that wants to know the OS X version number even when targeting | 
| 976 |  |     // IOS. | 
| 977 | 0 |     Major = 10; | 
| 978 | 0 |     Minor = 4; | 
| 979 | 0 |     Micro = 0; | 
| 980 | 0 |     break; | 
| 981 | 0 |   } | 
| 982 | 0 |   return true; | 
| 983 | 0 | } | 
| 984 |  |  | 
| 985 |  | void Triple::getiOSVersion(unsigned &Major, unsigned &Minor, | 
| 986 | 0 |                            unsigned &Micro) const { | 
| 987 | 0 |   switch (getOS()) { | 
| 988 | 0 |   default: llvm_unreachable("unexpected OS for Darwin triple"); | 
| 989 | 0 |   case Darwin: | 
| 990 | 0 |   case MacOSX: | 
| 991 |  |     // Ignore the version from the triple.  This is only handled because the | 
| 992 |  |     // the clang driver combines OS X and IOS support into a common Darwin | 
| 993 |  |     // toolchain that wants to know the iOS version number even when targeting | 
| 994 |  |     // OS X. | 
| 995 | 0 |     Major = 5; | 
| 996 | 0 |     Minor = 0; | 
| 997 | 0 |     Micro = 0; | 
| 998 | 0 |     break; | 
| 999 | 0 |   case IOS: | 
| 1000 | 0 |   case TvOS: | 
| 1001 | 0 |     getOSVersion(Major, Minor, Micro); | 
| 1002 |  |     // Default to 5.0 (or 7.0 for arm64). | 
| 1003 | 0 |     if (Major == 0) | 
| 1004 | 0 |       Major = (getArch() == aarch64) ? 7 : 5; | 
| 1005 | 0 |     break; | 
| 1006 | 0 |   case WatchOS: | 
| 1007 | 0 |     llvm_unreachable("conflicting triple info"); | 
| 1008 | 0 |   } | 
| 1009 | 0 | } | 
| 1010 |  |  | 
| 1011 |  | void Triple::getWatchOSVersion(unsigned &Major, unsigned &Minor, | 
| 1012 | 0 |                                unsigned &Micro) const { | 
| 1013 | 0 |   switch (getOS()) { | 
| 1014 | 0 |   default: llvm_unreachable("unexpected OS for Darwin triple"); | 
| 1015 | 0 |   case Darwin: | 
| 1016 | 0 |   case MacOSX: | 
| 1017 |  |     // Ignore the version from the triple.  This is only handled because the | 
| 1018 |  |     // the clang driver combines OS X and IOS support into a common Darwin | 
| 1019 |  |     // toolchain that wants to know the iOS version number even when targeting | 
| 1020 |  |     // OS X. | 
| 1021 | 0 |     Major = 2; | 
| 1022 | 0 |     Minor = 0; | 
| 1023 | 0 |     Micro = 0; | 
| 1024 | 0 |     break; | 
| 1025 | 0 |   case WatchOS: | 
| 1026 | 0 |     getOSVersion(Major, Minor, Micro); | 
| 1027 | 0 |     if (Major == 0) | 
| 1028 | 0 |       Major = 2; | 
| 1029 | 0 |     break; | 
| 1030 | 0 |   case IOS: | 
| 1031 | 0 |     llvm_unreachable("conflicting triple info"); | 
| 1032 | 0 |   } | 
| 1033 | 0 | } | 
| 1034 |  |  | 
| 1035 | 0 | void Triple::setTriple(const Twine &Str) { | 
| 1036 | 0 |   *this = Triple(Str); | 
| 1037 | 0 | } | 
| 1038 |  |  | 
| 1039 | 0 | void Triple::setArch(ArchType Kind) { | 
| 1040 | 0 |   setArchName(getArchTypeName(Kind)); | 
| 1041 | 0 | } | 
| 1042 |  |  | 
| 1043 | 0 | void Triple::setVendor(VendorType Kind) { | 
| 1044 | 0 |   setVendorName(getVendorTypeName(Kind)); | 
| 1045 | 0 | } | 
| 1046 |  |  | 
| 1047 | 0 | void Triple::setOS(OSType Kind) { | 
| 1048 | 0 |   setOSName(getOSTypeName(Kind)); | 
| 1049 | 0 | } | 
| 1050 |  |  | 
| 1051 | 0 | void Triple::setEnvironment(EnvironmentType Kind) { | 
| 1052 | 0 |   if (ObjectFormat == getDefaultFormat(*this)) | 
| 1053 | 0 |     return setEnvironmentName(getEnvironmentTypeName(Kind)); | 
| 1054 |  |  | 
| 1055 | 0 |   setEnvironmentName((getEnvironmentTypeName(Kind) + Twine("-") + | 
| 1056 | 0 |                       getObjectFormatTypeName(ObjectFormat)).str()); | 
| 1057 | 0 | } | 
| 1058 |  |  | 
| 1059 | 0 | void Triple::setObjectFormat(ObjectFormatType Kind) { | 
| 1060 | 0 |   if (Environment == UnknownEnvironment) | 
| 1061 | 0 |     return setEnvironmentName(getObjectFormatTypeName(Kind)); | 
| 1062 |  |  | 
| 1063 | 0 |   setEnvironmentName((getEnvironmentTypeName(Environment) + Twine("-") + | 
| 1064 | 0 |                       getObjectFormatTypeName(Kind)).str()); | 
| 1065 | 0 | } | 
| 1066 |  |  | 
| 1067 | 0 | void Triple::setArchName(StringRef Str) { | 
| 1068 |  |   // Work around a miscompilation bug for Twines in gcc 4.0.3. | 
| 1069 | 0 |   SmallString<64> Triple; | 
| 1070 | 0 |   Triple += Str; | 
| 1071 | 0 |   Triple += "-"; | 
| 1072 | 0 |   Triple += getVendorName(); | 
| 1073 | 0 |   Triple += "-"; | 
| 1074 | 0 |   Triple += getOSAndEnvironmentName(); | 
| 1075 | 0 |   setTriple(Triple); | 
| 1076 | 0 | } | 
| 1077 |  |  | 
| 1078 | 0 | void Triple::setVendorName(StringRef Str) { | 
| 1079 | 0 |   setTriple(getArchName() + "-" + Str + "-" + getOSAndEnvironmentName()); | 
| 1080 | 0 | } | 
| 1081 |  |  | 
| 1082 | 0 | void Triple::setOSName(StringRef Str) { | 
| 1083 | 0 |   if (hasEnvironment()) | 
| 1084 | 0 |     setTriple(getArchName() + "-" + getVendorName() + "-" + Str + | 
| 1085 | 0 |               "-" + getEnvironmentName()); | 
| 1086 | 0 |   else | 
| 1087 | 0 |     setTriple(getArchName() + "-" + getVendorName() + "-" + Str); | 
| 1088 | 0 | } | 
| 1089 |  |  | 
| 1090 | 0 | void Triple::setEnvironmentName(StringRef Str) { | 
| 1091 | 0 |   setTriple(getArchName() + "-" + getVendorName() + "-" + getOSName() + | 
| 1092 | 0 |             "-" + Str); | 
| 1093 | 0 | } | 
| 1094 |  |  | 
| 1095 | 0 | void Triple::setOSAndEnvironmentName(StringRef Str) { | 
| 1096 | 0 |   setTriple(getArchName() + "-" + getVendorName() + "-" + Str); | 
| 1097 | 0 | } | 
| 1098 |  |  | 
| 1099 | 130k | static unsigned getArchPointerBitWidth(llvm_ks::Triple::ArchType Arch) { | 
| 1100 | 130k |   switch (Arch) { | 
| 1101 | 0 |   case llvm_ks::Triple::UnknownArch: | 
| 1102 | 0 |     return 0; | 
| 1103 |  |  | 
| 1104 | 0 |   case llvm_ks::Triple::avr: | 
| 1105 | 0 |   case llvm_ks::Triple::msp430: | 
| 1106 | 0 |     return 16; | 
| 1107 |  |  | 
| 1108 | 0 |   case llvm_ks::Triple::arm: | 
| 1109 | 0 |   case llvm_ks::Triple::armeb: | 
| 1110 | 0 |   case llvm_ks::Triple::hexagon: | 
| 1111 | 0 |   case llvm_ks::Triple::le32: | 
| 1112 | 0 |   case llvm_ks::Triple::mips: | 
| 1113 | 0 |   case llvm_ks::Triple::mipsel: | 
| 1114 | 0 |   case llvm_ks::Triple::nvptx: | 
| 1115 | 0 |   case llvm_ks::Triple::ppc: | 
| 1116 | 0 |   case llvm_ks::Triple::r600: | 
| 1117 | 68.4k |   case llvm_ks::Triple::riscv32: | 
| 1118 | 68.4k |   case llvm_ks::Triple::sparc: | 
| 1119 | 68.4k |   case llvm_ks::Triple::sparcel: | 
| 1120 | 68.4k |   case llvm_ks::Triple::tce: | 
| 1121 | 68.4k |   case llvm_ks::Triple::thumb: | 
| 1122 | 68.4k |   case llvm_ks::Triple::thumbeb: | 
| 1123 | 68.4k |   case llvm_ks::Triple::x86: | 
| 1124 | 68.4k |   case llvm_ks::Triple::xcore: | 
| 1125 | 68.4k |   case llvm_ks::Triple::amdil: | 
| 1126 | 68.4k |   case llvm_ks::Triple::hsail: | 
| 1127 | 68.4k |   case llvm_ks::Triple::spir: | 
| 1128 | 68.4k |   case llvm_ks::Triple::kalimba: | 
| 1129 | 68.4k |   case llvm_ks::Triple::shave: | 
| 1130 | 68.4k |   case llvm_ks::Triple::wasm32: | 
| 1131 | 68.4k |     return 32; | 
| 1132 |  |  | 
| 1133 | 0 |   case llvm_ks::Triple::aarch64: | 
| 1134 | 0 |   case llvm_ks::Triple::aarch64_be: | 
| 1135 | 0 |   case llvm_ks::Triple::amdgcn: | 
| 1136 | 0 |   case llvm_ks::Triple::bpfel: | 
| 1137 | 0 |   case llvm_ks::Triple::bpfeb: | 
| 1138 | 0 |   case llvm_ks::Triple::le64: | 
| 1139 | 0 |   case llvm_ks::Triple::mips64: | 
| 1140 | 0 |   case llvm_ks::Triple::mips64el: | 
| 1141 | 0 |   case llvm_ks::Triple::nvptx64: | 
| 1142 | 0 |   case llvm_ks::Triple::ppc64: | 
| 1143 | 0 |   case llvm_ks::Triple::ppc64le: | 
| 1144 | 62.4k |   case llvm_ks::Triple::riscv64: | 
| 1145 | 62.4k |   case llvm_ks::Triple::sparcv9: | 
| 1146 | 62.4k |   case llvm_ks::Triple::systemz: | 
| 1147 | 62.4k |   case llvm_ks::Triple::x86_64: | 
| 1148 | 62.4k |   case llvm_ks::Triple::amdil64: | 
| 1149 | 62.4k |   case llvm_ks::Triple::hsail64: | 
| 1150 | 62.4k |   case llvm_ks::Triple::spir64: | 
| 1151 | 62.4k |   case llvm_ks::Triple::wasm64: | 
| 1152 | 62.4k |     return 64; | 
| 1153 | 130k |   } | 
| 1154 | 130k |   llvm_unreachable("Invalid architecture value"); | 
| 1155 | 130k | } | 
| 1156 |  |  | 
| 1157 | 130k | bool Triple::isArch64Bit() const { | 
| 1158 | 130k |   return getArchPointerBitWidth(getArch()) == 64; | 
| 1159 | 130k | } | 
| 1160 |  |  | 
| 1161 | 0 | bool Triple::isArch32Bit() const { | 
| 1162 | 0 |   return getArchPointerBitWidth(getArch()) == 32; | 
| 1163 | 0 | } | 
| 1164 |  |  | 
| 1165 | 0 | bool Triple::isArch16Bit() const { | 
| 1166 | 0 |   return getArchPointerBitWidth(getArch()) == 16; | 
| 1167 | 0 | } | 
| 1168 |  |  | 
| 1169 | 0 | Triple Triple::get32BitArchVariant() const { | 
| 1170 | 0 |   Triple T(*this); | 
| 1171 | 0 |   switch (getArch()) { | 
| 1172 | 0 |   case Triple::UnknownArch: | 
| 1173 | 0 |   case Triple::amdgcn: | 
| 1174 | 0 |   case Triple::avr: | 
| 1175 | 0 |   case Triple::bpfel: | 
| 1176 | 0 |   case Triple::bpfeb: | 
| 1177 | 0 |   case Triple::msp430: | 
| 1178 | 0 |   case Triple::systemz: | 
| 1179 | 0 |   case Triple::ppc64le: | 
| 1180 | 0 |     T.setArch(UnknownArch); | 
| 1181 | 0 |     break; | 
| 1182 |  |  | 
| 1183 | 0 |   case Triple::amdil: | 
| 1184 | 0 |   case Triple::hsail: | 
| 1185 | 0 |   case Triple::spir: | 
| 1186 | 0 |   case Triple::arm: | 
| 1187 | 0 |   case Triple::armeb: | 
| 1188 | 0 |   case Triple::hexagon: | 
| 1189 | 0 |   case Triple::kalimba: | 
| 1190 | 0 |   case Triple::le32: | 
| 1191 | 0 |   case Triple::mips: | 
| 1192 | 0 |   case Triple::mipsel: | 
| 1193 | 0 |   case Triple::nvptx: | 
| 1194 | 0 |   case Triple::ppc: | 
| 1195 | 0 |   case Triple::r600: | 
| 1196 | 0 |   case Triple::riscv32: | 
| 1197 | 0 |   case Triple::sparc: | 
| 1198 | 0 |   case Triple::sparcel: | 
| 1199 | 0 |   case Triple::tce: | 
| 1200 | 0 |   case Triple::thumb: | 
| 1201 | 0 |   case Triple::thumbeb: | 
| 1202 | 0 |   case Triple::x86: | 
| 1203 | 0 |   case Triple::xcore: | 
| 1204 | 0 |   case Triple::shave: | 
| 1205 | 0 |   case Triple::wasm32: | 
| 1206 |  |     // Already 32-bit. | 
| 1207 | 0 |     break; | 
| 1208 |  |  | 
| 1209 | 0 |   case Triple::aarch64:    T.setArch(Triple::arm);     break; | 
| 1210 | 0 |   case Triple::aarch64_be: T.setArch(Triple::armeb);   break; | 
| 1211 | 0 |   case Triple::le64:       T.setArch(Triple::le32);    break; | 
| 1212 | 0 |   case Triple::mips64:     T.setArch(Triple::mips);    break; | 
| 1213 | 0 |   case Triple::mips64el:   T.setArch(Triple::mipsel);  break; | 
| 1214 | 0 |   case Triple::nvptx64:    T.setArch(Triple::nvptx);   break; | 
| 1215 | 0 |   case Triple::ppc64:      T.setArch(Triple::ppc);     break; | 
| 1216 | 0 |   case Triple::sparcv9:    T.setArch(Triple::sparc);   break; | 
| 1217 | 0 |   case Triple::riscv64:    T.setArch(Triple::riscv32); break; | 
| 1218 | 0 |   case Triple::x86_64:     T.setArch(Triple::x86);     break; | 
| 1219 | 0 |   case Triple::amdil64:    T.setArch(Triple::amdil);   break; | 
| 1220 | 0 |   case Triple::hsail64:    T.setArch(Triple::hsail);   break; | 
| 1221 | 0 |   case Triple::spir64:     T.setArch(Triple::spir);    break; | 
| 1222 | 0 |   case Triple::wasm64:     T.setArch(Triple::wasm32);  break; | 
| 1223 | 0 |   } | 
| 1224 | 0 |   return T; | 
| 1225 | 0 | } | 
| 1226 |  |  | 
| 1227 | 0 | Triple Triple::get64BitArchVariant() const { | 
| 1228 | 0 |   Triple T(*this); | 
| 1229 | 0 |   switch (getArch()) { | 
| 1230 | 0 |   case Triple::UnknownArch: | 
| 1231 | 0 |   case Triple::avr: | 
| 1232 | 0 |   case Triple::hexagon: | 
| 1233 | 0 |   case Triple::kalimba: | 
| 1234 | 0 |   case Triple::msp430: | 
| 1235 | 0 |   case Triple::r600: | 
| 1236 | 0 |   case Triple::tce: | 
| 1237 | 0 |   case Triple::xcore: | 
| 1238 | 0 |   case Triple::sparcel: | 
| 1239 | 0 |   case Triple::shave: | 
| 1240 | 0 |     T.setArch(UnknownArch); | 
| 1241 | 0 |     break; | 
| 1242 |  |  | 
| 1243 | 0 |   case Triple::aarch64: | 
| 1244 | 0 |   case Triple::aarch64_be: | 
| 1245 | 0 |   case Triple::bpfel: | 
| 1246 | 0 |   case Triple::bpfeb: | 
| 1247 | 0 |   case Triple::le64: | 
| 1248 | 0 |   case Triple::amdil64: | 
| 1249 | 0 |   case Triple::amdgcn: | 
| 1250 | 0 |   case Triple::hsail64: | 
| 1251 | 0 |   case Triple::spir64: | 
| 1252 | 0 |   case Triple::mips64: | 
| 1253 | 0 |   case Triple::mips64el: | 
| 1254 | 0 |   case Triple::nvptx64: | 
| 1255 | 0 |   case Triple::ppc64: | 
| 1256 | 0 |   case Triple::ppc64le: | 
| 1257 | 0 |   case Triple::riscv64: | 
| 1258 | 0 |   case Triple::sparcv9: | 
| 1259 | 0 |   case Triple::systemz: | 
| 1260 | 0 |   case Triple::x86_64: | 
| 1261 | 0 |   case Triple::wasm64: | 
| 1262 |  |     // Already 64-bit. | 
| 1263 | 0 |     break; | 
| 1264 |  |  | 
| 1265 | 0 |   case Triple::arm:     T.setArch(Triple::aarch64);    break; | 
| 1266 | 0 |   case Triple::armeb:   T.setArch(Triple::aarch64_be); break; | 
| 1267 | 0 |   case Triple::le32:    T.setArch(Triple::le64);       break; | 
| 1268 | 0 |   case Triple::mips:    T.setArch(Triple::mips64);     break; | 
| 1269 | 0 |   case Triple::mipsel:  T.setArch(Triple::mips64el);   break; | 
| 1270 | 0 |   case Triple::nvptx:   T.setArch(Triple::nvptx64);    break; | 
| 1271 | 0 |   case Triple::ppc:     T.setArch(Triple::ppc64);      break; | 
| 1272 | 0 |   case Triple::sparc:   T.setArch(Triple::sparcv9);    break; | 
| 1273 | 0 |   case Triple::riscv32: T.setArch(Triple::riscv64);    break; | 
| 1274 | 0 |   case Triple::x86:     T.setArch(Triple::x86_64);     break; | 
| 1275 | 0 |   case Triple::amdil:   T.setArch(Triple::amdil64);    break; | 
| 1276 | 0 |   case Triple::hsail:   T.setArch(Triple::hsail64);    break; | 
| 1277 | 0 |   case Triple::spir:    T.setArch(Triple::spir64);     break; | 
| 1278 | 0 |   case Triple::thumb:   T.setArch(Triple::aarch64);    break; | 
| 1279 | 0 |   case Triple::thumbeb: T.setArch(Triple::aarch64_be); break; | 
| 1280 | 0 |   case Triple::wasm32:  T.setArch(Triple::wasm64);     break; | 
| 1281 | 0 |   } | 
| 1282 | 0 |   return T; | 
| 1283 | 0 | } | 
| 1284 |  |  | 
| 1285 | 0 | Triple Triple::getBigEndianArchVariant() const { | 
| 1286 | 0 |   Triple T(*this); | 
| 1287 | 0 |   switch (getArch()) { | 
| 1288 | 0 |   case Triple::UnknownArch: | 
| 1289 | 0 |   case Triple::amdgcn: | 
| 1290 | 0 |   case Triple::amdil64: | 
| 1291 | 0 |   case Triple::amdil: | 
| 1292 | 0 |   case Triple::avr: | 
| 1293 | 0 |   case Triple::hexagon: | 
| 1294 | 0 |   case Triple::hsail64: | 
| 1295 | 0 |   case Triple::hsail: | 
| 1296 | 0 |   case Triple::kalimba: | 
| 1297 | 0 |   case Triple::le32: | 
| 1298 | 0 |   case Triple::le64: | 
| 1299 | 0 |   case Triple::msp430: | 
| 1300 | 0 |   case Triple::nvptx64: | 
| 1301 | 0 |   case Triple::nvptx: | 
| 1302 | 0 |   case Triple::r600: | 
| 1303 | 0 |   case Triple::riscv32: | 
| 1304 | 0 |   case Triple::riscv64: | 
| 1305 | 0 |   case Triple::shave: | 
| 1306 | 0 |   case Triple::spir64: | 
| 1307 | 0 |   case Triple::spir: | 
| 1308 | 0 |   case Triple::wasm32: | 
| 1309 | 0 |   case Triple::wasm64: | 
| 1310 | 0 |   case Triple::x86: | 
| 1311 | 0 |   case Triple::x86_64: | 
| 1312 | 0 |   case Triple::xcore: | 
| 1313 |  |  | 
| 1314 |  |   // ARM is intentionally unsupported here, changing the architecture would | 
| 1315 |  |   // drop any arch suffixes. | 
| 1316 | 0 |   case Triple::arm: | 
| 1317 | 0 |   case Triple::thumb: | 
| 1318 | 0 |     T.setArch(UnknownArch); | 
| 1319 | 0 |     break; | 
| 1320 |  |  | 
| 1321 | 0 |   case Triple::aarch64_be: | 
| 1322 | 0 |   case Triple::armeb: | 
| 1323 | 0 |   case Triple::bpfeb: | 
| 1324 | 0 |   case Triple::mips64: | 
| 1325 | 0 |   case Triple::mips: | 
| 1326 | 0 |   case Triple::ppc64: | 
| 1327 | 0 |   case Triple::ppc: | 
| 1328 | 0 |   case Triple::sparc: | 
| 1329 | 0 |   case Triple::sparcv9: | 
| 1330 | 0 |   case Triple::systemz: | 
| 1331 | 0 |   case Triple::tce: | 
| 1332 | 0 |   case Triple::thumbeb: | 
| 1333 |  |     // Already big endian. | 
| 1334 | 0 |     break; | 
| 1335 |  |  | 
| 1336 | 0 |   case Triple::aarch64: T.setArch(Triple::aarch64_be); break; | 
| 1337 | 0 |   case Triple::bpfel:   T.setArch(Triple::bpfeb);      break; | 
| 1338 | 0 |   case Triple::mips64el:T.setArch(Triple::mips64);     break; | 
| 1339 | 0 |   case Triple::mipsel:  T.setArch(Triple::mips);       break; | 
| 1340 | 0 |   case Triple::ppc64le: T.setArch(Triple::ppc64);      break; | 
| 1341 | 0 |   case Triple::sparcel: T.setArch(Triple::sparc);      break; | 
| 1342 | 0 |   } | 
| 1343 | 0 |   return T; | 
| 1344 | 0 | } | 
| 1345 |  |  | 
| 1346 | 0 | Triple Triple::getLittleEndianArchVariant() const { | 
| 1347 | 0 |   Triple T(*this); | 
| 1348 | 0 |   switch (getArch()) { | 
| 1349 | 0 |   case Triple::UnknownArch: | 
| 1350 | 0 |   case Triple::ppc: | 
| 1351 | 0 |   case Triple::sparcv9: | 
| 1352 | 0 |   case Triple::systemz: | 
| 1353 | 0 |   case Triple::tce: | 
| 1354 |  |  | 
| 1355 |  |   // ARM is intentionally unsupported here, changing the architecture would | 
| 1356 |  |   // drop any arch suffixes. | 
| 1357 | 0 |   case Triple::armeb: | 
| 1358 | 0 |   case Triple::thumbeb: | 
| 1359 | 0 |     T.setArch(UnknownArch); | 
| 1360 | 0 |     break; | 
| 1361 |  |  | 
| 1362 | 0 |   case Triple::aarch64: | 
| 1363 | 0 |   case Triple::amdgcn: | 
| 1364 | 0 |   case Triple::amdil64: | 
| 1365 | 0 |   case Triple::amdil: | 
| 1366 | 0 |   case Triple::arm: | 
| 1367 | 0 |   case Triple::avr: | 
| 1368 | 0 |   case Triple::bpfel: | 
| 1369 | 0 |   case Triple::hexagon: | 
| 1370 | 0 |   case Triple::hsail64: | 
| 1371 | 0 |   case Triple::hsail: | 
| 1372 | 0 |   case Triple::kalimba: | 
| 1373 | 0 |   case Triple::le32: | 
| 1374 | 0 |   case Triple::le64: | 
| 1375 | 0 |   case Triple::mips64el: | 
| 1376 | 0 |   case Triple::mipsel: | 
| 1377 | 0 |   case Triple::msp430: | 
| 1378 | 0 |   case Triple::nvptx64: | 
| 1379 | 0 |   case Triple::nvptx: | 
| 1380 | 0 |   case Triple::ppc64le: | 
| 1381 | 0 |   case Triple::r600: | 
| 1382 | 0 |   case Triple::shave: | 
| 1383 | 0 |   case Triple::sparcel: | 
| 1384 | 0 |   case Triple::spir64: | 
| 1385 | 0 |   case Triple::spir: | 
| 1386 | 0 |   case Triple::thumb: | 
| 1387 | 0 |   case Triple::wasm32: | 
| 1388 | 0 |   case Triple::wasm64: | 
| 1389 | 0 |   case Triple::x86: | 
| 1390 | 0 |   case Triple::x86_64: | 
| 1391 | 0 |   case Triple::xcore: | 
| 1392 |  |     // Already little endian. | 
| 1393 | 0 |     break; | 
| 1394 |  |  | 
| 1395 | 0 |   case Triple::aarch64_be: T.setArch(Triple::aarch64);  break; | 
| 1396 | 0 |   case Triple::bpfeb:      T.setArch(Triple::bpfel);    break; | 
| 1397 | 0 |   case Triple::mips64:     T.setArch(Triple::mips64el); break; | 
| 1398 | 0 |   case Triple::mips:       T.setArch(Triple::mipsel);   break; | 
| 1399 | 0 |   case Triple::ppc64:      T.setArch(Triple::ppc64le);  break; | 
| 1400 | 0 |   case Triple::sparc:      T.setArch(Triple::sparcel);  break; | 
| 1401 | 0 |   } | 
| 1402 | 0 |   return T; | 
| 1403 | 0 | } | 
| 1404 |  |  | 
| 1405 | 0 | StringRef Triple::getARMCPUForArch(StringRef MArch) const { | 
| 1406 | 0 |   if (MArch.empty()) | 
| 1407 | 0 |     MArch = getArchName(); | 
| 1408 | 0 |   MArch = ARM::getCanonicalArchName(MArch); | 
| 1409 |  |  | 
| 1410 |  |   // Some defaults are forced. | 
| 1411 | 0 |   switch (getOS()) { | 
| 1412 | 0 |   case llvm_ks::Triple::FreeBSD: | 
| 1413 | 0 |   case llvm_ks::Triple::NetBSD: | 
| 1414 | 0 |     if (!MArch.empty() && MArch == "v6") | 
| 1415 | 0 |       return "arm1176jzf-s"; | 
| 1416 | 0 |     break; | 
| 1417 | 0 |   case llvm_ks::Triple::Win32: | 
| 1418 |  |     // FIXME: this is invalid for WindowsCE | 
| 1419 | 0 |     return "cortex-a9"; | 
| 1420 | 0 |   case llvm_ks::Triple::MacOSX: | 
| 1421 | 0 |   case llvm_ks::Triple::IOS: | 
| 1422 | 0 |   case llvm_ks::Triple::WatchOS: | 
| 1423 | 0 |     if (MArch == "v7k") | 
| 1424 | 0 |       return "cortex-a7"; | 
| 1425 | 0 |     break; | 
| 1426 | 0 |   default: | 
| 1427 | 0 |     break; | 
| 1428 | 0 |   } | 
| 1429 |  |  | 
| 1430 | 0 |   if (MArch.empty()) | 
| 1431 | 0 |     return StringRef(); | 
| 1432 |  |  | 
| 1433 | 0 |   StringRef CPU = ARM::getDefaultCPU(MArch); | 
| 1434 | 0 |   if (!CPU.empty()) | 
| 1435 | 0 |     return CPU; | 
| 1436 |  |  | 
| 1437 |  |   // If no specific architecture version is requested, return the minimum CPU | 
| 1438 |  |   // required by the OS and environment. | 
| 1439 | 0 |   switch (getOS()) { | 
| 1440 | 0 |   case llvm_ks::Triple::NetBSD: | 
| 1441 | 0 |     switch (getEnvironment()) { | 
| 1442 | 0 |     case llvm_ks::Triple::GNUEABIHF: | 
| 1443 | 0 |     case llvm_ks::Triple::GNUEABI: | 
| 1444 | 0 |     case llvm_ks::Triple::EABIHF: | 
| 1445 | 0 |     case llvm_ks::Triple::EABI: | 
| 1446 | 0 |       return "arm926ej-s"; | 
| 1447 | 0 |     default: | 
| 1448 | 0 |       return "strongarm"; | 
| 1449 | 0 |     } | 
| 1450 | 0 |   case llvm_ks::Triple::NaCl: | 
| 1451 | 0 |     return "cortex-a8"; | 
| 1452 | 0 |   default: | 
| 1453 | 0 |     switch (getEnvironment()) { | 
| 1454 | 0 |     case llvm_ks::Triple::EABIHF: | 
| 1455 | 0 |     case llvm_ks::Triple::GNUEABIHF: | 
| 1456 | 0 |       return "arm1176jzf-s"; | 
| 1457 | 0 |     default: | 
| 1458 | 0 |       return "arm7tdmi"; | 
| 1459 | 0 |     } | 
| 1460 | 0 |   } | 
| 1461 |  |  | 
| 1462 | 0 |   llvm_unreachable("invalid arch name"); | 
| 1463 | 0 | } |