50#define DEBUG_TYPE "asm-printer"
53 std::unique_ptr<MCStreamer> Streamer)
55 InConstantPool(
false), OptimizationGoals(-1) {}
66 InConstantPool =
false;
73 if (AFI->isThumbFunction()) {
81 if (AFI->isCmseNSEntryFunction()) {
93 assert(
Size &&
"C++ constructor pointer had zero size!");
96 assert(GV &&
"C++ constructor pointer was not a GlobalValue!");
107void ARMAsmPrinter::emitCMSEVeneerAlias(
const GlobalAlias &GA) {
132 emitCMSEVeneerAlias(GA);
136 if (PromotedGlobals.count(GV))
147 MCP =
MF.getConstantPool();
156 PromotedGlobals.insert_range(AFI->getGlobalsPromotedToConstantPool());
159 unsigned OptimizationGoal;
162 OptimizationGoal = 6;
163 else if (
F.hasMinSize())
165 OptimizationGoal = 4;
166 else if (
F.hasOptSize())
168 OptimizationGoal = 3;
171 OptimizationGoal = 2;
174 OptimizationGoal = 1;
177 OptimizationGoal = 5;
180 if (OptimizationGoals == -1)
181 OptimizationGoals = OptimizationGoal;
182 else if (OptimizationGoals != (
int)OptimizationGoal)
183 OptimizationGoals = 0;
185 if (
TM.getTargetTriple().isOSBinFormatCOFF()) {
186 bool Local =
F.hasLocalLinkage();
206 if (! ThumbIndirectPads.empty()) {
211 for (std::pair<unsigned, MCSymbol *> &TIP : ThumbIndirectPads) {
219 ThumbIndirectPads.clear();
257 if(ARM::GPRPairRegClass.
contains(Reg)) {
260 Reg =
TRI->getSubReg(Reg, ARM::gsub_0);
292 "execute-only should not generate constant pools");
310GetARMJTIPICJumpTableLabel(
unsigned uid)
const {
321 if (ExtraCode && ExtraCode[0]) {
322 if (ExtraCode[1] != 0)
return true;
324 switch (ExtraCode[0]) {
333 if (
MI->getOperand(OpNum).isReg()) {
334 MCRegister Reg =
MI->getOperand(OpNum).getReg().asMCReg();
341 bool Lane0 =
TRI->getSubReg(SR, ARM::ssub_0) == Reg;
348 if (!
MI->getOperand(OpNum).isImm())
350 O << ~(
MI->getOperand(OpNum).
getImm());
353 if (!
MI->getOperand(OpNum).isImm())
355 O << (
MI->getOperand(OpNum).
getImm() & 0xffff);
358 if (!
MI->getOperand(OpNum).isReg())
366 if (ARM::GPRPairRegClass.
contains(RegBegin)) {
368 Register Reg0 =
TRI->getSubReg(RegBegin, ARM::gsub_0);
370 RegBegin =
TRI->getSubReg(RegBegin, ARM::gsub_1);
378 unsigned RegOps = OpNum + 1;
379 while (
MI->getOperand(RegOps).isReg()) {
394 if (!FlagsOP.
isImm())
402 if (
F.isUseOperandTiedToDef(TiedIdx)) {
404 unsigned OpFlags =
MI->getOperand(OpNum).getImm();
406 OpNum +=
F.getNumOperandRegisters() + 1;
415 const unsigned NumVals =
F.getNumOperandRegisters();
424 if (ExtraCode[0] ==
'Q')
430 if (
F.hasRegClassConstraint(RC) &&
431 ARM::GPRPairRegClass.hasSubClassEq(
TRI->getRegClass(RC))) {
439 TRI->getSubReg(MO.
getReg(), FirstHalf ? ARM::gsub_0 : ARM::gsub_1);
445 unsigned RegOp = FirstHalf ? OpNum : OpNum + 1;
446 if (RegOp >=
MI->getNumOperands())
458 if (!
MI->getOperand(OpNum).isReg())
460 Register Reg =
MI->getOperand(OpNum).getReg();
461 if (!ARM::QPRRegClass.
contains(Reg))
465 TRI->getSubReg(Reg, ExtraCode[0] ==
'e' ? ARM::dsub_0 : ARM::dsub_1);
480 if(!ARM::GPRPairRegClass.
contains(Reg))
482 Reg =
TRI->getSubReg(Reg, ARM::gsub_1);
494 unsigned OpNum,
const char *ExtraCode,
497 if (ExtraCode && ExtraCode[0]) {
498 if (ExtraCode[1] != 0)
return true;
500 switch (ExtraCode[0]) {
502 default:
return true;
504 if (!
MI->getOperand(OpNum).isReg())
512 assert(MO.
isReg() &&
"unexpected inline asm memory operand");
526 const bool WasThumb =
isThumb(StartInfo);
527 if (!EndInfo || WasThumb !=
isThumb(*EndInfo)) {
538 const Triple &TT =
TM.getTargetTriple();
545 if (TT.isOSBinFormatELF())
550 if (!M.getModuleInlineAsm().empty() && TT.isThumb())
579 const Triple &TT =
TM.getTargetTriple();
580 if (TT.isOSBinFormatMachO()) {
590 if (!Stubs.empty()) {
595 for (
auto &Stub : Stubs)
603 if (!Stubs.empty()) {
608 for (
auto &Stub : Stubs)
627 if (OptimizationGoals > 0 &&
628 (TT.isTargetAEABI() || TT.isTargetGNUAEABI() || TT.isTargetMuslAEABI()))
630 OptimizationGoals = -1;
647 if (
F.isDeclaration())
649 return F.getFnAttribute(Attr).getValueAsString() !=
Value;
657 if (
F.isDeclaration())
659 return F.getDenormalFPEnv() !=
Value;
665 auto F = M.functions().begin();
666 auto E = M.functions().end();
672 return !
F.isDeclaration() &&
F.getDenormalFPEnv() !=
Value;
676void ARMAsmPrinter::emitAttributes() {
677 MCTargetStreamer &TS = *
OutStreamer->getTargetStreamer();
678 ARMTargetStreamer &ATS =
static_cast<ARMTargetStreamer &
>(TS);
689 const Triple &
TT =
TM.getTargetTriple();
690 StringRef CPU =
TM.getTargetCPU();
691 StringRef
FS =
TM.getTargetFeatureString();
695 ArchFS = (Twine(ArchFS) +
"," +
FS).str();
697 ArchFS = std::string(FS);
699 const ARMBaseTargetMachine &ATM =
700 static_cast<const ARMBaseTargetMachine &
>(
TM);
701 const ARMSubtarget STI(TT, std::string(CPU), ArchFS, ATM,
711 }
else if (STI.isRWPI()) {
734 MMI->getModule()->getModuleFlag(
"arm-eabi-fp-denormal"))) {
735 if (
unsigned TagVal =
DM->getZExtValue())
751 if (!STI.hasVFP2Base()) {
761 }
else if (STI.hasVFP3Base()) {
778 MMI->getModule()->getModuleFlag(
"arm-eabi-fp-exceptions"))) {
779 if (
unsigned TagVal = Ex->getZExtValue())
782 "no-trapping-math",
"true") ||
783 TM.Options.NoTrappingFPMath)
791 if (
TM.Options.HonorSignDependentRoundingFPMathOption)
797 MMI->getModule()->getModuleFlag(
"arm-eabi-fp-number-model"))) {
798 if (
unsigned TagVal = NumModel->getZExtValue())
820 if (
const Module *SourceModule =
MMI->getModule()) {
824 SourceModule->getModuleFlag(
"wchar_size"))) {
825 int WCharWidth = WCharWidthValue->getZExtValue();
826 assert((WCharWidth == 2 || WCharWidth == 4) &&
827 "wchar_t width must be 2 or 4 bytes");
835 SourceModule->getModuleFlag(
"min_enum_size"))) {
836 int EnumWidth = EnumWidthValue->getZExtValue();
837 assert((EnumWidth == 1 || EnumWidth == 4) &&
838 "Minimum enum width must be 1 or 4 bytes");
839 int EnumBuildAttr = EnumWidth == 1 ? 1 : 2;
844 SourceModule->getModuleFlag(
"sign-return-address"));
845 if (PACValue && PACValue->isOne()) {
849 if (!STI.hasPACBTI()) {
857 SourceModule->getModuleFlag(
"branch-target-enforcement"));
858 if (BTIValue && !BTIValue->isZero()) {
862 if (!STI.hasPACBTI()) {
874 else if (STI.isR9Reserved())
888 +
"BF" +
Twine(FunctionNumber) +
"_" +
Twine(LabelId));
896 +
"PC" +
Twine(FunctionNumber) +
"_" +
Twine(LabelId));
921 unsigned char TargetFlags) {
922 const Triple &
TT =
TM.getTargetTriple();
923 if (
TT.isOSBinFormatMachO()) {
932 MachineModuleInfoMachO &MMIMachO =
933 MMI->getObjFileInfo<MachineModuleInfoMachO>();
938 if (!StubSym.getPointer())
942 }
else if (
TT.isOSBinFormatCOFF()) {
943 assert(
TT.isOSWindows() &&
"Windows is the only supported COFF target");
950 SmallString<128>
Name;
960 MachineModuleInfoCOFF &MMICOFF =
961 MMI->getObjFileInfo<MachineModuleInfoCOFF>();
965 if (!StubSym.getPointer())
970 }
else if (
TT.isOSBinFormatELF()) {
994 for (
const auto *GV : ACPC->promotedGlobals()) {
995 if (!EmittedPromotedGlobalLabels.count(GV)) {
998 EmittedPromotedGlobalLabels.insert(GV);
1018 MCSym = GetARMGVSymbol(GV, TF);
1021 MCSym =
MBB->getSymbol();
1064 MCSymbol *JTISymbol = GetARMJTIPICJumpTableLabel(JTI);
1072 const std::vector<MachineJumpTableEntry> &JT = MJTI->
getJumpTables();
1073 const std::vector<MachineBasicBlock*> &JTBBs = JT[JTI].MBBs;
1093 else if (AFI->isThumbFunction())
1111 MCSymbol *JTISymbol = GetARMJTIPICJumpTableLabel(JTI);
1116 const std::vector<MachineJumpTableEntry> &JT = MJTI->
getJumpTables();
1117 const std::vector<MachineBasicBlock*> &JTBBs = JT[JTI].MBBs;
1124 .addExpr(MBBSymbolExpr)
1131 unsigned OffsetWidth) {
1132 assert((OffsetWidth == 1 || OffsetWidth == 2) &&
"invalid tbb/tbh width");
1140 MCSymbol *JTISymbol = GetARMJTIPICJumpTableLabel(JTI);
1145 const std::vector<MachineJumpTableEntry> &JT = MJTI->
getJumpTables();
1146 const std::vector<MachineBasicBlock*> &JTBBs = JT[JTI].MBBs;
1152 for (
auto *
MBB : JTBBs) {
1188 const MCSymbol *BranchLabel)
const {
1198 BaseLabel = GetARMJTIPICJumpTableLabel(JTI);
1205 BaseLabel = BranchLabel;
1213 BaseLabel = BranchLabel;
1218 BaseLabel =
nullptr;
1225 return std::make_tuple(BaseLabel, BaseOffset, BranchLabel, EntrySize);
1228void ARMAsmPrinter::EmitUnwindingInstruction(
const MachineInstr *
MI) {
1230 "Only instruction which are involved into frame setup code are allowed");
1240 unsigned Opc =
MI->getOpcode();
1241 unsigned SrcReg, DstReg;
1246 SrcReg = DstReg = ARM::SP;
1250 case ARM::t2MOVTi16:
1271 DstReg =
MI->getOperand(0).getReg();
1274 SrcReg = ARM::FPSCR;
1275 DstReg =
MI->getOperand(0).getReg();
1277 case ARM::VMRS_FPEXC:
1278 SrcReg = ARM::FPEXC;
1279 DstReg =
MI->getOperand(0).getReg();
1282 SrcReg =
MI->getOperand(1).getReg();
1283 DstReg =
MI->getOperand(0).getReg();
1288 if (
MI->mayStore()) {
1290 assert(DstReg == ARM::SP &&
1291 "Only stack pointer as a destination reg is supported");
1295 unsigned StartOp = 2 + 2;
1297 unsigned NumOffset = 0;
1300 unsigned PadBefore = 0;
1303 unsigned PadAfter = 0;
1311 StartOp = 2; NumOffset = 2;
1313 case ARM::STMDB_UPD:
1314 case ARM::t2STMDB_UPD:
1315 case ARM::VSTMDDB_UPD:
1316 assert(SrcReg == ARM::SP &&
1317 "Only stack pointer as a source reg is supported");
1318 for (
unsigned i = StartOp,
NumOps =
MI->getNumOperands() - NumOffset;
1331 "Pad registers must come before restored ones");
1340 if (
unsigned RemappedReg = AFI->EHPrologueRemappedRegs.lookup(
Reg))
1345 case ARM::STR_PRE_IMM:
1346 case ARM::STR_PRE_REG:
1347 case ARM::t2STR_PRE:
1348 assert(
MI->getOperand(2).getReg() == ARM::SP &&
1349 "Only stack pointer as a source reg is supported");
1350 if (
unsigned RemappedReg = AFI->EHPrologueRemappedRegs.lookup(SrcReg))
1351 SrcReg = RemappedReg;
1355 case ARM::t2STRD_PRE:
1356 assert(
MI->getOperand(3).getReg() == ARM::SP &&
1357 "Only stack pointer as a source reg is supported");
1358 SrcReg =
MI->getOperand(1).getReg();
1359 if (
unsigned RemappedReg = AFI->EHPrologueRemappedRegs.lookup(SrcReg))
1360 SrcReg = RemappedReg;
1362 SrcReg =
MI->getOperand(2).getReg();
1363 if (
unsigned RemappedReg = AFI->EHPrologueRemappedRegs.lookup(SrcReg))
1364 SrcReg = RemappedReg;
1366 PadBefore = -
MI->getOperand(4).getImm() - 8;
1379 if (SrcReg == ARM::SP) {
1395 case ARM::t2ADDri12:
1396 case ARM::t2ADDspImm:
1397 case ARM::t2ADDspImm12:
1398 Offset = -
MI->getOperand(2).getImm();
1402 case ARM::t2SUBri12:
1403 case ARM::t2SUBspImm:
1404 case ARM::t2SUBspImm12:
1405 Offset =
MI->getOperand(2).getImm();
1408 Offset =
MI->getOperand(2).getImm()*4;
1412 Offset = -
MI->getOperand(2).getImm()*4;
1416 -AFI->EHPrologueOffsetInRegs.lookup(
MI->getOperand(2).getReg());
1425 else if (DstReg == ARM::SP) {
1435 }
else if (DstReg == ARM::SP) {
1445 AFI->EHPrologueRemappedRegs[DstReg] = SrcReg;
1448 case ARM::VMRS_FPEXC:
1455 case ARM::tLDRpci: {
1458 unsigned CPI =
MI->getOperand(1).getIndex();
1459 const MachineConstantPool *MCP =
MF.getConstantPool();
1460 if (CPI >= MCP->getConstants().size())
1461 CPI = AFI->getOriginalCPIdx(CPI);
1462 assert(CPI != -1U &&
"Invalid constpool index");
1465 const MachineConstantPoolEntry &CPE = MCP->getConstants()[CPI];
1468 AFI->EHPrologueOffsetInRegs[DstReg] =
Offset;
1472 Offset =
MI->getOperand(1).getImm();
1473 AFI->EHPrologueOffsetInRegs[DstReg] =
Offset;
1475 case ARM::t2MOVTi16:
1476 Offset =
MI->getOperand(2).getImm();
1477 AFI->EHPrologueOffsetInRegs[DstReg] |= (
Offset << 16);
1480 Offset =
MI->getOperand(2).getImm();
1481 AFI->EHPrologueOffsetInRegs[DstReg] =
Offset;
1484 assert(
MI->getOperand(3).getImm() == 8 &&
1485 "The shift amount is not equal to 8");
1486 assert(
MI->getOperand(2).getReg() ==
MI->getOperand(0).getReg() &&
1487 "The source register is not equal to the destination register");
1488 AFI->EHPrologueOffsetInRegs[DstReg] <<= 8;
1491 assert(
MI->getOperand(2).getReg() ==
MI->getOperand(0).getReg() &&
1492 "The source register is not equal to the destination register");
1493 Offset =
MI->getOperand(3).getImm();
1494 AFI->EHPrologueOffsetInRegs[DstReg] +=
Offset;
1498 AFI->EHPrologueRemappedRegs[ARM::R12] = ARM::RA_AUTH_CODE;
1510#include "ARMGenMCPseudoLowering.inc"
1523void ARMAsmPrinter::EmitKCFI_CHECK_ARM32(
Register AddrReg, int64_t
Type,
1525 int64_t PrefixNops) {
1527 unsigned ScratchReg = ARM::R12;
1528 if (AddrReg == ARM::R12) {
1529 ScratchReg = ARM::R3;
1534 const ARMBaseRegisterInfo *
TRI =
static_cast<const ARMBaseRegisterInfo *
>(
1535 MF->getSubtarget().getRegisterInfo());
1536 unsigned AddrIndex =
TRI->getEncodingValue(AddrReg);
1537 unsigned ESR = 0x8000 | (31 << 5) | (AddrIndex & 31);
1571 .addImm(-(PrefixNops * 4 + 4))
1576 for (
int i = 0; i < 4; i++) {
1577 uint8_t
byte = (
Type >> (i * 8)) & 0xFF;
1578 uint32_t imm =
byte << (i * 8);
1579 bool isLast = (i == 3);
1584 "Cannot encode immediate as ARM modified immediate");
1588 MCInstBuilder(ARM::EORri)
1594 .addReg(isLast ? ARM::CPSR : ARM::NoRegister));
1612 MCInstBuilder(ARM::Bcc)
1615 .addReg(ARM::CPSR));
1623void ARMAsmPrinter::EmitKCFI_CHECK_Thumb2(
Register AddrReg, int64_t
Type,
1625 int64_t PrefixNops) {
1627 unsigned ScratchReg = ARM::R12;
1628 if (AddrReg == ARM::R12) {
1629 ScratchReg = ARM::R3;
1636 const ARMBaseRegisterInfo *
TRI =
static_cast<const ARMBaseRegisterInfo *
>(
1637 MF->getSubtarget().getRegisterInfo());
1638 unsigned AddrIndex =
TRI->getEncodingValue(AddrReg);
1639 unsigned ESR = 0x80 | (AddrIndex & 0x1F);
1650 MCInstBuilder(ARM::tPUSH).addImm(
ARMCC::AL).addReg(0).addReg(ARM::R3));
1670 .addImm(-(PrefixNops * 4 + 4))
1675 for (
int i = 0; i < 4; i++) {
1676 uint8_t
byte = (
Type >> (i * 8)) & 0xFF;
1677 uint32_t imm =
byte << (i * 8);
1678 bool isLast = (i == 3);
1682 "Cannot encode immediate as Thumb2 modified immediate");
1686 MCInstBuilder(ARM::t2EORri)
1692 .addReg(isLast ? ARM::CPSR : ARM::NoRegister));
1701 MCInstBuilder(ARM::tPOP).addImm(
ARMCC::AL).addReg(0).addReg(ARM::R3));
1707 MCInstBuilder(ARM::t2Bcc)
1710 .addReg(ARM::CPSR));
1718void ARMAsmPrinter::EmitKCFI_CHECK_Thumb1(
Register AddrReg, int64_t
Type,
1720 int64_t PrefixNops) {
1723 unsigned ScratchReg = ARM::R2;
1724 unsigned TempReg = ARM::R3;
1733 MCInstBuilder(ARM::tPUSH).addImm(
ARMCC::AL).addReg(0).addReg(ARM::R3));
1743 MCInstBuilder(ARM::tPUSH).addImm(
ARMCC::AL).addReg(0).addReg(ARM::R2));
1774 int offset = PrefixNops * 4 + 4;
1804 uint8_t byte0 = (
Type >> 0) & 0xFF;
1805 uint8_t byte1 = (
Type >> 8) & 0xFF;
1806 uint8_t byte2 = (
Type >> 16) & 0xFF;
1807 uint8_t byte3 = (
Type >> 24) & 0xFF;
1883 MCInstBuilder(ARM::tPOP).addImm(
ARMCC::AL).addReg(0).addReg(ARM::R2));
1891 MCInstBuilder(ARM::tPOP).addImm(
ARMCC::AL).addReg(0).addReg(ARM::R3));
1897 MCInstBuilder(ARM::tBcc)
1900 .addReg(ARM::CPSR));
1909 Register AddrReg =
MI.getOperand(0).getReg();
1910 const int64_t
Type =
MI.getOperand(1).getImm();
1913 assert(std::next(
MI.getIterator())->isCall() &&
1914 "KCFI_CHECK not followed by a call instruction");
1918 int64_t PrefixNops = 0;
1921 .getFnAttribute(
"patchable-function-prefix")
1923 .getAsInteger(10, PrefixNops);
1926 switch (
MI.getOpcode()) {
1927 case ARM::KCFI_CHECK_ARM:
1928 EmitKCFI_CHECK_ARM32(AddrReg,
Type,
Call, PrefixNops);
1930 case ARM::KCFI_CHECK_Thumb2:
1931 EmitKCFI_CHECK_Thumb2(AddrReg,
Type,
Call, PrefixNops);
1933 case ARM::KCFI_CHECK_Thumb1:
1934 EmitKCFI_CHECK_Thumb1(AddrReg,
Type,
Call, PrefixNops);
1942 ARM_MC::verifyInstructionPredicates(
MI->getOpcode(),
1951 if (InConstantPool &&
MI->getOpcode() != ARM::CONSTPOOL_ENTRY) {
1953 InConstantPool =
false;
1957 if (
TM.getTargetTriple().isTargetEHABICompatible() &&
1959 EmitUnwindingInstruction(
MI);
1962 if (
MCInst OutInst; lowerPseudoInstExpansion(
MI, OutInst)) {
1968 "Pseudo flag setting opcode should be expanded early");
1971 unsigned Opc =
MI->getOpcode();
1973 case ARM::t2MOVi32imm:
llvm_unreachable(
"Should be lowered by thumb2it pass");
1974 case ARM::DBG_VALUE:
llvm_unreachable(
"Should be handled by generic printing");
1975 case ARM::KCFI_CHECK_ARM:
1976 case ARM::KCFI_CHECK_Thumb2:
1977 case ARM::KCFI_CHECK_Thumb1:
1981 case ARM::tLEApcrel:
1982 case ARM::t2LEApcrel: {
1986 ARM::t2LEApcrel ? ARM::t2ADR
1987 : (
MI->getOpcode() == ARM::tLEApcrel ? ARM::tADR
1989 .
addReg(
MI->getOperand(0).getReg())
1992 .
addImm(
MI->getOperand(2).getImm())
1993 .
addReg(
MI->getOperand(3).getReg()));
1996 case ARM::LEApcrelJT:
1997 case ARM::tLEApcrelJT:
1998 case ARM::t2LEApcrelJT: {
2000 GetARMJTIPICJumpTableLabel(
MI->getOperand(1).getIndex());
2002 ARM::t2LEApcrelJT ? ARM::t2ADR
2003 : (
MI->getOpcode() == ARM::tLEApcrelJT ? ARM::tADR
2005 .
addReg(
MI->getOperand(0).getReg())
2008 .
addImm(
MI->getOperand(2).getImm())
2009 .
addReg(
MI->getOperand(3).getReg()));
2014 case ARM::BX_CALL: {
2024 assert(STI.hasV4TOps() &&
"Expected V4TOps for BX call");
2029 case ARM::tBX_CALL: {
2030 assert(!STI.hasV5TOps() &&
"Expected BLX to be selected for v5t+");
2040 for (std::pair<unsigned, MCSymbol *> &TIP : ThumbIndirectPads) {
2041 if (TIP.first == TReg) {
2042 TRegSym = TIP.second;
2049 ThumbIndirectPads.push_back(std::make_pair(TReg, TRegSym));
2059 case ARM::BMOVPCRX_CALL: {
2071 .addReg(
MI->getOperand(0).getReg())
2079 case ARM::BMOVPCB_CALL: {
2091 const unsigned TF =
Op.getTargetFlags();
2092 MCSymbol *GVSym = GetARMGVSymbol(GV, TF);
2101 case ARM::MOVi16_ga_pcrel:
2102 case ARM::t2MOVi16_ga_pcrel: {
2104 TmpInst.
setOpcode(
Opc == ARM::MOVi16_ga_pcrel? ARM::MOVi16 : ARM::t2MOVi16);
2107 unsigned TF =
MI->getOperand(1).getTargetFlags();
2109 MCSymbol *GVSym = GetARMGVSymbol(GV, TF);
2116 unsigned PCAdj = (
Opc == ARM::MOVi16_ga_pcrel) ? 8 : 4;
2135 case ARM::MOVTi16_ga_pcrel:
2136 case ARM::t2MOVTi16_ga_pcrel: {
2139 ? ARM::MOVTi16 : ARM::t2MOVTi16);
2143 unsigned TF =
MI->getOperand(2).getTargetFlags();
2145 MCSymbol *GVSym = GetARMGVSymbol(GV, TF);
2152 unsigned PCAdj = (
Opc == ARM::MOVTi16_ga_pcrel) ? 8 : 4;
2183 if (
MI->getOperand(1).isReg()) {
2185 MCInst.addReg(
MI->getOperand(1).getReg());
2188 const MCExpr *BranchTarget;
2189 if (
MI->getOperand(1).isMBB())
2192 else if (
MI->getOperand(1).isGlobal()) {
2195 GetARMGVSymbol(GV,
MI->getOperand(1).getTargetFlags()),
OutContext);
2196 }
else if (
MI->getOperand(1).isSymbol()) {
2203 MCInst.addExpr(BranchTarget);
2206 if (
Opc == ARM::t2BFic) {
2211 MCInst.addExpr(ElseLabel);
2212 MCInst.addImm(
MI->getOperand(3).getImm());
2214 MCInst.addImm(
MI->getOperand(2).getImm())
2215 .addReg(
MI->getOperand(3).getReg());
2221 case ARM::t2BF_LabelPseudo: {
2230 case ARM::tPICADD: {
2243 .addReg(
MI->getOperand(0).getReg())
2244 .
addReg(
MI->getOperand(0).getReg())
2264 .addReg(
MI->getOperand(0).getReg())
2266 .
addReg(
MI->getOperand(1).getReg())
2268 .
addImm(
MI->getOperand(3).getImm())
2269 .
addReg(
MI->getOperand(4).getReg())
2281 case ARM::PICLDRSH: {
2295 switch (
MI->getOpcode()) {
2298 case ARM::PICSTR: Opcode = ARM::STRrs;
break;
2299 case ARM::PICSTRB: Opcode = ARM::STRBrs;
break;
2300 case ARM::PICSTRH: Opcode = ARM::STRH;
break;
2301 case ARM::PICLDR: Opcode = ARM::LDRrs;
break;
2302 case ARM::PICLDRB: Opcode = ARM::LDRBrs;
break;
2303 case ARM::PICLDRH: Opcode = ARM::LDRH;
break;
2304 case ARM::PICLDRSB: Opcode = ARM::LDRSB;
break;
2305 case ARM::PICLDRSH: Opcode = ARM::LDRSH;
break;
2308 .addReg(
MI->getOperand(0).getReg())
2310 .
addReg(
MI->getOperand(1).getReg())
2313 .
addImm(
MI->getOperand(3).getImm())
2314 .
addReg(
MI->getOperand(4).getReg()));
2318 case ARM::CONSTPOOL_ENTRY: {
2319 assert(!STI.genExecuteOnly() &&
2320 "execute-only should not generate constant pools");
2327 unsigned LabelId = (
unsigned)
MI->getOperand(0).getImm();
2328 unsigned CPIdx = (
unsigned)
MI->getOperand(1).getIndex();
2331 if (!InConstantPool) {
2333 InConstantPool =
true;
2345 case ARM::JUMPTABLE_ADDRS:
2348 case ARM::JUMPTABLE_INSTS:
2351 case ARM::JUMPTABLE_TBB:
2352 case ARM::JUMPTABLE_TBH:
2355 case ARM::t2BR_JT: {
2358 .addReg(
MI->getOperand(0).getReg())
2365 case ARM::t2TBH_JT: {
2366 unsigned Opc =
MI->getOpcode() == ARM::t2TBB_JT ? ARM::t2TBB : ARM::t2TBH;
2370 .addReg(
MI->getOperand(0).getReg())
2371 .
addReg(
MI->getOperand(1).getReg())
2378 case ARM::tTBH_JT: {
2380 bool Is8Bit =
MI->getOpcode() == ARM::tTBB_JT;
2383 assert(
MI->getOperand(1).isKill() &&
"We need the index register as scratch!");
2396 if (
Base == ARM::PC) {
2419 unsigned Opc = Is8Bit ? ARM::tLDRBi : ARM::tLDRHi;
2423 .addImm(Is8Bit ? 4 : 2)
2433 unsigned Opc = Is8Bit ? ARM::tLDRBr : ARM::tLDRHr;
2466 unsigned Opc =
MI->getOpcode() == ARM::BR_JTr ?
2467 ARM::MOVr : ARM::tMOVr;
2475 if (
Opc == ARM::MOVr)
2480 case ARM::BR_JTm_i12: {
2493 case ARM::BR_JTm_rs: {
2507 case ARM::BR_JTadd: {
2511 .addReg(
MI->getOperand(0).getReg())
2512 .
addReg(
MI->getOperand(1).getReg())
2526 if (!
TM.getTargetTriple().isOSBinFormatMachO()) {
2537 if (!
TM.getTargetTriple().isOSBinFormatMachO()) {
2545 case ARM::t2Int_eh_sjlj_setjmp:
2546 case ARM::t2Int_eh_sjlj_setjmp_nofp:
2547 case ARM::tInt_eh_sjlj_setjmp: {
2556 Register SrcReg =
MI->getOperand(0).getReg();
2557 Register ValReg =
MI->getOperand(1).getReg();
2597 .addExpr(SymbolExpr)
2614 case ARM::Int_eh_sjlj_setjmp_nofp:
2615 case ARM::Int_eh_sjlj_setjmp: {
2622 Register SrcReg =
MI->getOperand(0).getReg();
2623 Register ValReg =
MI->getOperand(1).getReg();
2674 case ARM::Int_eh_sjlj_longjmp: {
2679 Register SrcReg =
MI->getOperand(0).getReg();
2680 Register ScratchReg =
MI->getOperand(1).getReg();
2733 case ARM::tInt_eh_sjlj_longjmp: {
2739 Register SrcReg =
MI->getOperand(0).getReg();
2740 Register ScratchReg =
MI->getOperand(1).getReg();
2802 case ARM::tInt_WIN_eh_sjlj_longjmp: {
2807 Register SrcReg =
MI->getOperand(0).getReg();
2832 case ARM::PATCHABLE_FUNCTION_ENTER:
2835 case ARM::PATCHABLE_FUNCTION_EXIT:
2838 case ARM::PATCHABLE_TAIL_CALL:
2841 case ARM::SpeculationBarrierISBDSBEndBB: {
2853 case ARM::t2SpeculationBarrierISBDSBEndBB: {
2869 case ARM::SpeculationBarrierSBEndBB: {
2876 case ARM::t2SpeculationBarrierSBEndBB: {
2884 case ARM::SEH_StackAlloc:
2886 MI->getOperand(1).getImm());
2889 case ARM::SEH_SaveRegs:
2890 case ARM::SEH_SaveRegs_Ret:
2892 MI->getOperand(1).getImm());
2895 case ARM::SEH_SaveSP:
2899 case ARM::SEH_SaveFRegs:
2901 MI->getOperand(1).getImm());
2904 case ARM::SEH_SaveLR:
2909 case ARM::SEH_Nop_Ret:
2913 case ARM::SEH_PrologEnd:
2917 case ARM::SEH_EpilogStart:
2921 case ARM::SEH_EpilogEnd:
2943LLVMInitializeARMAsmPrinter() {
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static bool isRegisterLiveInCall(const MachineInstr &Call, MCRegister Reg)
static void emitNonLazySymbolPointer(MCStreamer &OutStreamer, MCSymbol *StubLabel, MachineModuleInfoImpl::StubValueTy &MCSym)
static uint8_t getModifierSpecifier(ARMCP::ARMCPModifier Modifier)
static MCSymbol * getPICLabel(StringRef Prefix, unsigned FunctionNumber, unsigned LabelId, MCContext &Ctx)
static bool checkDenormalAttributeInconsistency(const Module &M)
static bool checkDenormalAttributeConsistency(const Module &M, DenormalFPEnv Value)
static bool checkFunctionsAttributeConsistency(const Module &M, StringRef Attr, StringRef Value)
static bool isThumb(const MCSubtargetInfo &STI)
static MCSymbol * getBFLabel(StringRef Prefix, unsigned FunctionNumber, unsigned LabelId, MCContext &Ctx)
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_EXTERNAL_VISIBILITY
This file contains the declarations for the subclasses of Constant, which represent the different fla...
static RegisterPass< DebugifyModulePass > DM("debugify", "Attach debug info to everything")
Module.h This file contains the declarations for the Module class.
const size_t AbstractManglingParser< Derived, Alloc >::NumOps
Machine Check Debug Module
Register const TargetRegisterInfo * TRI
Promote Memory to Register
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
static bool contains(SmallPtrSetImpl< ConstantExpr * > &Cache, ConstantExpr *Expr, Constant *C)
This file defines the SmallString class.
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
static const unsigned FramePtr
void emitJumpTableAddrs(const MachineInstr *MI)
void emitJumpTableTBInst(const MachineInstr *MI, unsigned OffsetWidth)
void emitFunctionBodyEnd() override
Targets can override this to emit stuff after the last basic block in the function.
bool runOnMachineFunction(MachineFunction &F) override
runOnMachineFunction - This uses the emitInstruction() method to print assembly for each instruction.
MCSymbol * GetCPISymbol(unsigned CPID) const override
Return the symbol for the specified constant pool entry.
void printOperand(const MachineInstr *MI, int OpNum, raw_ostream &O)
void emitStartOfAsmFile(Module &M) override
This virtual method can be overridden by targets that want to emit something at the start of their fi...
ARMAsmPrinter(TargetMachine &TM, std::unique_ptr< MCStreamer > Streamer)
void emitFunctionEntryLabel() override
EmitFunctionEntryLabel - Emit the label that is the entrypoint for the function.
void LowerPATCHABLE_FUNCTION_EXIT(const MachineInstr &MI)
void emitMachineConstantPoolValue(MachineConstantPoolValue *MCPV) override
EmitMachineConstantPoolValue - Print a machine constantpool value to the .s file.
bool PrintAsmOperand(const MachineInstr *MI, unsigned OpNum, const char *ExtraCode, raw_ostream &O) override
Print the specified operand of MI, an INLINEASM instruction, using the specified assembler variant.
void emitXXStructor(const DataLayout &DL, const Constant *CV) override
Targets can override this to change how global constants that are part of a C++ static/global constru...
void LowerPATCHABLE_FUNCTION_ENTER(const MachineInstr &MI)
void LowerPATCHABLE_TAIL_CALL(const MachineInstr &MI)
void emitEndOfAsmFile(Module &M) override
This virtual method can be overridden by targets that want to emit something at the end of their file...
std::tuple< const MCSymbol *, uint64_t, const MCSymbol *, codeview::JumpTableEntrySize > getCodeViewJumpTableInfo(int JTI, const MachineInstr *BranchInstr, const MCSymbol *BranchLabel) const override
Gets information required to create a CodeView debug symbol for a jump table.
void emitJumpTableInsts(const MachineInstr *MI)
const ARMBaseTargetMachine & getTM() const
void emitGlobalVariable(const GlobalVariable *GV) override
Emit the specified global variable to the .s file.
bool PrintAsmMemoryOperand(const MachineInstr *MI, unsigned OpNum, const char *ExtraCode, raw_ostream &O) override
Print the specified operand of MI, an INLINEASM instruction, using the specified assembler variant as...
void emitInstruction(const MachineInstr *MI) override
Targets should implement this to emit instructions.
void PrintSymbolOperand(const MachineOperand &MO, raw_ostream &O) override
Print the MachineOperand as a symbol.
void emitInlineAsmEnd(const MCSubtargetInfo &StartInfo, const MCSubtargetInfo *EndInfo, const MachineInstr *MI) override
Let the target do anything it needs to do after emitting inlineasm.
void LowerKCFI_CHECK(const MachineInstr &MI)
void emitGlobalAlias(const Module &M, const GlobalAlias &GA) override
bool isGVIndirectSymbol(const GlobalValue *GV) const
bool isLittleEndian() const
ARMConstantPoolValue - ARM specific constantpool value.
bool isPromotedGlobal() const
unsigned char getPCAdjustment() const
bool isMachineBasicBlock() const
bool isGlobalValue() const
ARMCP::ARMCPModifier getModifier() const
bool mustAddCurrentAddress() const
unsigned getLabelId() const
bool isBlockAddress() const
ARMFunctionInfo - This class is derived from MachineFunctionInfo and contains private ARM-specific in...
static const char * getRegisterName(MCRegister Reg, unsigned AltIdx=ARM::NoRegAltName)
bool isThumb1Only() const
MCPhysReg getFramePointerReg() const
bool isTargetWindows() const
bool isTargetDarwin() const
void emitTargetAttributes(const MCSubtargetInfo &STI)
Emit the build attributes that only depend on the hardware that we expect.
virtual void emitSetFP(MCRegister FpReg, MCRegister SpReg, int64_t Offset=0)
virtual void finishAttributeSection()
virtual void emitMovSP(MCRegister Reg, int64_t Offset=0)
virtual void emitARMWinCFISaveSP(unsigned Reg)
virtual void emitInst(uint32_t Inst, char Suffix='\0')
virtual void emitARMWinCFISaveLR(unsigned Offset)
virtual void emitTextAttribute(unsigned Attribute, StringRef String)
virtual void emitARMWinCFIAllocStack(unsigned Size, bool Wide)
virtual void emitARMWinCFISaveRegMask(unsigned Mask, bool Wide)
virtual void emitRegSave(const SmallVectorImpl< MCRegister > &RegList, bool isVector)
virtual void emitARMWinCFIEpilogEnd()
virtual void emitARMWinCFIPrologEnd(bool Fragment)
virtual void switchVendor(StringRef Vendor)
virtual void emitCode16()
virtual void emitARMWinCFISaveFRegs(unsigned First, unsigned Last)
virtual void emitSyntaxUnified()
virtual void emitARMWinCFIEpilogStart(unsigned Condition)
virtual void emitPad(int64_t Offset)
virtual void emitAttribute(unsigned Attribute, unsigned Value)
virtual void emitARMWinCFINop(bool Wide)
const TargetLoweringObjectFile & getObjFileLowering() const
Return information about object file lowering.
MCSymbol * getSymbolWithGlobalValueBase(const GlobalValue *GV, StringRef Suffix) const
Return the MCSymbol for a private symbol with global value name as its base, with the specified suffi...
MCSymbol * getSymbol(const GlobalValue *GV) const
void EmitToStreamer(MCStreamer &S, const MCInst &Inst)
virtual void emitGlobalVariable(const GlobalVariable *GV)
Emit the specified global variable to the .s file.
TargetMachine & TM
Target machine description.
void emitXRayTable()
Emit a table with all XRay instrumentation points.
virtual void emitGlobalAlias(const Module &M, const GlobalAlias &GA)
MCSymbol * getMBBExceptionSym(const MachineBasicBlock &MBB)
const MCAsmInfo * MAI
Target Asm Printer information.
MachineFunction * MF
The current machine function.
virtual void SetupMachineFunction(MachineFunction &MF)
This should be called when a new MachineFunction is being processed from runOnMachineFunction.
void emitFunctionBody()
This method emits the body and trailer for a function.
virtual void emitLinkage(const GlobalValue *GV, MCSymbol *GVSym) const
This emits linkage information about GVSym based on GV, if this is supported by the target.
unsigned getFunctionNumber() const
Return a unique ID for the current function.
AsmPrinter(TargetMachine &TM, std::unique_ptr< MCStreamer > Streamer, char &ID=AsmPrinter::ID)
void printOffset(int64_t Offset, raw_ostream &OS) const
This is just convenient handler for printing offsets.
void emitGlobalConstant(const DataLayout &DL, const Constant *CV, AliasMapTy *AliasList=nullptr)
EmitGlobalConstant - Print a general LLVM constant to the .s file.
MCSymbol * getSymbolPreferLocal(const GlobalValue &GV) const
Similar to getSymbol() but preferred for references.
MCSymbol * CurrentFnSym
The symbol for the current function.
MachineModuleInfo * MMI
This is a pointer to the current MachineModuleInfo.
void emitAlignment(Align Alignment, const GlobalObject *GV=nullptr, unsigned MaxBytesToEmit=0) const
Emit an alignment directive to the specified power of two boundary.
MCContext & OutContext
This is the context for the output file that we are streaming.
bool isPositionIndependent() const
void emitVisibility(MCSymbol *Sym, unsigned Visibility, bool IsDefinition=true) const
This emits visibility information about symbol, if this is supported by the target.
std::unique_ptr< MCStreamer > OutStreamer
This is the MCStreamer object for the file we are generating.
void getNameWithPrefix(SmallVectorImpl< char > &Name, const GlobalValue *GV) const
MCSymbol * GetBlockAddressSymbol(const BlockAddress *BA) const
Return the MCSymbol used to satisfy BlockAddress uses of the specified basic block.
const DataLayout & getDataLayout() const
Return information about data layout.
virtual void emitFunctionEntryLabel()
EmitFunctionEntryLabel - Emit the label that is the entrypoint for the function.
MCSymbol * GetExternalSymbolSymbol(const Twine &Sym) const
Return the MCSymbol for the specified ExternalSymbol.
const MCSubtargetInfo & getSubtargetInfo() const
Return information about subtarget.
virtual bool PrintAsmOperand(const MachineInstr *MI, unsigned OpNo, const char *ExtraCode, raw_ostream &OS)
Print the specified operand of MI, an INLINEASM instruction, using the specified assembler variant.
The address of a basic block.
This is an important base class in LLVM.
const Constant * stripPointerCasts() const
A parsed version of the target data layout string in and methods for querying it.
LLVM_ABI TypeSize getTypeAllocSize(Type *Ty) const
Returns the offset in bytes between successive objects of the specified type, including alignment pad...
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
LLVM_ABI const GlobalObject * getAliaseeObject() const
bool isThreadLocal() const
If the value is "Thread Local", its value isn't shared by the threads.
VisibilityTypes getVisibility() const
bool hasInternalLinkage() const
static const MCBinaryExpr * createAdd(const MCExpr *LHS, const MCExpr *RHS, MCContext &Ctx, SMLoc Loc=SMLoc())
static const MCBinaryExpr * createDiv(const MCExpr *LHS, const MCExpr *RHS, MCContext &Ctx)
static const MCBinaryExpr * createSub(const MCExpr *LHS, const MCExpr *RHS, MCContext &Ctx)
static LLVM_ABI const MCConstantExpr * create(int64_t Value, MCContext &Ctx, bool PrintInHex=false, unsigned SizeInBytes=0)
Context object for machine code objects.
LLVM_ABI MCSymbol * getOrCreateSymbol(const Twine &Name)
Lookup the symbol inside with the specified Name.
Base class for the full range of assembler expressions which are needed for parsing.
MCInstBuilder & addReg(MCRegister Reg)
Add a new register operand.
MCInstBuilder & addImm(int64_t Val)
Add a new integer immediate operand.
MCInstBuilder & addExpr(const MCExpr *Val)
Add a new MCExpr operand.
Instances of this class represent a single low-level machine instruction.
void addOperand(const MCOperand Op)
void setOpcode(unsigned Op)
MCSection * getThreadLocalPointerSection() const
MCSection * getNonLazySymbolPointerSection() const
static MCOperand createExpr(const MCExpr *Val)
static MCOperand createReg(MCRegister Reg)
static MCOperand createImm(int64_t Val)
Wrapper class representing physical registers. Should be passed by value.
Streaming machine code generation interface.
virtual bool emitSymbolAttribute(MCSymbol *Symbol, MCSymbolAttr Attribute)=0
Add the given Attribute to Symbol.
MCContext & getContext() const
void emitValue(const MCExpr *Value, unsigned Size, SMLoc Loc=SMLoc())
virtual void emitLabel(MCSymbol *Symbol, SMLoc Loc=SMLoc())
Emit a label for Symbol into the current section.
virtual void emitIntValue(uint64_t Value, unsigned Size)
Special case of EmitValue that avoids the client having to pass in a MCExpr for constant integers.
Generic base class for all target subtargets.
bool hasFeature(unsigned Feature) const
static const MCSymbolRefExpr * create(const MCSymbol *Symbol, MCContext &Ctx, SMLoc Loc=SMLoc())
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
LLVM_ABI void print(raw_ostream &OS, const MCAsmInfo *MAI) const
print - Print the value to the stream OS.
StringRef getName() const
getName - Get the symbol name.
Target specific streamer interface.
LLVM_ABI MCSymbol * getSymbol() const
Return the MCSymbol for this basic block.
This class is a data container for one entry in a MachineConstantPool.
union llvm::MachineConstantPoolEntry::@004270020304201266316354007027341142157160323045 Val
The constant itself.
bool isMachineConstantPoolEntry() const
isMachineConstantPoolEntry - Return true if the MachineConstantPoolEntry is indeed a target specific ...
MachineConstantPoolValue * MachineCPVal
const Constant * ConstVal
Abstract base class for all machine specific constantpool value subclasses.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
Representation of each machine instruction.
unsigned getOpcode() const
Returns the opcode of this MachineInstr.
const MachineOperand & getOperand(unsigned i) const
const std::vector< MachineJumpTableEntry > & getJumpTables() const
StubValueTy & getGVStubEntry(MCSymbol *Sym)
std::vector< std::pair< MCSymbol *, StubValueTy > > SymbolListTy
PointerIntPair< MCSymbol *, 1, bool > StubValueTy
MachineModuleInfoMachO - This is a MachineModuleInfoImpl implementation for MachO targets.
SymbolListTy GetThreadLocalGVStubList()
StubValueTy & getGVStubEntry(MCSymbol *Sym)
StubValueTy & getThreadLocalGVStubEntry(MCSymbol *Sym)
SymbolListTy GetGVStubList()
Accessor methods to return the set of stubs in sorted order.
MachineOperand class - Representation of each machine instruction operand.
unsigned getSubReg() const
const GlobalValue * getGlobal() const
bool isReg() const
isReg - Tests if this is a MO_Register operand.
MachineBasicBlock * getMBB() const
bool isImm() const
isImm - Tests if this is a MO_Immediate operand.
unsigned getTargetFlags() const
bool isGlobal() const
isGlobal - Tests if this is a MO_GlobalAddress operand.
MachineOperandType getType() const
getType - Returns the MachineOperandType for this operand.
Register getReg() const
getReg - Returns the register number.
@ MO_Immediate
Immediate operand.
@ MO_ConstantPoolIndex
Address of indexed Constant in Constant Pool.
@ MO_GlobalAddress
Address of a global value.
@ MO_MachineBasicBlock
MachineBasicBlock reference.
@ MO_Register
Register operand.
int64_t getOffset() const
Return the offset from the symbol in this operand.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
A Module instance is used to store all the information related to an LLVM module.
virtual void print(raw_ostream &OS, const Module *M) const
print - Print out the internal state of the pass.
Pass(PassKind K, char &pid)
PointerTy getPointer() const
Wrapper class representing virtual and physical registers.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
Primary interface to the complete machine description for the target machine.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
TypeSize getRegSizeInBits(const TargetRegisterClass &RC) const
Return the size in bits of a register from class RC.
virtual Register getFrameRegister(const MachineFunction &MF) const =0
Debug information queries.
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
Triple - Helper class for working with autoconf configuration names.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
This class implements an extremely fast bulk output stream that can only output to a stream.
A raw_ostream that writes to an SmallVector or SmallString.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ SECREL
Thread Pointer Offset.
@ GOT_PREL
Thread Local Storage (General Dynamic Mode)
@ SBREL
Section Relative (Windows TLS)
@ GOTTPOFF
Global Offset Table, PC Relative.
@ TPOFF
Global Offset Table, Thread Pointer Offset.
@ MO_LO16
MO_LO16 - On a symbol operand, this represents a relocation containing lower 16 bit of the address.
@ MO_LO_0_7
MO_LO_0_7 - On a symbol operand, this represents a relocation containing bits 0 through 7 of the addr...
@ MO_LO_8_15
MO_LO_8_15 - On a symbol operand, this represents a relocation containing bits 8 through 15 of the ad...
@ MO_NONLAZY
MO_NONLAZY - This is an independent flag, on a symbol operand "FOO" it represents a symbol which,...
@ MO_HI_8_15
MO_HI_8_15 - On a symbol operand, this represents a relocation containing bits 24 through 31 of the a...
@ MO_HI16
MO_HI16 - On a symbol operand, this represents a relocation containing higher 16 bit of the address.
@ MO_DLLIMPORT
MO_DLLIMPORT - On a symbol operand, this represents that the reference to the symbol is for an import...
@ MO_HI_0_7
MO_HI_0_7 - On a symbol operand, this represents a relocation containing bits 16 through 23 of the ad...
@ MO_COFFSTUB
MO_COFFSTUB - On a symbol operand "FOO", this indicates that the reference is actually to the "....
int getSOImmVal(unsigned Arg)
getSOImmVal - Given a 32-bit immediate, if it is something that can fit into an shifter_operand immed...
int getT2SOImmVal(unsigned Arg)
getT2SOImmVal - Given a 32-bit immediate, if it is something that can fit into a Thumb-2 shifter_oper...
std::string ParseARMTriple(const Triple &TT, StringRef CPU)
const MCSpecifierExpr * createLower16(const MCExpr *Expr, MCContext &Ctx)
const MCSpecifierExpr * createUpper16(const MCExpr *Expr, MCContext &Ctx)
SymbolStorageClass
Storage class tells where and what the symbol represents.
@ IMAGE_SYM_CLASS_EXTERNAL
External symbol.
@ IMAGE_SYM_CLASS_STATIC
Static.
@ IMAGE_SYM_DTYPE_FUNCTION
A function that returns a base type.
@ SCT_COMPLEX_TYPE_SHIFT
Type is formed as (base + (derived << SCT_COMPLEX_TYPE_SHIFT))
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > extract_or_null(Y &&MD)
Extract a Value from Metadata, allowing null.
This is an optimization pass for GlobalISel generic memory operations.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Target & getTheThumbBETarget()
@ MCDR_DataRegionEnd
.end_data_region
@ MCDR_DataRegion
.data_region
@ MCDR_DataRegionJT8
.data_region jt8
@ MCDR_DataRegionJT32
.data_region jt32
@ MCDR_DataRegionJT16
.data_region jt16
auto dyn_cast_or_null(const Y &Val)
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
MachineInstr * getImm(const MachineOperand &MO, const MachineRegisterInfo *MRI)
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
void LowerARMMachineInstrToMCInst(const MachineInstr *MI, MCInst &OutMI, ARMAsmPrinter &AP)
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
DWARFExpression::Operation Op
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Target & getTheARMLETarget()
unsigned convertAddSubFlagsOpcode(unsigned OldOpc)
Map pseudo instructions that imply an 'S' bit onto real opcodes.
@ MCSA_IndirectSymbol
.indirect_symbol (MachO)
@ MCSA_ELF_TypeFunction
.type _foo, STT_FUNC # aka @function
Target & getTheARMBETarget()
Target & getTheThumbLETarget()
Implement std::hash so that hash_code can be used in STL containers.
This struct is a compact representation of a valid (non-zero power of two) alignment.
Represents the full denormal controls for a function, including the default mode and the f32 specific...
static constexpr DenormalMode getPositiveZero()
static constexpr DenormalMode getPreserveSign()
static constexpr DenormalMode getIEEE()
RegisterAsmPrinter - Helper template for registering a target specific assembly printer,...