diff options
author | Andrew Lenharth <andrewl@lenharth.org> | 2005-10-09 20:11:35 +0000 |
---|---|---|
committer | Andrew Lenharth <andrewl@lenharth.org> | 2005-10-09 20:11:35 +0000 |
commit | 1dfb85c7afb8294baebb6e0230717d822d44d5e1 (patch) | |
tree | 7dcee14b258c9b0b4d0e80451e9dbcd05608146e /llvm/lib/Target/Alpha/AlphaRegisterInfo.cpp | |
parent | 62010c450f3ee4bb718655487d80426dd19b424c (diff) | |
download | bcm5719-llvm-1dfb85c7afb8294baebb6e0230717d822d44d5e1.tar.gz bcm5719-llvm-1dfb85c7afb8294baebb6e0230717d822d44d5e1.zip |
This seems useful from the original patch that added the function. If there is a reason it is not useful on a RISC type target, let me know and I will pull it out
llvm-svn: 23676
Diffstat (limited to 'llvm/lib/Target/Alpha/AlphaRegisterInfo.cpp')
-rw-r--r-- | llvm/lib/Target/Alpha/AlphaRegisterInfo.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/llvm/lib/Target/Alpha/AlphaRegisterInfo.cpp b/llvm/lib/Target/Alpha/AlphaRegisterInfo.cpp index ac7d3f146f8..c348fa9ce46 100644 --- a/llvm/lib/Target/Alpha/AlphaRegisterInfo.cpp +++ b/llvm/lib/Target/Alpha/AlphaRegisterInfo.cpp @@ -107,6 +107,25 @@ AlphaRegisterInfo::loadRegFromStackSlot(MachineBasicBlock &MBB, abort(); } +unsigned +AlphaRegisterInfo::isLoadFromStackSlot(MachineInstr *MI, int &FrameIndex) const +{ + switch (MI->getOpcode()) { + case Alpha::LDL: + case Alpha::LDQ: + case Alpha::LDBU: + case Alpha::LDWU: + case Alpha::LDS: + case Alpha::LDT: + if (MI->getOperand(1).isFrameIndex()) { + FrameIndex = MI->getOperand(1).getFrameIndex(); + return MI->getOperand(0).getReg(); + } + break; + } + return 0; +} + void AlphaRegisterInfo::copyRegToReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, unsigned DestReg, unsigned SrcReg, |