21 if (
T.getArchName() ==
"x86_64h")
33 case ARM::ArchKind::ARMV4T:
35 case ARM::ArchKind::ARMV5T:
36 case ARM::ArchKind::ARMV5TE:
37 case ARM::ArchKind::ARMV5TEJ:
39 case ARM::ArchKind::ARMV6:
40 case ARM::ArchKind::ARMV6K:
42 case ARM::ArchKind::ARMV7A:
44 case ARM::ArchKind::ARMV7S:
46 case ARM::ArchKind::ARMV7K:
48 case ARM::ArchKind::ARMV6M:
50 case ARM::ArchKind::ARMV7M:
52 case ARM::ArchKind::ARMV7EM:
73 "Unsupported triple for mach-o cpu %s: %s", Str,
78 if (!
T.isOSBinFormatMachO())
80 if (
T.isX86() &&
T.isArch32Bit())
82 if (
T.isX86() &&
T.isArch64Bit())
84 if (
T.isARM() ||
T.isThumb())
96 if (!
T.isOSBinFormatMachO())
100 if (
T.isARM() ||
T.isThumb())
110 unsigned PtrAuthABIVersion,
111 bool PtrAuthKernelABIVersion) {
114 return Result.takeError();
117 std::errc::invalid_argument,
118 "ptrauth ABI version is only supported on arm64e.");
119 if (PtrAuthABIVersion > 0xF)
121 std::errc::invalid_argument,
122 "The ptrauth ABI version needs to fit within 4 bits.");
124 PtrAuthKernelABIVersion);
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
Lightweight error class with error context and mandatory checking.
Tagged union holding either a T or a Error.
StringRef - Represent a constant reference to a string, i.e.
Triple - Helper class for working with autoconf configuration names.
ArchKind parseArch(StringRef Arch)
Expected< uint32_t > getCPUSubType(const Triple &T)
@ CPU_SUBTYPE_POWERPC_ALL
unsigned CPU_SUBTYPE_ARM64E_WITH_PTRAUTH_VERSION(unsigned PtrAuthABIVersion, bool PtrAuthKernelABIVersion)
@ CPU_SUBTYPE_ARM64_32_V8
Expected< uint32_t > getCPUType(const Triple &T)
This is an optimization pass for GlobalISel generic memory operations.
Error createStringError(std::error_code EC, char const *Fmt, const Ts &... Vals)
Create formatted StringError object.