diff options
| author | Nate Begeman <natebegeman@mac.com> | 2008-02-14 07:39:30 +0000 |
|---|---|---|
| committer | Nate Begeman <natebegeman@mac.com> | 2008-02-14 07:39:30 +0000 |
| commit | 26b76b69f4ce4877f67ca28c31527d2b5aff2229 (patch) | |
| tree | dc0f6a8a03e30e94aa0bda720025f9d7cf8a9435 /llvm/lib | |
| parent | 89acd61805ca070deba4805869fcc582d96b47fd (diff) | |
| download | bcm5719-llvm-26b76b69f4ce4877f67ca28c31527d2b5aff2229.tar.gz bcm5719-llvm-26b76b69f4ce4877f67ca28c31527d2b5aff2229.zip | |
Support a new type of MachineOperand, MO_FPImmediate, used for holding
FP Immediates, crazily enough
llvm-svn: 47117
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/MachineInstr.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/MachineInstr.cpp b/llvm/lib/CodeGen/MachineInstr.cpp index d576caf7f9b..911d5caa1d3 100644 --- a/llvm/lib/CodeGen/MachineInstr.cpp +++ b/llvm/lib/CodeGen/MachineInstr.cpp @@ -11,6 +11,7 @@ // //===----------------------------------------------------------------------===// +#include "llvm/Constants.h" #include "llvm/CodeGen/MachineInstr.h" #include "llvm/Value.h" #include "llvm/CodeGen/MachineFunction.h" @@ -138,6 +139,8 @@ bool MachineOperand::isIdenticalTo(const MachineOperand &Other) const { getSubReg() == Other.getSubReg(); case MachineOperand::MO_Immediate: return getImm() == Other.getImm(); + case MachineOperand::MO_FPImmediate: + return getFPImm() == Other.getFPImm(); case MachineOperand::MO_MachineBasicBlock: return getMBB() == Other.getMBB(); case MachineOperand::MO_FrameIndex: @@ -197,6 +200,13 @@ void MachineOperand::print(std::ostream &OS, const TargetMachine *TM) const { case MachineOperand::MO_Immediate: OS << getImm(); break; + case MachineOperand::MO_FPImmediate: + if (getFPImm()->getType() == Type::FloatTy) { + OS << getFPImm()->getValueAPF().convertToFloat(); + } else { + OS << getFPImm()->getValueAPF().convertToDouble(); + } + break; case MachineOperand::MO_MachineBasicBlock: OS << "mbb<" << ((Value*)getMBB()->getBasicBlock())->getName() |

