diff options
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 33 | 
1 files changed, 16 insertions, 17 deletions
| diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index 26ca58a76e4..75de005bea1 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -1,4 +1,4 @@ -//===-- AsmPrinter.cpp - Common AsmPrinter code ---------------------------===// +//===- AsmPrinter.cpp - Common AsmPrinter code ----------------------------===//  //  //                     The LLVM Compiler Infrastructure  // @@ -29,10 +29,11 @@  #include "llvm/ADT/Triple.h"  #include "llvm/ADT/Twine.h"  #include "llvm/Analysis/ConstantFolding.h" +#include "llvm/Analysis/EHPersonalities.h"  #include "llvm/Analysis/ObjectUtils.h" +#include "llvm/Analysis/OptimizationRemarkEmitter.h"  #include "llvm/BinaryFormat/Dwarf.h"  #include "llvm/BinaryFormat/ELF.h" -#include "llvm/CodeGen/Analysis.h"  #include "llvm/CodeGen/GCMetadata.h"  #include "llvm/CodeGen/GCMetadataPrinter.h"  #include "llvm/CodeGen/GCStrategy.h" @@ -46,10 +47,12 @@  #include "llvm/CodeGen/MachineJumpTableInfo.h"  #include "llvm/CodeGen/MachineLoopInfo.h"  #include "llvm/CodeGen/MachineMemOperand.h" +#include "llvm/CodeGen/MachineModuleInfo.h"  #include "llvm/CodeGen/MachineModuleInfoImpls.h"  #include "llvm/CodeGen/MachineOperand.h"  #include "llvm/CodeGen/MachineOptimizationRemarkEmitter.h"  #include "llvm/IR/BasicBlock.h" +#include "llvm/IR/Comdat.h"  #include "llvm/IR/Constant.h"  #include "llvm/IR/Constants.h"  #include "llvm/IR/DataLayout.h" @@ -62,14 +65,17 @@  #include "llvm/IR/GlobalObject.h"  #include "llvm/IR/GlobalValue.h"  #include "llvm/IR/GlobalVariable.h" +#include "llvm/IR/Instruction.h"  #include "llvm/IR/Mangler.h"  #include "llvm/IR/Metadata.h"  #include "llvm/IR/Module.h"  #include "llvm/IR/Operator.h" +#include "llvm/IR/Type.h"  #include "llvm/IR/Value.h"  #include "llvm/MC/MCAsmInfo.h"  #include "llvm/MC/MCContext.h"  #include "llvm/MC/MCDirectives.h" +#include "llvm/MC/MCDwarf.h"  #include "llvm/MC/MCExpr.h"  #include "llvm/MC/MCInst.h"  #include "llvm/MC/MCSection.h" @@ -78,11 +84,13 @@  #include "llvm/MC/MCStreamer.h"  #include "llvm/MC/MCSubtargetInfo.h"  #include "llvm/MC/MCSymbol.h" +#include "llvm/MC/MCSymbolELF.h"  #include "llvm/MC/MCTargetOptions.h"  #include "llvm/MC/MCValue.h"  #include "llvm/MC/SectionKind.h"  #include "llvm/Pass.h"  #include "llvm/Support/Casting.h" +#include "llvm/Support/CommandLine.h"  #include "llvm/Support/Compiler.h"  #include "llvm/Support/ErrorHandling.h"  #include "llvm/Support/Format.h" @@ -96,12 +104,15 @@  #include "llvm/Target/TargetLowering.h"  #include "llvm/Target/TargetLoweringObjectFile.h"  #include "llvm/Target/TargetMachine.h" +#include "llvm/Target/TargetOpcodes.h" +#include "llvm/Target/TargetOptions.h"  #include "llvm/Target/TargetRegisterInfo.h"  #include "llvm/Target/TargetSubtargetInfo.h"  #include <algorithm>  #include <cassert>  #include <cinttypes>  #include <cstdint> +#include <iterator>  #include <limits>  #include <memory>  #include <string> @@ -130,7 +141,8 @@ static cl::opt<bool>  char AsmPrinter::ID = 0; -typedef DenseMap<GCStrategy*, std::unique_ptr<GCMetadataPrinter>> gcp_map_type; +using gcp_map_type = DenseMap<GCStrategy *, std::unique_ptr<GCMetadataPrinter>>; +  static gcp_map_type &getGCMap(void *&P) {    if (!P)      P = new gcp_map_type(); @@ -185,7 +197,6 @@ bool AsmPrinter::isPositionIndependent() const {  }  /// getFunctionNumber - Return a unique ID for the current function. -///  unsigned AsmPrinter::getFunctionNumber() const {    return MF->getFunctionNumber();  } @@ -983,7 +994,6 @@ void AsmPrinter::EmitFunctionBody() {      // Print a label for the basic block.      EmitBasicBlockStart(MBB);      for (auto &MI : MBB) { -        // Print the assembly for the instruction.        if (!MI.isPosition() && !MI.isImplicitDef() && !MI.isKill() &&            !MI.isDebugValue()) { @@ -1007,11 +1017,9 @@ void AsmPrinter::EmitFunctionBody() {        case TargetOpcode::CFI_INSTRUCTION:          emitCFIInstruction(MI);          break; -        case TargetOpcode::LOCAL_ESCAPE:          emitFrameAlloc(MI);          break; -        case TargetOpcode::EH_LABEL:        case TargetOpcode::GC_LABEL:          OutStreamer->EmitLabel(MI.getOperand(0).getMCSymbol()); @@ -1458,7 +1466,6 @@ namespace {  /// representations of the constants in the constant pool MCP. This is  /// used to print out constants which have been "spilled to memory" by  /// the code generator. -///  void AsmPrinter::EmitConstantPool() {    const MachineConstantPool *MCP = MF->getConstantPool();    const std::vector<MachineConstantPoolEntry> &CP = MCP->getConstants(); @@ -1538,7 +1545,6 @@ void AsmPrinter::EmitConstantPool() {  /// EmitJumpTableInfo - Print assembly representations of the jump tables used  /// by the current function to the current output stream. -///  void AsmPrinter::EmitJumpTableInfo() {    const DataLayout &DL = MF->getDataLayout();    const MachineJumpTableInfo *MJTI = MF->getJumpTableInfo(); @@ -1735,7 +1741,7 @@ struct Structor {    Structor() = default;  }; -}  // end anonymous namespace +} // end anonymous namespace  /// EmitXXStructorList - Emit the ctor or dtor list taking into account the init  /// priority. @@ -1830,13 +1836,11 @@ void AsmPrinter::EmitInt8(int Value) const {  }  /// EmitInt16 - Emit a short directive and value. -///  void AsmPrinter::EmitInt16(int Value) const {    OutStreamer->EmitIntValue(Value, 2);  }  /// EmitInt32 - Emit a long directive and value. -///  void AsmPrinter::EmitInt32(int Value) const {    OutStreamer->EmitIntValue(Value, 4);  } @@ -1878,7 +1882,6 @@ void AsmPrinter::EmitLabelPlusOffset(const MCSymbol *Label, uint64_t Offset,  // byte alignment.  If a global value is specified, and if that global has  // an explicit alignment requested, it will override the alignment request  // if required for correctness. -//  void AsmPrinter::EmitAlignment(unsigned NumBits, const GlobalObject *GV) const {    if (GV)      NumBits = getGVAlignmentLog2(GV, GV->getParent()->getDataLayout(), NumBits); @@ -2329,7 +2332,6 @@ static void handleIndirectSymViaGOTPCRel(AsmPrinter &AP, const MCExpr **ME,    //    //  cstexpr := <gotequiv> - <foo> + gotpcrelcst, where    //    gotpcrelcst := <offset from @foo base> + <cst> -  //    MCValue MV;    if (!(*ME)->evaluateAsRelocatable(MV, nullptr, nullptr) || MV.isAbsolute())      return; @@ -2360,7 +2362,6 @@ static void handleIndirectSymViaGOTPCRel(AsmPrinter &AP, const MCExpr **ME,    // If gotpcrelcst is positive it means that we can safely fold the pc rel    // displacement into the GOTPCREL. We can also can have an extra offset <cst>    // if the target knows how to encode it. -  //    int64_t GOTPCRelCst = Offset + MV.getConstant();    if (GOTPCRelCst < 0)      return; @@ -2382,7 +2383,6 @@ static void handleIndirectSymViaGOTPCRel(AsmPrinter &AP, const MCExpr **ME,    //    .long 42    //  foo:    //    .long bar@GOTPCREL+<gotpcrelcst> -  //    AsmPrinter::GOTEquivUsePair Result = AP.GlobalGOTEquivs[GOTEquivSym];    const GlobalVariable *GV = Result.first;    int NumUses = (int)Result.second; @@ -2562,7 +2562,6 @@ static void PrintParentLoopComment(raw_ostream &OS, const MachineLoop *Loop,      << " Depth=" << Loop->getLoopDepth() << '\n';  } -  /// PrintChildLoopComment - Print comments about child loops within  /// the loop for this basic block, with nesting.  static void PrintChildLoopComment(raw_ostream &OS, const MachineLoop *Loop, | 

