diff options
| author | Petar Avramovic <Petar.Avramovic@rt-rk.com> | 2019-02-26 17:22:42 +0000 |
|---|---|---|
| committer | Petar Avramovic <Petar.Avramovic@rt-rk.com> | 2019-02-26 17:22:42 +0000 |
| commit | bd395699133260d171690fb15f5bd9a39952ecee (patch) | |
| tree | fd8eb20091306aac9bab3d414845106e86f2c146 /llvm/lib | |
| parent | 4f171d2761753a7664ddcc27cdd53770c6e59d7c (diff) | |
| download | bcm5719-llvm-bd395699133260d171690fb15f5bd9a39952ecee.tar.gz bcm5719-llvm-bd395699133260d171690fb15f5bd9a39952ecee.zip | |
[MIPS GlobalISel] Select G_UADDO
Lower G_UADDO.
Legalize G_UADDO for MIPS32
Differential Revision: https://reviews.llvm.org/D58671
llvm-svn: 354900
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/GlobalISel/LegalizerHelper.cpp | 12 | ||||
| -rw-r--r-- | llvm/lib/Target/Mips/MipsLegalizerInfo.cpp | 2 |
2 files changed, 13 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/GlobalISel/LegalizerHelper.cpp b/llvm/lib/CodeGen/GlobalISel/LegalizerHelper.cpp index 7abce5a3fa8..67f90cd2ab3 100644 --- a/llvm/lib/CodeGen/GlobalISel/LegalizerHelper.cpp +++ b/llvm/lib/CodeGen/GlobalISel/LegalizerHelper.cpp @@ -1545,6 +1545,18 @@ LegalizerHelper::lower(MachineInstr &MI, unsigned TypeIdx, LLT Ty) { case TargetOpcode::G_CTTZ: case TargetOpcode::G_CTPOP: return lowerBitCount(MI, TypeIdx, Ty); + case G_UADDO: { + unsigned Res = MI.getOperand(0).getReg(); + unsigned CarryOut = MI.getOperand(1).getReg(); + unsigned LHS = MI.getOperand(2).getReg(); + unsigned RHS = MI.getOperand(3).getReg(); + + MIRBuilder.buildAdd(Res, LHS, RHS); + MIRBuilder.buildICmp(CmpInst::ICMP_ULT, CarryOut, Res, RHS); + + MI.eraseFromParent(); + return Legalized; + } case G_UADDE: { unsigned Res = MI.getOperand(0).getReg(); unsigned CarryOut = MI.getOperand(1).getReg(); diff --git a/llvm/lib/Target/Mips/MipsLegalizerInfo.cpp b/llvm/lib/Target/Mips/MipsLegalizerInfo.cpp index 4fddabcedfe..dd87d01777e 100644 --- a/llvm/lib/Target/Mips/MipsLegalizerInfo.cpp +++ b/llvm/lib/Target/Mips/MipsLegalizerInfo.cpp @@ -32,7 +32,7 @@ MipsLegalizerInfo::MipsLegalizerInfo(const MipsSubtarget &ST) { .legalFor({s32}) .minScalar(0, s32); - getActionDefinitionsBuilder({G_UADDE, G_USUBO, G_USUBE}) + getActionDefinitionsBuilder({G_UADDO, G_UADDE, G_USUBO, G_USUBE}) .lowerFor({{s32, s1}}); getActionDefinitionsBuilder({G_LOAD, G_STORE}) |

