summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/GlobalISel
diff options
context:
space:
mode:
authorAhmed Bougacha <ahmed.bougacha@gmail.com>2017-03-19 16:12:48 +0000
committerAhmed Bougacha <ahmed.bougacha@gmail.com>2017-03-19 16:12:48 +0000
commit7f2d17331c7ecbdf171eb4557dd8c0edcab8d392 (patch)
tree835c4267fe35322fb49300ce83c697b21dae4f48 /llvm/lib/CodeGen/GlobalISel
parent531e275aa8f3de18e3ecb0b88704965d14c78f85 (diff)
downloadbcm5719-llvm-7f2d17331c7ecbdf171eb4557dd8c0edcab8d392.tar.gz
bcm5719-llvm-7f2d17331c7ecbdf171eb4557dd8c0edcab8d392.zip
[GlobalISel] Move method definition to the proper file. NFC.
llvm-svn: 298221
Diffstat (limited to 'llvm/lib/CodeGen/GlobalISel')
-rw-r--r--llvm/lib/CodeGen/GlobalISel/InstructionSelect.cpp19
-rw-r--r--llvm/lib/CodeGen/GlobalISel/InstructionSelector.cpp21
2 files changed, 21 insertions, 19 deletions
diff --git a/llvm/lib/CodeGen/GlobalISel/InstructionSelect.cpp b/llvm/lib/CodeGen/GlobalISel/InstructionSelect.cpp
index c1e4a8661a2..0ca4134a577 100644
--- a/llvm/lib/CodeGen/GlobalISel/InstructionSelect.cpp
+++ b/llvm/lib/CodeGen/GlobalISel/InstructionSelect.cpp
@@ -177,22 +177,3 @@ bool InstructionSelect::runOnMachineFunction(MachineFunction &MF) {
// FIXME: Should we accurately track changes?
return true;
}
-
-bool InstructionSelector::isOperandImmEqual(
- const MachineOperand &MO, int64_t Value,
- const MachineRegisterInfo &MRI) const {
- // TODO: We should also test isImm() and isCImm() too but this isn't required
- // until a DAGCombine equivalent is implemented.
-
- if (MO.isReg()) {
- MachineInstr *Def = MRI.getVRegDef(MO.getReg());
- if (Def->getOpcode() != TargetOpcode::G_CONSTANT)
- return false;
- assert(Def->getOperand(1).isCImm() &&
- "G_CONSTANT values must be constants");
- const ConstantInt &Imm = *Def->getOperand(1).getCImm();
- return Imm.getBitWidth() <= 64 && Imm.getSExtValue() == Value;
- }
-
- return false;
-}
diff --git a/llvm/lib/CodeGen/GlobalISel/InstructionSelector.cpp b/llvm/lib/CodeGen/GlobalISel/InstructionSelector.cpp
index 1e1d0392483..104835c7c59 100644
--- a/llvm/lib/CodeGen/GlobalISel/InstructionSelector.cpp
+++ b/llvm/lib/CodeGen/GlobalISel/InstructionSelector.cpp
@@ -14,6 +14,8 @@
#include "llvm/CodeGen/GlobalISel/RegisterBankInfo.h"
#include "llvm/CodeGen/GlobalISel/Utils.h"
#include "llvm/CodeGen/MachineInstr.h"
+#include "llvm/CodeGen/MachineRegisterInfo.h"
+#include "llvm/IR/Constants.h"
#include "llvm/Target/TargetInstrInfo.h"
#include "llvm/Target/TargetRegisterInfo.h"
@@ -65,3 +67,22 @@ bool InstructionSelector::constrainSelectedInstRegOperands(
}
return true;
}
+
+bool InstructionSelector::isOperandImmEqual(
+ const MachineOperand &MO, int64_t Value,
+ const MachineRegisterInfo &MRI) const {
+ // TODO: We should also test isImm() and isCImm() too but this isn't required
+ // until a DAGCombine equivalent is implemented.
+
+ if (MO.isReg()) {
+ MachineInstr *Def = MRI.getVRegDef(MO.getReg());
+ if (Def->getOpcode() != TargetOpcode::G_CONSTANT)
+ return false;
+ assert(Def->getOperand(1).isCImm() &&
+ "G_CONSTANT values must be constants");
+ const ConstantInt &Imm = *Def->getOperand(1).getCImm();
+ return Imm.getBitWidth() <= 64 && Imm.getSExtValue() == Value;
+ }
+
+ return false;
+}
OpenPOWER on IntegriCloud