summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp
diff options
context:
space:
mode:
authorTim Northover <tnorthover@apple.com>2016-08-23 21:01:26 +0000
committerTim Northover <tnorthover@apple.com>2016-08-23 21:01:26 +0000
commit6cd4b23a0fc9cc2f24d996148e170b0a538079d7 (patch)
treef70e16cf6123f81966b6be1c3a163a3b6a98cb11 /llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp
parentb3a0be4d38ab08456aa4406e86d1b6c76581245a (diff)
downloadbcm5719-llvm-6cd4b23a0fc9cc2f24d996148e170b0a538079d7.tar.gz
bcm5719-llvm-6cd4b23a0fc9cc2f24d996148e170b0a538079d7.zip
GlobalISel: legalize integer comparisons on AArch64.
Next step is doing both legalizations at the same time! Marvel at GlobalISel's cunning. llvm-svn: 279566
Diffstat (limited to 'llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp')
-rw-r--r--llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp36
1 files changed, 34 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp b/llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp
index f22cf358e77..2fb7f244c25 100644
--- a/llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp
+++ b/llvm/lib/CodeGen/GlobalISel/MachineLegalizeHelper.cpp
@@ -107,8 +107,6 @@ MachineLegalizeHelper::narrowScalar(MachineInstr &MI, unsigned TypeIdx,
MachineLegalizeHelper::LegalizeResult
MachineLegalizeHelper::widenScalar(MachineInstr &MI, unsigned TypeIdx,
LLT WideTy) {
- assert(TypeIdx == 0 && "don't know how to handle secondary types yet");
-
unsigned WideSize = WideTy.getSizeInBits();
MIRBuilder.setInstr(MI);
@@ -180,6 +178,40 @@ MachineLegalizeHelper::widenScalar(MachineInstr &MI, unsigned TypeIdx,
MI.eraseFromParent();
return Legalized;
}
+ case TargetOpcode::G_ICMP: {
+ if (TypeIdx == 0) {
+ unsigned TstExt = MRI.createGenericVirtualRegister(WideSize);
+ MIRBuilder.buildICmp(
+ {WideTy, MI.getType(1)},
+ static_cast<CmpInst::Predicate>(MI.getOperand(1).getPredicate()),
+ TstExt, MI.getOperand(2).getReg(), MI.getOperand(3).getReg());
+ MIRBuilder.buildTrunc(MI.getType(), MI.getOperand(0).getReg(), TstExt);
+ MI.eraseFromParent();
+ return Legalized;
+ } else {
+ bool IsSigned = CmpInst::isSigned(
+ static_cast<CmpInst::Predicate>(MI.getOperand(1).getPredicate()));
+ unsigned Op0Ext = MRI.createGenericVirtualRegister(WideSize);
+ unsigned Op1Ext = MRI.createGenericVirtualRegister(WideSize);
+ if (IsSigned) {
+ MIRBuilder.buildSExt({WideTy, MI.getType(1)}, Op0Ext,
+ MI.getOperand(2).getReg());
+ MIRBuilder.buildSExt({WideTy, MI.getType(1)}, Op1Ext,
+ MI.getOperand(3).getReg());
+ } else {
+ MIRBuilder.buildZExt({WideTy, MI.getType(1)}, Op0Ext,
+ MI.getOperand(2).getReg());
+ MIRBuilder.buildZExt({WideTy, MI.getType(1)}, Op1Ext,
+ MI.getOperand(3).getReg());
+ }
+ MIRBuilder.buildICmp(
+ {MI.getType(0), WideTy},
+ static_cast<CmpInst::Predicate>(MI.getOperand(1).getPredicate()),
+ MI.getOperand(0).getReg(), Op0Ext, Op1Ext);
+ MI.eraseFromParent();
+ return Legalized;
+ }
+ }
}
}
OpenPOWER on IntegriCloud