48  if (Mips::ACC64RegClass.
contains(Src))
 
   49    return std::make_pair((
unsigned)Mips::PseudoMFHI,
 
   50                          (
unsigned)Mips::PseudoMFLO);
 
   52  if (Mips::ACC64DSPRegClass.
contains(Src))
 
   53    return std::make_pair((
unsigned)Mips::MFHI_DSP, (
unsigned)Mips::MFLO_DSP);
 
   55  if (Mips::ACC128RegClass.
contains(Src))
 
   56    return std::make_pair((
unsigned)Mips::PseudoMFHI64,
 
   57                          (
unsigned)Mips::PseudoMFLO64);
 
   59  return std::make_pair(0, 0);
 
 
   67  ExpandPseudo(MachineFunction &MF);
 
   73  bool expandInstr(MachineBasicBlock &
MBB, Iter 
I);
 
   74  void expandLoadCCond(MachineBasicBlock &
MBB, Iter 
I);
 
   75  void expandStoreCCond(MachineBasicBlock &
MBB, Iter 
I);
 
   76  void expandLoadACC(MachineBasicBlock &
MBB, Iter 
I, 
unsigned RegSize);
 
   77  void expandStoreACC(MachineBasicBlock &
MBB, Iter 
I, 
unsigned MFHiOpc,
 
   78                      unsigned MFLoOpc, 
unsigned RegSize);
 
   79  bool expandCopy(MachineBasicBlock &
MBB, Iter 
I);
 
   80  bool expandCopyACC(MachineBasicBlock &
MBB, Iter 
I, 
unsigned MFHiOpc,
 
   82  bool expandBuildPairF64(MachineBasicBlock &
MBB,
 
   84  bool expandExtractElementF64(MachineBasicBlock &
MBB,
 
   88  MachineRegisterInfo &MRI;
 
   89  const MipsSubtarget &Subtarget;
 
   90  const MipsSEInstrInfo &TII;
 
   91  const MipsRegisterInfo &RegInfo;
 
   97    : MF(MF_), 
MRI(MF.getRegInfo()),
 
  100      RegInfo(*Subtarget.getRegisterInfo()) {}
 
  102bool ExpandPseudo::expand() {
 
  103  bool Expanded = 
false;
 
  105  for (
auto &
MBB : MF) {
 
  107      Expanded |= expandInstr(
MBB, 
I++);
 
  113bool ExpandPseudo::expandInstr(MachineBasicBlock &
MBB, Iter 
I) {
 
  114  switch(
I->getOpcode()) {
 
  115  case Mips::LOAD_CCOND_DSP:
 
  116    expandLoadCCond(
MBB, 
I);
 
  118  case Mips::STORE_CCOND_DSP:
 
  119    expandStoreCCond(
MBB, 
I);
 
  121  case Mips::LOAD_ACC64:
 
  122  case Mips::LOAD_ACC64DSP:
 
  123    expandLoadACC(
MBB, 
I, 4);
 
  125  case Mips::LOAD_ACC128:
 
  126    expandLoadACC(
MBB, 
I, 8);
 
  128  case Mips::STORE_ACC64:
 
  129    expandStoreACC(
MBB, 
I, Mips::PseudoMFHI, Mips::PseudoMFLO, 4);
 
  131  case Mips::STORE_ACC64DSP:
 
  132    expandStoreACC(
MBB, 
I, Mips::MFHI_DSP, Mips::MFLO_DSP, 4);
 
  134  case Mips::STORE_ACC128:
 
  135    expandStoreACC(
MBB, 
I, Mips::PseudoMFHI64, Mips::PseudoMFLO64, 8);
 
  137  case Mips::BuildPairF64:
 
  138    if (expandBuildPairF64(
MBB, 
I, 
false))
 
  141  case Mips::BuildPairF64_64:
 
  142    if (expandBuildPairF64(
MBB, 
I, 
true))
 
  145  case Mips::ExtractElementF64:
 
  146    if (expandExtractElementF64(
MBB, 
I, 
false))
 
  149  case Mips::ExtractElementF64_64:
 
  150    if (expandExtractElementF64(
MBB, 
I, 
true))
 
  153  case TargetOpcode::COPY:
 
  154    if (!expandCopy(
MBB, 
I))
 
  165void ExpandPseudo::expandLoadCCond(MachineBasicBlock &
MBB, Iter 
I) {
 
  169  assert(
I->getOperand(0).isReg() && 
I->getOperand(1).isFI());
 
  171  const TargetRegisterClass *RC = RegInfo.
intRegClass(4);
 
  173  Register Dst = 
I->getOperand(0).getReg(), FI = 
I->getOperand(1).getIndex();
 
  175  TII.loadRegFromStack(
MBB, 
I, VR, FI, RC, &RegInfo, 0);
 
  180void ExpandPseudo::expandStoreCCond(MachineBasicBlock &
MBB, Iter 
I) {
 
  184  assert(
I->getOperand(0).isReg() && 
I->getOperand(1).isFI());
 
  186  const TargetRegisterClass *RC = RegInfo.
intRegClass(4);
 
  188  Register Src = 
I->getOperand(0).getReg(), FI = 
I->getOperand(1).getIndex();
 
  192  TII.storeRegToStack(
MBB, 
I, VR, 
true, FI, RC, &RegInfo, 0);
 
  195void ExpandPseudo::expandLoadACC(MachineBasicBlock &
MBB, Iter 
I,
 
  202  assert(
I->getOperand(0).isReg() && 
I->getOperand(1).isFI());
 
  207  Register Dst = 
I->getOperand(0).getReg(), FI = 
I->getOperand(1).getIndex();
 
  208  Register Lo = RegInfo.getSubReg(Dst, Mips::sub_lo);
 
  209  Register Hi = RegInfo.getSubReg(Dst, Mips::sub_hi);
 
  211  const MCInstrDesc &
Desc = 
TII.get(TargetOpcode::COPY);
 
  213  TII.loadRegFromStack(
MBB, 
I, VR0, FI, RC, &RegInfo, 0);
 
  219void ExpandPseudo::expandStoreACC(MachineBasicBlock &
MBB, Iter 
I,
 
  220                                  unsigned MFHiOpc, 
unsigned MFLoOpc,
 
  227  assert(
I->getOperand(0).isReg() && 
I->getOperand(1).isFI());
 
  232  Register Src = 
I->getOperand(0).getReg(), FI = 
I->getOperand(1).getIndex();
 
  237  TII.storeRegToStack(
MBB, 
I, VR0, 
true, FI, RC, &RegInfo, 0);
 
  239  TII.storeRegToStack(
MBB, 
I, VR1, 
true, FI, RC, &RegInfo, 
RegSize);
 
  242bool ExpandPseudo::expandCopy(MachineBasicBlock &
MBB, Iter 
I) {
 
  243  Register Src = 
I->getOperand(1).getReg();
 
  244  std::pair<unsigned, unsigned> Opcodes = 
getMFHiLoOpc(Src);
 
  249  return expandCopyACC(
MBB, 
I, Opcodes.first, Opcodes.second);
 
  252bool ExpandPseudo::expandCopyACC(MachineBasicBlock &
MBB, Iter 
I,
 
  253                                 unsigned MFHiOpc, 
unsigned MFLoOpc) {
 
  259  unsigned Dst = 
I->getOperand(0).getReg(), Src = 
I->getOperand(1).getReg();
 
  260  const TargetRegisterClass *DstRC = RegInfo.getMinimalPhysRegClass(Dst);
 
  261  unsigned VRegSize = RegInfo.getRegSizeInBits(*DstRC) / 16;
 
  262  const TargetRegisterClass *RC = RegInfo.
intRegClass(VRegSize);
 
  266  Register DstLo = RegInfo.getSubReg(Dst, Mips::sub_lo);
 
  267  Register DstHi = RegInfo.getSubReg(Dst, Mips::sub_hi);
 
  284bool ExpandPseudo::expandBuildPairF64(MachineBasicBlock &
MBB,
 
  303  if (
I->getNumOperands() == 4 && 
I->getOperand(3).isReg()
 
  304      && 
I->getOperand(3).getReg() == Mips::SP) {
 
  305    Register DstReg = 
I->getOperand(0).getReg();
 
  306    Register LoReg = 
I->getOperand(1).getReg();
 
  307    Register HiReg = 
I->getOperand(2).getReg();
 
  315    const TargetRegisterClass *RC = &Mips::GPR32RegClass;
 
  316    const TargetRegisterClass *RC2 =
 
  317        FP64 ? &Mips::FGR64RegClass : &Mips::AFGR64RegClass;
 
  321    int FI = MF.getInfo<MipsFunctionInfo>()->getMoveF64ViaSpillFI(MF, RC2);
 
  324    TII.storeRegToStack(
MBB, 
I, LoReg, 
I->getOperand(1).isKill(), FI, RC,
 
  326    TII.storeRegToStack(
MBB, 
I, HiReg, 
I->getOperand(2).isKill(), FI, RC,
 
  328    TII.loadRegFromStack(
MBB, 
I, DstReg, FI, RC2, &RegInfo, 0);
 
  340bool ExpandPseudo::expandExtractElementF64(MachineBasicBlock &
MBB,
 
  344  const MachineOperand &Op2 = 
I->getOperand(2);
 
  347    Register DstReg = 
I->getOperand(0).getReg();
 
  348    BuildMI(
MBB, 
I, 
I->getDebugLoc(), 
TII.get(Mips::IMPLICIT_DEF), DstReg);
 
  368  if (
I->getNumOperands() == 4 && 
I->getOperand(3).isReg()
 
  369      && 
I->getOperand(3).getReg() == Mips::SP) {
 
  370    Register DstReg = 
I->getOperand(0).getReg();
 
  381    const TargetRegisterClass *RC =
 
  382        FP64 ? &Mips::FGR64RegClass : &Mips::AFGR64RegClass;
 
  383    const TargetRegisterClass *RC2 = &Mips::GPR32RegClass;
 
  387    int FI = MF.getInfo<MipsFunctionInfo>()->getMoveF64ViaSpillFI(MF, RC);
 
  388    TII.storeRegToStack(
MBB, 
I, SrcReg, Op1.
isKill(), FI, RC, &RegInfo, 0);
 
  389    TII.loadRegFromStack(
MBB, 
I, DstReg, FI, RC2, &RegInfo, 
Offset);
 
  411  unsigned SP = ABI.GetStackPtr();
 
  412  unsigned FP = ABI.GetFramePtr();
 
  413  unsigned ZERO = ABI.GetNullPtr();
 
  414  unsigned MOVE = ABI.GetGPRMoveOp();
 
  415  unsigned ADDiu = ABI.GetPtrAddiuOp();
 
  416  unsigned AND = ABI.IsN64() ? Mips::AND64 : Mips::AND;
 
  419        &Mips::GPR64RegClass : &Mips::GPR32RegClass;
 
  430  TII.adjustStackPtr(SP, -StackSize, 
MBB, 
MBBI);
 
  434    emitInterruptPrologueStub(MF, 
MBB);
 
  440  std::advance(
MBBI, CSI.size());
 
  452      if (Mips::AFGR64RegClass.
contains(Reg)) {
 
  453        MCRegister Reg0 = RegInfo.getSubReg(Reg, Mips::sub_lo);
 
  454        MCRegister Reg1 = RegInfo.getSubReg(Reg, Mips::sub_hi);
 
  461      } 
else if (Mips::FGR64RegClass.
contains(Reg)) {
 
  479    for (
int I = 0; 
I < 4; ++
I) {
 
  480      if (!
MBB.isLiveIn(ABI.GetEhDataReg(
I)))
 
  481        MBB.addLiveIn(ABI.GetEhDataReg(
I));
 
  482      TII.storeRegToStackSlot(
MBB, 
MBBI, ABI.GetEhDataReg(
I), 
false,
 
  488    for (
int I = 0; 
I < 4; ++
I) {
 
  502    if (RegInfo.hasStackRealignment(MF)) {
 
  507             "Function's alignment size requirement is not supported.");
 
  515        unsigned BP = 
STI.isABI_N64() ? Mips::S7_64 : Mips::S7;
 
 
  524void MipsSEFrameLowering::emitInterruptPrologueStub(
 
  537        "\"interrupt\" attribute is not supported on pre-MIPS32R2 or " 
  546                       "static relocation model on MIPS at the present time.");
 
  550                       "O32 ABI on MIPS32R2+ at the present time.");
 
  559  if (IntKind == 
"eic") {
 
  561    MBB.addLiveIn(Mips::COP013);
 
  575  MBB.addLiveIn(Mips::COP014);
 
  586  MBB.addLiveIn(Mips::COP012);
 
  598  unsigned InsPosition = 8;
 
  599  unsigned InsSize = 0;
 
  600  unsigned SrcReg = Mips::ZERO;
 
  604  if (IntKind == 
"eic") {
 
  609    InsSize = StringSwitch<unsigned>(IntKind)
 
  619  assert(InsSize != 0 && 
"Unknown interrupt type!");
 
  637  if (!
STI.useSoftFloat())
 
  664  unsigned SP = ABI.GetStackPtr();
 
  665  unsigned FP = ABI.GetFramePtr();
 
  666  unsigned ZERO = ABI.GetNullPtr();
 
  667  unsigned MOVE = ABI.GetGPRMoveOp();
 
  683        ABI.ArePtrs64bit() ? &Mips::GPR64RegClass : &Mips::GPR32RegClass;
 
  691    for (
int J = 0; J < 4; ++J) {
 
  692      TII.loadRegFromStackSlot(
MBB, 
I, ABI.GetEhDataReg(J),
 
  699    emitInterruptEpilogueStub(MF, 
MBB);
 
 
  711void MipsSEFrameLowering::emitInterruptEpilogueStub(
 
  748    FrameReg = 
hasFP(MF) ? ABI.GetFramePtr() : ABI.GetStackPtr();
 
  750    FrameReg = 
hasBP(MF) ? ABI.GetBasePtr() : ABI.GetStackPtr();
 
 
  770    bool IsRAAndRetAddrIsTaken = (Reg == Mips::RA || Reg == Mips::RA_64)
 
  772    if (!IsRAAndRetAddrIsTaken)
 
  777    bool IsLOHI = (Reg == Mips::LO0 || Reg == Mips::LO0_64 ||
 
  778                   Reg == Mips::HI0 || Reg == Mips::HI0_64);
 
  779    const Function &Func = 
MBB.getParent()->getFunction();
 
  780    if (IsLOHI && Func.hasFnAttribute(
"interrupt")) {
 
  784      if (!
STI.getABI().ArePtrs64bit()) {
 
  785        Op = (Reg == Mips::HI0) ? Mips::MFHI : Mips::MFLO;
 
  788        Op = (Reg == Mips::HI0) ? Mips::MFHI64 : Mips::MFLO64;
 
  796    bool IsKill = !IsRAAndRetAddrIsTaken;
 
  798    TII.storeRegToStackSlot(
MBB, 
MI, Reg, IsKill, 
I.getFrameIdx(), RC, 
TRI,
 
 
  831  unsigned RA = ABI.IsN64() ? Mips::RA_64 : Mips::RA;
 
  832  unsigned FP = ABI.GetFramePtr();
 
  833  unsigned BP = ABI.IsN64() ? Mips::S7_64 : Mips::S7;
 
  854  if (ExpandPseudo(MF).
expand()) {
 
  859      Mips::GPR64RegClass : Mips::GPR32RegClass;
 
  861                                                      TRI->getSpillAlign(RC));
 
  862    RS->addScavengingFrameIndex(FI);
 
  870  if (
isIntN(
STI.hasMSA() ? 10 : 16, MaxSPOffset) &&
 
  875      ABI.ArePtrs64bit() ? Mips::GPR64RegClass : Mips::GPR32RegClass;
 
  877                                                    TRI->getSpillAlign(RC));
 
  878  RS->addScavengingFrameIndex(FI);
 
 
unsigned const MachineRegisterInfo * MRI
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
This file implements the BitVector class.
@ ZERO
Special weight used for cases with exact zero probability.
static Expected< BitVector > expand(StringRef S, StringRef Original)
const HexagonInstrInfo * TII
Register const TargetRegisterInfo * TRI
Promote Memory to Register
static std::pair< unsigned, unsigned > getMFHiLoOpc(unsigned Src)
static void setAliasRegs(MachineFunction &MF, BitVector &SavedRegs, unsigned Reg)
Mark Reg and all registers aliasing it in the bitset.
This file declares the machine register scavenger class.
SI optimize exec mask operations pre RA
static bool contains(SmallPtrSetImpl< ConstantExpr * > &Cache, ConstantExpr *Expr, Constant *C)
This file implements the StringSwitch template, which mimics a switch() statement whose cases are str...
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
LLVM_ABI StringRef getValueAsString() const
Return the attribute's value as a string.
Helper class for creating CFI instructions and inserting them into MIR.
void buildDefCFAOffset(int64_t Offset, MCSymbol *Label=nullptr) const
void buildDefCFARegister(MCRegister Reg) const
void buildOffset(MCRegister Reg, int64_t Offset) const
void setInsertPoint(MachineBasicBlock::iterator IP)
The CalleeSavedInfo class tracks the information need to locate where a callee saved register is in t...
Attribute getFnAttribute(Attribute::AttrKind Kind) const
Return the attribute for the given attribute kind.
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
MCRegAliasIterator enumerates all registers aliasing Reg.
Wrapper class representing physical registers. Should be passed by value.
LLVM_ABI instr_iterator erase(instr_iterator I)
Remove an instruction from the instruction list and delete it.
MachineInstrBundleIterator< MachineInstr > iterator
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
bool hasVarSizedObjects() const
This method may be called any time after instruction selection is complete to determine if the stack ...
uint64_t getStackSize() const
Return the number of bytes that must be allocated to hold all of the fixed size frame objects.
bool adjustsStack() const
Return true if this function adjusts the stack – e.g., when calling another function.
bool isReturnAddressTaken() const
This method may be called any time after instruction selection is complete to determine if there is a...
Align getMaxAlign() const
Return the alignment in bytes that this function must be aligned to, which is greater than the defaul...
uint64_t getMaxCallFrameSize() const
Return the maximum size of a call frame that must be allocated for an outgoing function call.
int64_t getOffsetAdjustment() const
Return the correction for frame offsets.
LLVM_ABI int CreateSpillStackObject(uint64_t Size, Align Alignment)
Create a new statically sized stack object that represents a spill slot, returning a nonnegative iden...
const std::vector< CalleeSavedInfo > & getCalleeSavedInfo() const
Returns a reference to call saved info vector for the current function.
int64_t getObjectOffset(int ObjectIdx) const
Return the assigned stack offset of the specified object from the incoming stack pointer.
bool isFixedObjectIndex(int ObjectIdx) const
Returns true if the specified index corresponds to a fixed stack object.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
MachineFrameInfo & getFrameInfo()
getFrameInfo - Return the frame info object for the current function.
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
Function & getFunction()
Return the LLVM function that this machine code represents.
Ty * getInfo()
getInfo - Keep track of various per-function pieces of information for backends that would like to do...
const MachineInstrBuilder & setMIFlag(MachineInstr::MIFlag Flag) const
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
const MachineInstrBuilder & addReg(Register RegNo, unsigned flags=0, unsigned SubReg=0) const
Add a new virtual register operand.
const MachineOperand & getOperand(unsigned i) const
bool isReg() const
isReg - Tests if this is a MO_Register operand.
Register getReg() const
getReg - Returns the register number.
LLVM_ABI Register createVirtualRegister(const TargetRegisterClass *RegClass, StringRef Name="")
createVirtualRegister - Create and return a new virtual register in the function with the specified r...
MipsFrameLowering(const MipsSubtarget &sti, Align Alignment)
bool hasBP(const MachineFunction &MF) const
uint64_t estimateStackSize(const MachineFunction &MF) const
const MipsSubtarget & STI
MipsFunctionInfo - This class is derived from MachineFunction private Mips target-specific informatio...
int getEhDataRegFI(unsigned Reg) const
int getISRRegFI(Register Reg) const
bool callsEhReturn() const
void createEhDataRegsFI(MachineFunction &MF)
void createISRRegFI(MachineFunction &MF)
virtual void storeRegToStack(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, Register SrcReg, bool isKill, int FrameIndex, const TargetRegisterClass *RC, const TargetRegisterInfo *TRI, int64_t Offset, MachineInstr::MIFlag Flags=MachineInstr::NoFlags) const =0
void loadRegFromStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, Register DestReg, int FrameIndex, const TargetRegisterClass *RC, const TargetRegisterInfo *TRI, Register VReg, MachineInstr::MIFlag Flags=MachineInstr::NoFlags) const override
virtual const TargetRegisterClass * intRegClass(unsigned Size) const =0
Return GPR register class.
void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs, RegScavenger *RS) const override
This method determines which of the registers reported by TargetRegisterInfo::getCalleeSavedRegs() sh...
MipsSEFrameLowering(const MipsSubtarget &STI)
StackOffset getFrameIndexReference(const MachineFunction &MF, int FI, Register &FrameReg) const override
getFrameIndexReference - This method should return the base register and offset used to reference a f...
bool hasReservedCallFrame(const MachineFunction &MF) const override
hasReservedCallFrame - Under normal circumstances, when a frame pointer is not required,...
bool spillCalleeSavedRegisters(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, ArrayRef< CalleeSavedInfo > CSI, const TargetRegisterInfo *TRI) const override
spillCalleeSavedRegisters - Issues instruction(s) to spill all callee saved registers and returns tru...
void emitPrologue(MachineFunction &MF, MachineBasicBlock &MBB) const override
emitProlog/emitEpilog - These methods insert prolog and epilog code into the function.
void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const override
const MipsInstrInfo * getInstrInfo() const override
const MipsRegisterInfo * getRegisterInfo() const override
Reloc::Model getRelocationModel() const
Wrapper class representing virtual and physical registers.
StackOffset holds a fixed and a scalable offset in bytes.
int64_t getFixed() const
Returns the fixed component of the stack.
StringRef - Represent a constant reference to a string, i.e.
unsigned getStackAlignment() const
getStackAlignment - This method returns the number of bytes to which the stack pointer must be aligne...
bool hasFP(const MachineFunction &MF) const
hasFP - Return true if the specified function should have a dedicated frame pointer register.
virtual void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs, RegScavenger *RS=nullptr) const
This method determines which of the registers reported by TargetRegisterInfo::getCalleeSavedRegs() sh...
int getOffsetOfLocalArea() const
getOffsetOfLocalArea - This method returns the offset of the local area from the stack pointer on ent...
TargetInstrInfo - Interface to description of machine instruction set.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
@ Kill
The last use of a register.
This is an optimization pass for GlobalISel generic memory operations.
auto size(R &&Range, std::enable_if_t< std::is_base_of< std::random_access_iterator_tag, typename std::iterator_traits< decltype(Range.begin())>::iterator_category >::value, void > *=nullptr)
Get the size of a range.
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
constexpr bool isInt(int64_t x)
Checks if an integer fits into the given bit width.
const MipsFrameLowering * createMipsSEFrameLowering(const MipsSubtarget &ST)
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
unsigned getKillRegState(bool B)
DWARFExpression::Operation Op
constexpr bool isIntN(unsigned N, int64_t x)
Checks if an signed integer fits into the given (dynamic) bit width.
unsigned Log2(Align A)
Returns the log2 of the alignment.
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
constexpr uint64_t value() const
This is a hole in the type system and should not be abused.