summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/X86/X86FrameLowering.cpp
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2011-12-06 19:16:17 +0000
committerBill Wendling <isanbard@gmail.com>2011-12-06 19:16:17 +0000
commit87571b63921c2459317082b5e2b060f846eea66e (patch)
tree79e8a082d9fdedddc9d78e55445aabb5bbc098c0 /llvm/lib/Target/X86/X86FrameLowering.cpp
parent8b815e1a087ffb6bc5bcf2c185838c1c243f610a (diff)
downloadbcm5719-llvm-87571b63921c2459317082b5e2b060f846eea66e.tar.gz
bcm5719-llvm-87571b63921c2459317082b5e2b060f846eea66e.zip
Check the correct value for small stack sizes. Also modify some comments.
llvm-svn: 145954
Diffstat (limited to 'llvm/lib/Target/X86/X86FrameLowering.cpp')
-rw-r--r--llvm/lib/Target/X86/X86FrameLowering.cpp13
1 files changed, 8 insertions, 5 deletions
diff --git a/llvm/lib/Target/X86/X86FrameLowering.cpp b/llvm/lib/Target/X86/X86FrameLowering.cpp
index 09aa114f1b6..fe3754587f5 100644
--- a/llvm/lib/Target/X86/X86FrameLowering.cpp
+++ b/llvm/lib/Target/X86/X86FrameLowering.cpp
@@ -554,17 +554,17 @@ uint32_t X86FrameLowering::getCompactUnwindEncoding(MachineFunction &MF) const {
// Get the encoding of the saved registers when we have a frame pointer.
uint32_t RegEnc = encodeCompactUnwindRegistersWithFrame(SavedRegs, Is64Bit);
- if (RegEnc == ~0U)
- return 0;
+ if (RegEnc == ~0U) return 0;
CompactUnwindEncoding |= 0x01000000;
CompactUnwindEncoding |= (CFAOffset & 0xFF) << 16;
CompactUnwindEncoding |= RegEnc & 0x7FFF;
} else {
- unsigned FullOffset = CFAOffset + StackAdjust;
- if ((FullOffset & 0xFF) == FullOffset) {
- // Frameless stack.
+ if ((CFAOffset & 0xFF) == CFAOffset) {
+ // Frameless stack with a small stack size.
CompactUnwindEncoding |= 0x02000000;
+
+ // Encode the stack size.
CompactUnwindEncoding |= (CFAOffset & 0xFF) << 16;
} else {
if ((CFAOffset & 0x7) != CFAOffset)
@@ -582,6 +582,7 @@ uint32_t X86FrameLowering::getCompactUnwindEncoding(MachineFunction &MF) const {
CompactUnwindEncoding |= (CFAOffset & 0x7) << 13;
}
+ // Encode the number of registers saved.
CompactUnwindEncoding |= ((6 - SavedRegIdx) & 0x7) << 10;
// Get the encoding of the saved registers when we don't have a frame
@@ -590,6 +591,8 @@ uint32_t X86FrameLowering::getCompactUnwindEncoding(MachineFunction &MF) const {
6 - SavedRegIdx,
Is64Bit);
if (RegEnc == ~0U) return 0;
+
+ // Encode the register encoding.
CompactUnwindEncoding |= RegEnc & 0x3FF;
}
OpenPOWER on IntegriCloud