diff options
Diffstat (limited to 'llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp')
-rw-r--r-- | llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp | 29 |
1 files changed, 18 insertions, 11 deletions
diff --git a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp index 1a243c54887..36150c6c444 100644 --- a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp +++ b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp @@ -100,17 +100,24 @@ bool IRTranslator::translateBinaryOp(unsigned Opcode, const User &U) { return true; } -bool IRTranslator::translateICmp(const User &U) { - const CmpInst &CI = cast<CmpInst>(U); - unsigned Op0 = getOrCreateVReg(*CI.getOperand(0)); - unsigned Op1 = getOrCreateVReg(*CI.getOperand(1)); - unsigned Res = getOrCreateVReg(CI); - CmpInst::Predicate Pred = CI.getPredicate(); - - assert(isa<ICmpInst>(CI) && "only integer comparisons supported now"); - assert(CmpInst::isIntPredicate(Pred) && "only int comparisons supported now"); - MIRBuilder.buildICmp({LLT{*CI.getType()}, LLT{*CI.getOperand(0)->getType()}}, - Pred, Res, Op0, Op1); +bool IRTranslator::translateCompare(const User &U) { + const CmpInst *CI = dyn_cast<CmpInst>(&U); + unsigned Op0 = getOrCreateVReg(*U.getOperand(0)); + unsigned Op1 = getOrCreateVReg(*U.getOperand(1)); + unsigned Res = getOrCreateVReg(U); + CmpInst::Predicate Pred = + CI ? CI->getPredicate() : static_cast<CmpInst::Predicate>( + cast<ConstantExpr>(U).getPredicate()); + + if (CmpInst::isIntPredicate(Pred)) + MIRBuilder.buildICmp( + {LLT{*U.getType()}, LLT{*U.getOperand(0)->getType()}}, Pred, Res, Op0, + Op1); + else + MIRBuilder.buildFCmp( + {LLT{*U.getType()}, LLT{*U.getOperand(0)->getType()}}, Pred, Res, Op0, + Op1); + return true; } |