diff options
author | Bill Wendling <isanbard@gmail.com> | 2011-12-06 01:26:14 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2011-12-06 01:26:14 +0000 |
commit | 79df986c60094e9ea29f081295aea08b1680a999 (patch) | |
tree | 995120cf786563d48c4824cd5e78e504fda805c7 | |
parent | d9a6e8978dd65c85d68bf1141d992da576878cd8 (diff) |
The compact encoding of the registers are 3-bits each. Make sure we shift the
value over that much.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@145888 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/X86/X86FrameLowering.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/Target/X86/X86FrameLowering.cpp b/lib/Target/X86/X86FrameLowering.cpp index 27b762af69..038ca7f34d 100644 --- a/lib/Target/X86/X86FrameLowering.cpp +++ b/lib/Target/X86/X86FrameLowering.cpp @@ -385,12 +385,14 @@ static uint32_t encodeCompactUnwindRegistersWithoutFrame(unsigned SavedRegs[6], }; const unsigned *CURegs = (Is64Bit ? CU64BitRegs : CU32BitRegs); - uint32_t RenumRegs[6]; for (unsigned i = 6 - RegCount; i < 6; ++i) { int CUReg = getCompactUnwindRegNum(CURegs, SavedRegs[i]); if (CUReg == -1) return ~0U; SavedRegs[i] = CUReg; + } + uint32_t RenumRegs[6]; + for (unsigned i = 6 - RegCount; i < 6; ++i) { unsigned Countless = 0; for (unsigned j = 6 - RegCount; j < i; ++j) if (SavedRegs[j] < SavedRegs[i]) @@ -454,7 +456,7 @@ static uint32_t encodeCompactUnwindRegistersWithFrame(unsigned SavedRegs[6], int CURegNum = getCompactUnwindRegNum(CURegs, Reg); if (CURegNum == -1) return ~0U; - RegEnc |= (CURegNum & 0x7) << (5 - I); + RegEnc |= (CURegNum & 0x7) << ((5 - I) * 3); } assert((RegEnc & 0x7FFF) == RegEnc && "Invalid compact register encoding!"); |