diff options
| author | Christudasan Devadasan <Christudasan.Devadasan@amd.com> | 2026-01-07 12:42:45 +0000 |
|---|---|---|
| committer | Christudasan Devadasan <Christudasan.Devadasan@amd.com> | 2026-01-13 03:50:24 +0000 |
| commit | 4343cad32c10a45defe7feba63df493d3e18d13a (patch) | |
| tree | c15800d8f4f136a801d9eaaded89e838da18ffd8 /llvm/lib/CodeGen/LiveRangeEdit.cpp | |
| parent | a8e52977d7383770d2864d5afe2769993bdb86b4 (diff) | |
| download | llvm-users/cdevadas/enhance-createFrom-function.zip llvm-users/cdevadas/enhance-createFrom-function.tar.gz llvm-users/cdevadas/enhance-createFrom-function.tar.bz2 | |
[CodeGen] Enhance createFrom for sub-reg aware cloningusers/cdevadas/enhance-createFrom-function
Instead of just cloning the virtual register, this
function now creates a new virtual register derived
from a subregister class of the original value.
Diffstat (limited to 'llvm/lib/CodeGen/LiveRangeEdit.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/LiveRangeEdit.cpp | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/LiveRangeEdit.cpp b/llvm/lib/CodeGen/LiveRangeEdit.cpp index 6fe1170..d8a2ad4 100644 --- a/llvm/lib/CodeGen/LiveRangeEdit.cpp +++ b/llvm/lib/CodeGen/LiveRangeEdit.cpp @@ -52,8 +52,16 @@ LiveInterval &LiveRangeEdit::createEmptyIntervalFrom(Register OldReg, return LI; } -Register LiveRangeEdit::createFrom(Register OldReg) { +Register LiveRangeEdit::createFrom(Register OldReg, + const TargetRegisterClass *RC) { Register VReg = MRI.cloneVirtualRegister(OldReg); + + // If RC is given, set it now. This is needed for cloning a new VReg with a + // smaller RC from its original virtual register, mainly used for subreg + // reload. The cloning is done first to ensure the vreg flags are preserved. + if (RC) + MRI.setRegClass(VReg, RC); + if (VRM) { VRM->setIsSplitFromReg(VReg, VRM->getOriginal(OldReg)); } |
