diff --git a/llvm/lib/Target/AArch64/AArch64GenRegisterBankInfo.def b/llvm/lib/Target/AArch64/AArch64GenRegisterBankInfo.def index 3a152c515e7e..75ee75355aad 100644 --- a/llvm/lib/Target/AArch64/AArch64GenRegisterBankInfo.def +++ b/llvm/lib/Target/AArch64/AArch64GenRegisterBankInfo.def @@ -216,61 +216,6 @@ RegisterBankInfo::ValueMapping AArch64GenRegisterBankInfo::ValMappings[]{ {&AArch64GenRegisterBankInfo::PartMappings[PMI_GPR64 - PMI_Min], 1} }; -namespace AArch64 { -/// Get the pointer to the ValueMapping representing the RegisterBank -/// at \p RBIdx with a size of \p Size. -/// -/// The returned mapping works for instructions with the same kind of -/// operands for up to 3 operands. -/// -/// \pre \p RBIdx != PartialMappingIdx::None -const RegisterBankInfo::ValueMapping * -getValueMapping(AArch64GenRegisterBankInfo::PartialMappingIdx RBIdx, - unsigned Size) { - assert(RBIdx != AArch64GenRegisterBankInfo::PartialMappingIdx::PMI_None && - "No mapping needed for that"); - unsigned ValMappingIdx = - AArch64GenRegisterBankInfo::First3OpsIdx + - (RBIdx - AArch64GenRegisterBankInfo::PartialMappingIdx::PMI_Min + - AArch64GenRegisterBankInfo::getRegBankBaseIdxOffset(RBIdx, Size)) * - AArch64GenRegisterBankInfo::ValueMappingIdx::DistanceBetweenRegBanks; - assert(ValMappingIdx >= AArch64GenRegisterBankInfo::First3OpsIdx && - ValMappingIdx <= AArch64GenRegisterBankInfo::Last3OpsIdx && - "Mapping out of bound"); - - return &AArch64GenRegisterBankInfo::ValMappings[ValMappingIdx]; -} - -/// Get the pointer to the ValueMapping of the operands of a copy -/// instruction from a GPR or FPR register to a GPR or FPR register -/// with a size of \p Size. -/// -/// If \p DstIsGPR is true, the destination of the copy is on GPR, -/// otherwise it is on FPR. Same thing for \p SrcIsGPR. -const RegisterBankInfo::ValueMapping * -getCopyMapping(bool DstIsGPR, bool SrcIsGPR, unsigned Size) { - AArch64GenRegisterBankInfo::PartialMappingIdx DstRBIdx = - DstIsGPR ? AArch64GenRegisterBankInfo::PMI_FirstGPR - : AArch64GenRegisterBankInfo::PMI_FirstFPR; - AArch64GenRegisterBankInfo::PartialMappingIdx SrcRBIdx = - SrcIsGPR ? AArch64GenRegisterBankInfo::PMI_FirstGPR - : AArch64GenRegisterBankInfo::PMI_FirstFPR; - if (DstRBIdx == SrcRBIdx) - return getValueMapping(DstRBIdx, Size); - assert(Size <= 64 && "GPR cannot handle that size"); - unsigned ValMappingIdx = - AArch64GenRegisterBankInfo::FirstCrossRegCpyIdx + - (DstRBIdx - AArch64GenRegisterBankInfo::PMI_Min + - AArch64GenRegisterBankInfo::getRegBankBaseIdxOffset(DstRBIdx, Size)) * - AArch64GenRegisterBankInfo::ValueMappingIdx:: - DistanceBetweenCrossRegCpy; - assert(ValMappingIdx >= AArch64GenRegisterBankInfo::FirstCrossRegCpyIdx && - ValMappingIdx <= AArch64GenRegisterBankInfo::LastCrossRegCpyIdx && - "Mapping out of bound"); - return &AArch64GenRegisterBankInfo::ValMappings[ValMappingIdx]; -} -} // End AArch64 namespace. - bool AArch64GenRegisterBankInfo::checkPartialMap(unsigned Idx, unsigned ValStartIdx, unsigned ValLength, @@ -286,9 +231,88 @@ bool AArch64GenRegisterBankInfo::checkValueMapImpl(unsigned Idx, unsigned Offset) { unsigned PartialMapBaseIdx = Idx - PartialMappingIdx::PMI_Min; const ValueMapping &Map = - AArch64::getValueMapping((PartialMappingIdx)FirstInBank, Size)[Offset]; + AArch64GenRegisterBankInfo::getValueMapping((PartialMappingIdx)FirstInBank, Size)[Offset]; return Map.BreakDown == &PartMappings[PartialMapBaseIdx] && Map.NumBreakDowns == 1; } +bool AArch64GenRegisterBankInfo::checkPartialMappingIdx( + PartialMappingIdx FirstAlias, PartialMappingIdx LastAlias, + ArrayRef Order) { + if (Order.front() != FirstAlias) + return false; + if (Order.back() != LastAlias) + return false; + if (Order.front() > Order.back()) + return false; + + PartialMappingIdx Previous = Order.front(); + bool First = true; + for (const auto &Current : Order) { + if (First) { + First = false; + continue; + } + if (Previous + 1 != Current) + return false; + Previous = Current; + } + return true; +} + +unsigned AArch64GenRegisterBankInfo::getRegBankBaseIdxOffset(unsigned RBIdx, + unsigned Size) { + if (RBIdx == PMI_FirstGPR) { + if (Size <= 32) + return 0; + if (Size <= 64) + return 1; + llvm_unreachable("Unexpected size"); + } + if (RBIdx == PMI_FirstFPR) { + if (Size <= 32) + return 0; + if (Size <= 64) + return 1; + if (Size <= 128) + return 2; + if (Size <= 256) + return 3; + if (Size <= 512) + return 4; + llvm_unreachable("Unexpected size"); + } + llvm_unreachable("Unexpected bank"); +} + +const RegisterBankInfo::ValueMapping * +AArch64GenRegisterBankInfo::getValueMapping(PartialMappingIdx RBIdx, + unsigned Size) { + assert(RBIdx != PartialMappingIdx::PMI_None && "No mapping needed for that"); + unsigned ValMappingIdx = First3OpsIdx + + (RBIdx - PartialMappingIdx::PMI_Min + + getRegBankBaseIdxOffset(RBIdx, Size)) * + ValueMappingIdx::DistanceBetweenRegBanks; + assert(ValMappingIdx >= First3OpsIdx && ValMappingIdx <= Last3OpsIdx && + "Mapping out of bound"); + + return &ValMappings[ValMappingIdx]; +} + +const RegisterBankInfo::ValueMapping * +AArch64GenRegisterBankInfo::getCopyMapping(bool DstIsGPR, bool SrcIsGPR, + unsigned Size) { + PartialMappingIdx DstRBIdx = DstIsGPR ? PMI_FirstGPR : PMI_FirstFPR; + PartialMappingIdx SrcRBIdx = SrcIsGPR ? PMI_FirstGPR : PMI_FirstFPR; + if (DstRBIdx == SrcRBIdx) + return getValueMapping(DstRBIdx, Size); + assert(Size <= 64 && "GPR cannot handle that size"); + unsigned ValMappingIdx = + FirstCrossRegCpyIdx + + (DstRBIdx - PMI_Min + getRegBankBaseIdxOffset(DstRBIdx, Size)) * + ValueMappingIdx::DistanceBetweenCrossRegCpy; + assert(ValMappingIdx >= FirstCrossRegCpyIdx && + ValMappingIdx <= LastCrossRegCpyIdx && "Mapping out of bound"); + return &ValMappings[ValMappingIdx]; +} } // End llvm namespace. diff --git a/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.cpp b/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.cpp index a26ddacb14c0..f2da23a4dac5 100644 --- a/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.cpp +++ b/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.cpp @@ -148,8 +148,8 @@ AArch64RegisterBankInfo::AArch64RegisterBankInfo(const TargetRegisterInfo &TRI) (void)PartialMapDstIdx; \ (void)PartialMapSrcIdx; \ const ValueMapping *Map = \ - AArch64::getCopyMapping(PMI_First##RBNameDst == PMI_FirstGPR, \ - PMI_First##RBNameSrc == PMI_FirstGPR, Size); \ + getCopyMapping(PMI_First##RBNameDst == PMI_FirstGPR, \ + PMI_First##RBNameSrc == PMI_FirstGPR, Size); \ (void)Map; \ assert(Map[0].BreakDown == \ &AArch64GenRegisterBankInfo::PartMappings[PartialMapDstIdx] && \ @@ -254,10 +254,10 @@ AArch64RegisterBankInfo::getInstrAlternativeMappings( break; InstructionMappings AltMappings; InstructionMapping GPRMapping( - /*ID*/ 1, /*Cost*/ 1, AArch64::getValueMapping(PMI_FirstGPR, Size), + /*ID*/ 1, /*Cost*/ 1, getValueMapping(PMI_FirstGPR, Size), /*NumOperands*/ 3); InstructionMapping FPRMapping( - /*ID*/ 2, /*Cost*/ 1, AArch64::getValueMapping(PMI_FirstFPR, Size), + /*ID*/ 2, /*Cost*/ 1, getValueMapping(PMI_FirstFPR, Size), /*NumOperands*/ 3); AltMappings.emplace_back(std::move(GPRMapping)); @@ -277,21 +277,21 @@ AArch64RegisterBankInfo::getInstrAlternativeMappings( InstructionMappings AltMappings; InstructionMapping GPRMapping( /*ID*/ 1, /*Cost*/ 1, - AArch64::getCopyMapping(/*DstIsGPR*/ true, /*SrcIsGPR*/ true, Size), + getCopyMapping(/*DstIsGPR*/ true, /*SrcIsGPR*/ true, Size), /*NumOperands*/ 2); InstructionMapping FPRMapping( /*ID*/ 2, /*Cost*/ 1, - AArch64::getCopyMapping(/*DstIsGPR*/ false, /*SrcIsGPR*/ false, Size), + getCopyMapping(/*DstIsGPR*/ false, /*SrcIsGPR*/ false, Size), /*NumOperands*/ 2); InstructionMapping GPRToFPRMapping( /*ID*/ 3, /*Cost*/ copyCost(AArch64::GPRRegBank, AArch64::FPRRegBank, Size), - AArch64::getCopyMapping(/*DstIsGPR*/ false, /*SrcIsGPR*/ true, Size), + getCopyMapping(/*DstIsGPR*/ false, /*SrcIsGPR*/ true, Size), /*NumOperands*/ 2); InstructionMapping FPRToGPRMapping( /*ID*/ 3, /*Cost*/ copyCost(AArch64::GPRRegBank, AArch64::FPRRegBank, Size), - AArch64::getCopyMapping(/*DstIsGPR*/ true, /*SrcIsGPR*/ false, Size), + getCopyMapping(/*DstIsGPR*/ true, /*SrcIsGPR*/ false, Size), /*NumOperands*/ 2); AltMappings.emplace_back(std::move(GPRMapping)); @@ -313,15 +313,15 @@ AArch64RegisterBankInfo::getInstrAlternativeMappings( InstructionMappings AltMappings; InstructionMapping GPRMapping( /*ID*/ 1, /*Cost*/ 1, - getOperandsMapping({AArch64::getValueMapping(PMI_FirstGPR, Size), + getOperandsMapping({getValueMapping(PMI_FirstGPR, Size), // Addresses are GPR 64-bit. - AArch64::getValueMapping(PMI_FirstGPR, 64)}), + getValueMapping(PMI_FirstGPR, 64)}), /*NumOperands*/ 2); InstructionMapping FPRMapping( /*ID*/ 2, /*Cost*/ 1, - getOperandsMapping({AArch64::getValueMapping(PMI_FirstFPR, Size), + getOperandsMapping({getValueMapping(PMI_FirstFPR, Size), // Addresses are GPR 64-bit. - AArch64::getValueMapping(PMI_FirstGPR, 64)}), + getValueMapping(PMI_FirstGPR, 64)}), /*NumOperands*/ 2); AltMappings.emplace_back(std::move(GPRMapping)); @@ -405,8 +405,8 @@ AArch64RegisterBankInfo::getSameKindOfOperandsMapping(const MachineInstr &MI) { } #endif // End NDEBUG. - return InstructionMapping{DefaultMappingID, 1, - AArch64::getValueMapping(RBIdx, Size), NumOperands}; + return InstructionMapping{DefaultMappingID, 1, getValueMapping(RBIdx, Size), + NumOperands}; } RegisterBankInfo::InstructionMapping @@ -457,7 +457,7 @@ AArch64RegisterBankInfo::getInstrMapping(const MachineInstr &MI) const { const RegisterBank &SrcRB = SrcIsGPR ? AArch64::GPRRegBank : AArch64::FPRRegBank; return InstructionMapping{DefaultMappingID, copyCost(DstRB, SrcRB, Size), - AArch64::getCopyMapping(DstIsGPR, SrcIsGPR, Size), + getCopyMapping(DstIsGPR, SrcIsGPR, Size), /*NumOperands*/ 2}; } case TargetOpcode::G_SEQUENCE: @@ -535,8 +535,7 @@ AArch64RegisterBankInfo::getInstrMapping(const MachineInstr &MI) const { SmallVector OpdsMapping(NumOperands); for (unsigned Idx = 0; Idx < NumOperands; ++Idx) if (MI.getOperand(Idx).isReg()) - OpdsMapping[Idx] = - AArch64::getValueMapping(OpRegBankIdx[Idx], OpSize[Idx]); + OpdsMapping[Idx] = getValueMapping(OpRegBankIdx[Idx], OpSize[Idx]); Mapping.setOperandsMapping(getOperandsMapping(OpdsMapping)); return Mapping; diff --git a/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.h b/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.h index 7dcb44a0de48..1ad4ca5fd463 100644 --- a/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.h +++ b/llvm/lib/Target/AArch64/AArch64RegisterBankInfo.h @@ -70,51 +70,28 @@ public: static bool checkPartialMappingIdx(PartialMappingIdx FirstAlias, PartialMappingIdx LastAlias, - ArrayRef Order) { - if (Order.front() != FirstAlias) - return false; - if (Order.back() != LastAlias) - return false; - if (Order.front() > Order.back()) - return false; + ArrayRef Order); - PartialMappingIdx Previous = Order.front(); - bool First = true; - for (const auto &Current : Order) { - if (First) { - First = false; - continue; - } - if (Previous + 1 != Current) - return false; - Previous = Current; - } - return true; - } + static unsigned getRegBankBaseIdxOffset(unsigned RBIdx, unsigned Size); - static unsigned getRegBankBaseIdxOffset(unsigned RBIdx, unsigned Size) { - if (RBIdx == PMI_FirstGPR) { - if (Size <= 32) - return 0; - if (Size <= 64) - return 1; - llvm_unreachable("Unexpected size"); - } - if (RBIdx == PMI_FirstFPR) { - if (Size <= 32) - return 0; - if (Size <= 64) - return 1; - if (Size <= 128) - return 2; - if (Size <= 256) - return 3; - if (Size <= 512) - return 4; - llvm_unreachable("Unexpected size"); - } - llvm_unreachable("Unexpected bank"); -} + /// Get the pointer to the ValueMapping representing the RegisterBank + /// at \p RBIdx with a size of \p Size. + /// + /// The returned mapping works for instructions with the same kind of + /// operands for up to 3 operands. + /// + /// \pre \p RBIdx != PartialMappingIdx::None + static const RegisterBankInfo::ValueMapping * + getValueMapping(PartialMappingIdx RBIdx, unsigned Size); + + /// Get the pointer to the ValueMapping of the operands of a copy + /// instruction from a GPR or FPR register to a GPR or FPR register + /// with a size of \p Size. + /// + /// If \p DstIsGPR is true, the destination of the copy is on GPR, + /// otherwise it is on FPR. Same thing for \p SrcIsGPR. + static const RegisterBankInfo::ValueMapping * + getCopyMapping(bool DstIsGPR, bool SrcIsGPR, unsigned Size); }; /// This class provides the information for the target register banks.