diff options
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 22 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfExpression.cpp | 60 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h | 2 | 
3 files changed, 58 insertions, 26 deletions
| diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index e2af0c5..8aa488f 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -41,6 +41,7 @@  #include "llvm/CodeGen/GCMetadataPrinter.h"  #include "llvm/CodeGen/LazyMachineBlockFrequencyInfo.h"  #include "llvm/CodeGen/MachineBasicBlock.h" +#include "llvm/CodeGen/MachineBlockHashInfo.h"  #include "llvm/CodeGen/MachineBranchProbabilityInfo.h"  #include "llvm/CodeGen/MachineConstantPool.h"  #include "llvm/CodeGen/MachineDominators.h" @@ -184,6 +185,8 @@ static cl::opt<bool> PrintLatency(      cl::desc("Print instruction latencies as verbose asm comments"), cl::Hidden,      cl::init(false)); +extern cl::opt<bool> EmitBBHash; +  STATISTIC(EmittedInsts, "Number of machine instrs printed");  char AsmPrinter::ID = 0; @@ -474,6 +477,8 @@ void AsmPrinter::getAnalysisUsage(AnalysisUsage &AU) const {    AU.addRequired<GCModuleInfo>();    AU.addRequired<LazyMachineBlockFrequencyInfoPass>();    AU.addRequired<MachineBranchProbabilityInfoWrapperPass>(); +  if (EmitBBHash) +    AU.addRequired<MachineBlockHashInfo>();  }  bool AsmPrinter::doInitialization(Module &M) { @@ -1434,13 +1439,11 @@ getBBAddrMapFeature(const MachineFunction &MF, int NumMBBSectionRanges,          "BB entries info is required for BBFreq and BrProb "          "features");    } -  return {FuncEntryCountEnabled, -          BBFreqEnabled, -          BrProbEnabled, +  return {FuncEntryCountEnabled, BBFreqEnabled, BrProbEnabled,            MF.hasBBSections() && NumMBBSectionRanges > 1, -          static_cast<bool>(BBAddrMapSkipEmitBBEntries), -          HasCalls, -          false}; +          // Use static_cast to avoid breakage of tests on windows. +          static_cast<bool>(BBAddrMapSkipEmitBBEntries), HasCalls, +          static_cast<bool>(EmitBBHash)};  }  void AsmPrinter::emitBBAddrMapSection(const MachineFunction &MF) { @@ -1499,6 +1502,9 @@ void AsmPrinter::emitBBAddrMapSection(const MachineFunction &MF) {        PrevMBBEndSymbol = MBBSymbol;      } +    auto MBHI = +        Features.BBHash ? &getAnalysis<MachineBlockHashInfo>() : nullptr; +      if (!Features.OmitBBEntries) {        OutStreamer->AddComment("BB id");        // Emit the BB ID for this basic block. @@ -1526,6 +1532,10 @@ void AsmPrinter::emitBBAddrMapSection(const MachineFunction &MF) {        emitLabelDifferenceAsULEB128(MBB.getEndSymbol(), CurrentLabel);        // Emit the Metadata.        OutStreamer->emitULEB128IntValue(getBBAddrMapMetadata(MBB)); +      // Emit the Hash. +      if (MBHI) { +        OutStreamer->emitInt64(MBHI->getMBBHash(MBB)); +      }      }      PrevMBBEndSymbol = MBB.getEndSymbol();    } diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfExpression.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfExpression.cpp index f0f0861..c7d45897 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfExpression.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfExpression.cpp @@ -566,32 +566,54 @@ bool DwarfExpression::addExpression(      case dwarf::DW_OP_LLVM_extract_bits_zext: {        unsigned SizeInBits = Op->getArg(1);        unsigned BitOffset = Op->getArg(0); +      unsigned DerefSize = 0; +      //  Operations are done in the DWARF "generic type" whose size +      // is the size of a pointer. +      unsigned PtrSizeInBytes = CU.getAsmPrinter()->MAI->getCodePointerSize();        // If we have a memory location then dereference to get the value, though        // we have to make sure we don't dereference any bytes past the end of the        // object.        if (isMemoryLocation()) { -        emitOp(dwarf::DW_OP_deref_size); -        emitUnsigned(alignTo(BitOffset + SizeInBits, 8) / 8); +        DerefSize = alignTo(BitOffset + SizeInBits, 8) / 8; +        if (DerefSize == PtrSizeInBytes) { +          emitOp(dwarf::DW_OP_deref); +        } else { +          emitOp(dwarf::DW_OP_deref_size); +          emitUnsigned(DerefSize); +        }        } -      // Extract the bits by a shift left (to shift out the bits after what we -      // want to extract) followed by shift right (to shift the bits to position -      // 0 and also sign/zero extend). These operations are done in the DWARF -      // "generic type" whose size is the size of a pointer. -      unsigned PtrSizeInBytes = CU.getAsmPrinter()->MAI->getCodePointerSize(); -      unsigned LeftShift = PtrSizeInBytes * 8 - (SizeInBits + BitOffset); -      unsigned RightShift = LeftShift + BitOffset; -      if (LeftShift) { -        emitOp(dwarf::DW_OP_constu); -        emitUnsigned(LeftShift); -        emitOp(dwarf::DW_OP_shl); -      } -      if (RightShift) { -        emitOp(dwarf::DW_OP_constu); -        emitUnsigned(RightShift); -        emitOp(OpNum == dwarf::DW_OP_LLVM_extract_bits_sext ? dwarf::DW_OP_shra -                                                            : dwarf::DW_OP_shr); +      // If a dereference was emitted for an unsigned value, and +      // there's no bit offset, then a bit of optimization is +      // possible. +      if (OpNum == dwarf::DW_OP_LLVM_extract_bits_zext && BitOffset == 0) { +        if (8 * DerefSize == SizeInBits) { +          // The correct value is already on the stack. +        } else { +          // No need to shift, we can just mask off the desired bits. +          emitOp(dwarf::DW_OP_constu); +          emitUnsigned((1u << SizeInBits) - 1); +          emitOp(dwarf::DW_OP_and); +        } +      } else { +        // Extract the bits by a shift left (to shift out the bits after what we +        // want to extract) followed by shift right (to shift the bits to +        // position 0 and also sign/zero extend). +        unsigned LeftShift = PtrSizeInBytes * 8 - (SizeInBits + BitOffset); +        unsigned RightShift = LeftShift + BitOffset; +        if (LeftShift) { +          emitOp(dwarf::DW_OP_constu); +          emitUnsigned(LeftShift); +          emitOp(dwarf::DW_OP_shl); +        } +        if (RightShift) { +          emitOp(dwarf::DW_OP_constu); +          emitUnsigned(RightShift); +          emitOp(OpNum == dwarf::DW_OP_LLVM_extract_bits_sext +                     ? dwarf::DW_OP_shra +                     : dwarf::DW_OP_shr); +        }        }        // The value is now at the top of the stack, so set the location to diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h b/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h index 9288d7e..9c0b68b 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h @@ -334,7 +334,7 @@ public:                                 const DIE &TyDIE);  protected: -  ~DwarfUnit(); +  ~DwarfUnit() override;    /// Create new static data member DIE.    DIE *getOrCreateStaticMemberDIE(const DIDerivedType *DT); | 
