diff options
| author | Michael Kruse <llvm-project@meinersbur.de> | 2025-01-03 10:22:51 +0100 |
|---|---|---|
| committer | Michael Kruse <llvm-project@meinersbur.de> | 2025-01-03 10:22:51 +0100 |
| commit | 38500d63e14ce340236840f60d356cdefb56a52c (patch) | |
| tree | 17edbec446ce9b50d2f215a483b83afb293a635d /llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp | |
| parent | 1a3d5daaef7a6a63448a497da3eff7fc9e23df26 (diff) | |
| parent | 27f30029741ecf023baece7b3dde1ff9011ffefc (diff) | |
Merge branch 'main' into users/meinersbur/flang_runtime_split-headersusers/meinersbur/flang_runtime_split-headers
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp b/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp index 43dfc4108f83..019d4cfa33fb 100644 --- a/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp +++ b/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp @@ -692,21 +692,23 @@ PPCRegisterInfo::getLargestLegalSuperClass(const TargetRegisterClass *RC, InflateGPRC++; } - for (const auto *I = RC->getSuperClasses(); *I; ++I) { - if (getRegSizeInBits(**I) != getRegSizeInBits(*RC)) + for (unsigned SuperID : RC->superclasses()) { + if (getRegSizeInBits(*getRegClass(SuperID)) != getRegSizeInBits(*RC)) continue; - switch ((*I)->getID()) { + switch (SuperID) { case PPC::VSSRCRegClassID: - return Subtarget.hasP8Vector() ? *I : DefaultSuperclass; + return Subtarget.hasP8Vector() ? getRegClass(SuperID) + : DefaultSuperclass; case PPC::VSFRCRegClassID: case PPC::VSRCRegClassID: - return *I; + return getRegClass(SuperID); case PPC::VSRpRCRegClassID: - return Subtarget.pairedVectorMemops() ? *I : DefaultSuperclass; + return Subtarget.pairedVectorMemops() ? getRegClass(SuperID) + : DefaultSuperclass; case PPC::ACCRCRegClassID: case PPC::UACCRCRegClassID: - return Subtarget.hasMMA() ? *I : DefaultSuperclass; + return Subtarget.hasMMA() ? getRegClass(SuperID) : DefaultSuperclass; } } } |
