|
LLVM 22.0.0git
|
#include "Target/Hexagon/HexagonSubtarget.h"
Classes | |
| struct | BankConflictMutation |
| struct | CallMutation |
| struct | HVXMemLatencyMutation |
| struct | UsrOverflowMutation |
Public Attributes | |
| Hexagon::ArchEnum | HexagonArchVersion |
| Hexagon::ArchEnum | HexagonHVXVersion = Hexagon::ArchEnum::NoArch |
| CodeGenOptLevel | OptLevel |
| bool | UseBSBScheduling |
| True if the target should use Back-Skip-Back scheduling. | |
Definition at line 43 of file HexagonSubtarget.h.
| HexagonSubtarget::HexagonSubtarget | ( | const Triple & | TT, |
| StringRef | CPU, | ||
| StringRef | FS, | ||
| const TargetMachine & | TM ) |
Definition at line 73 of file HexagonSubtarget.cpp.
References llvm::Hexagon_MC::addArchSubtarget(), assert(), initializeSubtargetDependencies(), and OptLevel.
Referenced by llvm::HexagonSubtarget::CallMutation::apply().
|
override |
Perform target specific adjustments to the latency of a schedule dependency.
Definition at line 434 of file HexagonSubtarget.cpp.
References llvm::HexagonInstrInfo::canExecuteInBundle(), llvm::SmallPtrSetImplBase::clear(), EnableDotCurSched, getInstrInfo(), llvm::SDep::getLatency(), llvm::MachineInstr::getNumOperands(), llvm::MachineInstr::getOperand(), llvm::MachineOperand::getReg(), llvm::SDep::isArtificial(), llvm::MachineInstr::isCopy(), llvm::MachineOperand::isReg(), llvm::MachineInstr::isRegSequence(), llvm::HexagonInstrInfo::isToBeScheduledASAP(), llvm::MachineOperand::isUse(), llvm::Latency, and llvm::SDep::setLatency().
|
inlineoverride |
Definition at line 300 of file HexagonSubtarget.h.
|
override |
Definition at line 527 of file HexagonSubtarget.cpp.
References DisableHexagonMISched.
|
inlineoverride |
True if the subtarget should run a scheduler after register allocation.
Definition at line 307 of file HexagonSubtarget.h.
|
override |
Definition at line 723 of file HexagonSubtarget.cpp.
|
inlineoverride |
Definition at line 304 of file HexagonSubtarget.h.
|
inline |
Definition at line 311 of file HexagonSubtarget.h.
|
inlineoverride |
Definition at line 129 of file HexagonSubtarget.h.
Referenced by llvm::HexagonDAGToDAGISel::emitFunctionEntryCode().
|
inline |
Definition at line 313 of file HexagonSubtarget.h.
References HexagonArchVersion.
Referenced by hasV55Ops(), hasV55OpsOnly(), hasV5Ops(), hasV5OpsOnly(), hasV60Ops(), hasV60OpsOnly(), hasV62Ops(), hasV62OpsOnly(), hasV65Ops(), hasV65OpsOnly(), hasV66Ops(), hasV66OpsOnly(), hasV67Ops(), hasV67OpsOnly(), hasV68Ops(), hasV68OpsOnly(), hasV69Ops(), hasV69OpsOnly(), hasV71Ops(), hasV71OpsOnly(), hasV73Ops(), hasV73OpsOnly(), hasV75Ops(), hasV75OpsOnly(), hasV79Ops(), hasV79OpsOnly(), hasV81Ops(), and hasV81OpsOnly().
Definition at line 344 of file HexagonSubtarget.h.
References llvm::ArrayRef(), useHVXFloatingPoint(), useHVXV68Ops(), and useHVXV81Ops().
Referenced by isHVXElementType(), and isHVXVectorType().
|
inlineoverride |
Definition at line 122 of file HexagonSubtarget.h.
Referenced by adjustSchedDependency(), llvm::HexagonSubtarget::CallMutation::apply(), llvm::HexagonRegisterInfo::eliminateFrameIndex(), llvm::HexagonPacketizerList::HexagonPacketizerList(), INITIALIZE_PASS(), llvm::HexagonDAGToDAGISel::runOnMachineFunction(), and llvm::HexagonConvergingVLIWScheduler::SchedulingCost().
|
inlineoverride |
getInstrItins - Return the instruction itineraries based on subtarget selection.
Definition at line 119 of file HexagonSubtarget.h.
| Intrinsic::ID HexagonSubtarget::getIntrinsicId | ( | unsigned | Opc | ) | const |
Definition at line 725 of file HexagonSubtarget.cpp.
References A(), B(), error, getVectorLength(), llvm_unreachable, Opc, and llvm::sort().
Referenced by get_i32_Mask().
| unsigned HexagonSubtarget::getL1CacheLineSize | ( | ) | const |
Definition at line 715 of file HexagonSubtarget.cpp.
| unsigned HexagonSubtarget::getL1PrefetchDistance | ( | ) | const |
Definition at line 719 of file HexagonSubtarget.cpp.
|
override |
Definition at line 511 of file HexagonSubtarget.cpp.
|
inlineoverride |
Definition at line 123 of file HexagonSubtarget.h.
Referenced by llvm::HexagonPacketizerList::HexagonPacketizerList(), and INITIALIZE_PASS().
|
inlineoverride |
Definition at line 132 of file HexagonSubtarget.h.
|
override |
Definition at line 518 of file HexagonSubtarget.cpp.
|
inlineoverride |
Definition at line 126 of file HexagonSubtarget.h.
Referenced by isTypeForHVX().
Definition at line 112 of file HexagonSubtarget.h.
Definition at line 361 of file HexagonSubtarget.h.
References getVectorLength(), and isHVXVectorType().
|
inline |
Definition at line 335 of file HexagonSubtarget.h.
References assert(), llvm_unreachable, useHVX128BOps(), useHVX64BOps(), and useHVXOps().
Referenced by getIntrinsicId(), getTypeAlignment(), and isHVXVectorType().
|
inline |
Definition at line 288 of file HexagonSubtarget.h.
|
inline |
Definition at line 289 of file HexagonSubtarget.h.
Referenced by llvm::HexagonRegisterInfo::getReservedRegs().
|
inline |
Definition at line 151 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V55.
|
inline |
Definition at line 154 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V55.
|
inline |
Definition at line 145 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V5.
|
inline |
Definition at line 148 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V5.
|
inline |
Definition at line 157 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V60.
Referenced by initializeSubtargetDependencies().
|
inline |
Definition at line 160 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V60.
Referenced by cannotCoexistAsymm().
|
inline |
Definition at line 163 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V62.
|
inline |
Definition at line 166 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V62.
|
inline |
Definition at line 169 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V65.
Referenced by llvm::HexagonPacketizerList::isLegalToPacketizeTogether().
|
inline |
Definition at line 172 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V65.
|
inline |
Definition at line 175 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V66.
|
inline |
Definition at line 178 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V66.
|
inline |
Definition at line 181 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V67.
|
inline |
Definition at line 184 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V67.
|
inline |
Definition at line 187 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V68.
Referenced by initializeSubtargetDependencies().
|
inline |
Definition at line 190 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V68.
|
inline |
Definition at line 193 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V69.
|
inline |
Definition at line 196 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V69.
|
inline |
Definition at line 199 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V71.
|
inline |
Definition at line 202 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V71.
|
inline |
Definition at line 205 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V73.
|
inline |
Definition at line 208 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V73.
|
inline |
Definition at line 211 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V75.
|
inline |
Definition at line 214 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V75.
|
inline |
Definition at line 217 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V79.
|
inline |
Definition at line 220 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V79.
|
inline |
Definition at line 226 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V81.
|
inline |
Definition at line 229 of file HexagonSubtarget.h.
References getHexagonArchVersion(), and llvm::Hexagon::V81.
| HexagonSubtarget & HexagonSubtarget::initializeSubtargetDependencies | ( | StringRef | CPU, |
| StringRef | FS ) |
Definition at line 87 of file HexagonSubtarget.cpp.
References llvm::SubtargetFeatures::AddFeature(), llvm::Hexagon_MC::completeHVXFeatures(), llvm::StringRef::consumeInteger(), llvm::count_if(), llvm::dbgs(), llvm::StringRef::drop_front(), EnableBSBSched, F, llvm::Hexagon::getCpu(), llvm::SubtargetFeatures::getFeatures(), llvm::SubtargetFeatures::getString(), hasV60Ops(), hasV68Ops(), HexagonArchVersion, llvm::HexagonDisableDuplex, isTinyCore(), LLVM_DEBUG, llvm_unreachable, OverrideLongCalls, ParseSubtargetFeatures(), llvm::FeatureBitset::reset(), llvm::reverse(), llvm::StringRef::starts_with(), UseBSBScheduling, and useHVXV68Ops().
Referenced by HexagonSubtarget().
|
inline |
Definition at line 113 of file HexagonSubtarget.h.
References llvm::Triple::Musl.
Definition at line 168 of file HexagonSubtarget.cpp.
References getHVXElementTypes(), llvm::is_contained(), and useHVXOps().
Definition at line 179 of file HexagonSubtarget.cpp.
References getHVXElementTypes(), llvm::EVT::getSimpleVT(), llvm::EVT::getSizeInBits(), llvm::MVT::getVectorElementType(), getVectorLength(), llvm::EVT::getVectorNumElements(), llvm::is_contained(), llvm::EVT::isScalableVector(), llvm::EVT::isSimple(), llvm::EVT::isVector(), T, and useHVXOps().
Referenced by getTypeAlignment(), and isTypeForHVX().
|
inline |
Definition at line 247 of file HexagonSubtarget.h.
Referenced by initializeSubtargetDependencies(), and isTinyCoreWithDuplex().
|
inline |
Definition at line 248 of file HexagonSubtarget.h.
References isTinyCore().
Definition at line 207 of file HexagonSubtarget.cpp.
References llvm::EVT::getEVT(), llvm::HexagonTargetLowering::getPreferredVectorAction(), llvm::Type::getScalarType(), getTargetLowering(), llvm::MVT::getVectorElementType(), llvm::MVT::getVectorVT(), llvm::isa(), llvm::Type::isFloatingPointTy(), isHVXVectorType(), llvm::Type::isIntegerTy(), llvm::MVT::isValid(), llvm::Type::isVectorTy(), llvm::PowerOf2Ceil(), llvm::TargetLoweringBase::TypeWidenVector, and useHVXFloatingPoint().
|
inlineoverride |
Definition at line 143 of file HexagonSubtarget.h.
|
inline |
Definition at line 292 of file HexagonSubtarget.h.
| void llvm::HexagonSubtarget::ParseSubtargetFeatures | ( | StringRef | CPU, |
| StringRef | TuneCPU, | ||
| StringRef | FS ) |
ParseSubtargetFeatures - Parses features string setting specified subtarget options.
Definition of function is auto generated by tblgen.
Referenced by initializeSubtargetDependencies().
|
override |
Enable use of alias analysis during code generation (during MI scheduling, DAGCombine, etc.).
Definition at line 426 of file HexagonSubtarget.cpp.
References llvm::None, and OptLevel.
|
inline |
Definition at line 236 of file HexagonSubtarget.h.
|
inline |
Definition at line 294 of file HexagonSubtarget.h.
References UseBSBScheduling.
|
inline |
Definition at line 245 of file HexagonSubtarget.h.
|
inline |
Definition at line 237 of file HexagonSubtarget.h.
|
inline |
Definition at line 285 of file HexagonSubtarget.h.
References useHVXOps().
Referenced by getVectorLength().
|
inline |
Definition at line 286 of file HexagonSubtarget.h.
References useHVXOps().
Referenced by getVectorLength().
|
inline |
Definition at line 254 of file HexagonSubtarget.h.
Referenced by getHVXElementTypes(), and isTypeForHVX().
|
inline |
Definition at line 250 of file HexagonSubtarget.h.
References useHVXOps().
|
inline |
Definition at line 255 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::NoArch.
Referenced by llvm::HexagonTargetLowering::CanLowerReturn(), getVectorLength(), isHVXElementType(), isHVXVectorType(), llvm::HexagonRegisterInfo::shouldCoalesce(), useHVX128BOps(), useHVX64BOps(), and useHVXIEEEFPOps().
|
inline |
Definition at line 251 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V68.
|
inline |
Definition at line 258 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V60.
|
inline |
Definition at line 261 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V62.
|
inline |
Definition at line 264 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V65.
|
inline |
Definition at line 267 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V66.
|
inline |
Definition at line 270 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V67.
|
inline |
Definition at line 273 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V68.
Referenced by getHVXElementTypes(), and initializeSubtargetDependencies().
|
inline |
Definition at line 276 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V69.
|
inline |
Definition at line 279 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V71.
|
inline |
Definition at line 282 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V73.
|
inline |
Definition at line 223 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V79.
|
inline |
Definition at line 232 of file HexagonSubtarget.h.
References HexagonHVXVersion, and llvm::Hexagon::V81.
Referenced by getHVXElementTypes().
|
inline |
Definition at line 238 of file HexagonSubtarget.h.
|
inline |
Definition at line 239 of file HexagonSubtarget.h.
|
inline |
Definition at line 241 of file HexagonSubtarget.h.
|
inline |
Definition at line 242 of file HexagonSubtarget.h.
|
inline |
Definition at line 240 of file HexagonSubtarget.h.
| bool HexagonSubtarget::usePredicatedCalls | ( | ) | const |
Definition at line 533 of file HexagonSubtarget.cpp.
References EnablePredicatedCalls.
|
inline |
Definition at line 243 of file HexagonSubtarget.h.
|
inline |
Definition at line 244 of file HexagonSubtarget.h.
| Hexagon::ArchEnum llvm::HexagonSubtarget::HexagonArchVersion |
Definition at line 70 of file HexagonSubtarget.h.
Referenced by getHexagonArchVersion(), and initializeSubtargetDependencies().
| Hexagon::ArchEnum llvm::HexagonSubtarget::HexagonHVXVersion = Hexagon::ArchEnum::NoArch |
Definition at line 71 of file HexagonSubtarget.h.
Referenced by useHVXOps(), useHVXQFloatOps(), useHVXV60Ops(), useHVXV62Ops(), useHVXV65Ops(), useHVXV66Ops(), useHVXV67Ops(), useHVXV68Ops(), useHVXV69Ops(), useHVXV71Ops(), useHVXV73Ops(), useHVXV79Ops(), and useHVXV81Ops().
| CodeGenOptLevel llvm::HexagonSubtarget::OptLevel |
Definition at line 72 of file HexagonSubtarget.h.
Referenced by HexagonSubtarget(), and useAA().
| bool llvm::HexagonSubtarget::UseBSBScheduling |
True if the target should use Back-Skip-Back scheduling.
This is the default for V60.
Definition at line 75 of file HexagonSubtarget.h.
Referenced by initializeSubtargetDependencies(), and useBSBScheduling().