Lines Matching refs:Ops

712   Value *EmitMul(const BinOpInfo &Ops) {  in EmitMul()  argument
713 if (Ops.Ty->isSignedIntegerOrEnumerationType()) { in EmitMul()
716 return Builder.CreateMul(Ops.LHS, Ops.RHS, "mul"); in EmitMul()
719 return Builder.CreateNSWMul(Ops.LHS, Ops.RHS, "mul"); in EmitMul()
722 if (CanElideOverflowCheck(CGF.getContext(), Ops)) in EmitMul()
723 return Builder.CreateNSWMul(Ops.LHS, Ops.RHS, "mul"); in EmitMul()
724 return EmitOverflowCheckedBinOp(Ops); in EmitMul()
728 if (Ops.Ty->isConstantMatrixType()) { in EmitMul()
732 auto *BO = cast<BinaryOperator>(Ops.E); in EmitMul()
737 CodeGenFunction::CGFPOptionsRAII FPOptsRAII(CGF, Ops.FPFeatures); in EmitMul()
739 return MB.CreateMatrixMultiply(Ops.LHS, Ops.RHS, LHSMatTy->getNumRows(), in EmitMul()
742 return MB.CreateScalarMultiply(Ops.LHS, Ops.RHS); in EmitMul()
745 if (Ops.Ty->isUnsignedIntegerType() && in EmitMul()
747 !CanElideOverflowCheck(CGF.getContext(), Ops)) in EmitMul()
748 return EmitOverflowCheckedBinOp(Ops); in EmitMul()
750 if (Ops.LHS->getType()->isFPOrFPVectorTy()) { in EmitMul()
752 CodeGenFunction::CGFPOptionsRAII FPOptsRAII(CGF, Ops.FPFeatures); in EmitMul()
753 return Builder.CreateFMul(Ops.LHS, Ops.RHS, "mul"); in EmitMul()
755 if (Ops.isFixedPointOp()) in EmitMul()
756 return EmitFixedPointBinOp(Ops); in EmitMul()
757 return Builder.CreateMul(Ops.LHS, Ops.RHS, "mul"); in EmitMul()
761 Value *EmitOverflowCheckedBinOp(const BinOpInfo &Ops);
764 void EmitUndefinedBehaviorIntegerDivAndRemCheck(const BinOpInfo &Ops,
773 Value *EmitDiv(const BinOpInfo &Ops);
774 Value *EmitRem(const BinOpInfo &Ops);
775 Value *EmitAdd(const BinOpInfo &Ops);
776 Value *EmitSub(const BinOpInfo &Ops);
777 Value *EmitShl(const BinOpInfo &Ops);
778 Value *EmitShr(const BinOpInfo &Ops);
779 Value *EmitAnd(const BinOpInfo &Ops) { in EmitAnd() argument
780 return Builder.CreateAnd(Ops.LHS, Ops.RHS, "and"); in EmitAnd()
782 Value *EmitXor(const BinOpInfo &Ops) { in EmitXor() argument
783 return Builder.CreateXor(Ops.LHS, Ops.RHS, "xor"); in EmitXor()
785 Value *EmitOr (const BinOpInfo &Ops) { in EmitOr() argument
786 return Builder.CreateOr(Ops.LHS, Ops.RHS, "or"); in EmitOr()
790 Value *EmitFixedPointBinOp(const BinOpInfo &Ops);
3156 const BinOpInfo &Ops, llvm::Value *Zero, bool isDiv) { in EmitUndefinedBehaviorIntegerDivAndRemCheck() argument
3160 Checks.push_back(std::make_pair(Builder.CreateICmpNE(Ops.RHS, Zero), in EmitUndefinedBehaviorIntegerDivAndRemCheck()
3164 const auto *BO = cast<BinaryOperator>(Ops.E); in EmitUndefinedBehaviorIntegerDivAndRemCheck()
3166 Ops.Ty->hasSignedIntegerRepresentation() && in EmitUndefinedBehaviorIntegerDivAndRemCheck()
3168 Ops.mayHaveIntegerOverflow()) { in EmitUndefinedBehaviorIntegerDivAndRemCheck()
3175 llvm::Value *LHSCmp = Builder.CreateICmpNE(Ops.LHS, IntMin); in EmitUndefinedBehaviorIntegerDivAndRemCheck()
3176 llvm::Value *RHSCmp = Builder.CreateICmpNE(Ops.RHS, NegOne); in EmitUndefinedBehaviorIntegerDivAndRemCheck()
3183 EmitBinOpCheck(Checks, Ops); in EmitUndefinedBehaviorIntegerDivAndRemCheck()
3186 Value *ScalarExprEmitter::EmitDiv(const BinOpInfo &Ops) { in EmitDiv() argument
3191 Ops.Ty->isIntegerType() && in EmitDiv()
3192 (Ops.mayHaveIntegerDivisionByZero() || Ops.mayHaveIntegerOverflow())) { in EmitDiv()
3193 llvm::Value *Zero = llvm::Constant::getNullValue(ConvertType(Ops.Ty)); in EmitDiv()
3194 EmitUndefinedBehaviorIntegerDivAndRemCheck(Ops, Zero, true); in EmitDiv()
3196 Ops.Ty->isRealFloatingType() && in EmitDiv()
3197 Ops.mayHaveFloatDivisionByZero()) { in EmitDiv()
3198 llvm::Value *Zero = llvm::Constant::getNullValue(ConvertType(Ops.Ty)); in EmitDiv()
3199 llvm::Value *NonZero = Builder.CreateFCmpUNE(Ops.RHS, Zero); in EmitDiv()
3201 Ops); in EmitDiv()
3205 if (Ops.Ty->isConstantMatrixType()) { in EmitDiv()
3209 auto *BO = cast<BinaryOperator>(Ops.E); in EmitDiv()
3216 CodeGenFunction::CGFPOptionsRAII FPOptsRAII(CGF, Ops.FPFeatures); in EmitDiv()
3217 return MB.CreateScalarDiv(Ops.LHS, Ops.RHS, in EmitDiv()
3218 Ops.Ty->hasUnsignedIntegerRepresentation()); in EmitDiv()
3221 if (Ops.LHS->getType()->isFPOrFPVectorTy()) { in EmitDiv()
3223 CodeGenFunction::CGFPOptionsRAII FPOptsRAII(CGF, Ops.FPFeatures); in EmitDiv()
3224 Val = Builder.CreateFDiv(Ops.LHS, Ops.RHS, "div"); in EmitDiv()
3242 else if (Ops.isFixedPointOp()) in EmitDiv()
3243 return EmitFixedPointBinOp(Ops); in EmitDiv()
3244 else if (Ops.Ty->hasUnsignedIntegerRepresentation()) in EmitDiv()
3245 return Builder.CreateUDiv(Ops.LHS, Ops.RHS, "div"); in EmitDiv()
3247 return Builder.CreateSDiv(Ops.LHS, Ops.RHS, "div"); in EmitDiv()
3250 Value *ScalarExprEmitter::EmitRem(const BinOpInfo &Ops) { in EmitRem() argument
3254 Ops.Ty->isIntegerType() && in EmitRem()
3255 (Ops.mayHaveIntegerDivisionByZero() || Ops.mayHaveIntegerOverflow())) { in EmitRem()
3257 llvm::Value *Zero = llvm::Constant::getNullValue(ConvertType(Ops.Ty)); in EmitRem()
3258 EmitUndefinedBehaviorIntegerDivAndRemCheck(Ops, Zero, false); in EmitRem()
3261 if (Ops.Ty->hasUnsignedIntegerRepresentation()) in EmitRem()
3262 return Builder.CreateURem(Ops.LHS, Ops.RHS, "rem"); in EmitRem()
3264 return Builder.CreateSRem(Ops.LHS, Ops.RHS, "rem"); in EmitRem()
3267 Value *ScalarExprEmitter::EmitOverflowCheckedBinOp(const BinOpInfo &Ops) { in EmitOverflowCheckedBinOp() argument
3272 bool isSigned = Ops.Ty->isSignedIntegerOrEnumerationType(); in EmitOverflowCheckedBinOp()
3273 switch (Ops.Opcode) { in EmitOverflowCheckedBinOp()
3303 llvm::Type *opTy = CGF.CGM.getTypes().ConvertType(Ops.Ty); in EmitOverflowCheckedBinOp()
3307 Value *resultAndOverflow = Builder.CreateCall(intrinsic, {Ops.LHS, Ops.RHS}); in EmitOverflowCheckedBinOp()
3321 EmitBinOpCheck(std::make_pair(NotOverflow, Kind), Ops); in EmitOverflowCheckedBinOp()
3349 llvm::Value *lhs = Builder.CreateSExt(Ops.LHS, CGF.Int64Ty); in EmitOverflowCheckedBinOp()
3350 llvm::Value *rhs = Builder.CreateSExt(Ops.RHS, CGF.Int64Ty); in EmitOverflowCheckedBinOp()
3855 Value *ScalarExprEmitter::EmitShl(const BinOpInfo &Ops) { in EmitShl() argument
3857 if (Ops.isFixedPointOp()) in EmitShl()
3858 return EmitFixedPointBinOp(Ops); in EmitShl()
3862 Value *RHS = Ops.RHS; in EmitShl()
3863 if (Ops.LHS->getType() != RHS->getType()) in EmitShl()
3864 RHS = Builder.CreateIntCast(RHS, Ops.LHS->getType(), false, "sh_prom"); in EmitShl()
3867 Ops.Ty->hasSignedIntegerRepresentation() && in EmitShl()
3872 Ops.Ty->hasUnsignedIntegerRepresentation(); in EmitShl()
3877 RHS = ConstrainShiftValue(Ops.LHS, RHS, "shl.mask"); in EmitShl()
3879 isa<llvm::IntegerType>(Ops.LHS->getType())) { in EmitShl()
3882 llvm::Value *WidthMinusOne = GetWidthMinusOneValue(Ops.LHS, Ops.RHS); in EmitShl()
3883 llvm::Value *ValidExponent = Builder.CreateICmpULE(Ops.RHS, WidthMinusOne); in EmitShl()
3899 (RHS == Ops.RHS) ? WidthMinusOne in EmitShl()
3900 : GetWidthMinusOneValue(Ops.LHS, RHS); in EmitShl()
3903 Ops.LHS, Builder.CreateSub(PromotedWidthMinusOne, RHS, "shl.zeros", in EmitShl()
3927 EmitBinOpCheck(Checks, Ops); in EmitShl()
3930 return Builder.CreateShl(Ops.LHS, RHS, "shl"); in EmitShl()
3933 Value *ScalarExprEmitter::EmitShr(const BinOpInfo &Ops) { in EmitShr() argument
3935 if (Ops.isFixedPointOp()) in EmitShr()
3936 return EmitFixedPointBinOp(Ops); in EmitShr()
3940 Value *RHS = Ops.RHS; in EmitShr()
3941 if (Ops.LHS->getType() != RHS->getType()) in EmitShr()
3942 RHS = Builder.CreateIntCast(RHS, Ops.LHS->getType(), false, "sh_prom"); in EmitShr()
3946 RHS = ConstrainShiftValue(Ops.LHS, RHS, "shr.mask"); in EmitShr()
3948 isa<llvm::IntegerType>(Ops.LHS->getType())) { in EmitShr()
3951 Builder.CreateICmpULE(RHS, GetWidthMinusOneValue(Ops.LHS, RHS)); in EmitShr()
3952 EmitBinOpCheck(std::make_pair(Valid, SanitizerKind::ShiftExponent), Ops); in EmitShr()
3955 if (Ops.Ty->hasUnsignedIntegerRepresentation()) in EmitShr()
3956 return Builder.CreateLShr(Ops.LHS, RHS, "shr"); in EmitShr()
3957 return Builder.CreateAShr(Ops.LHS, RHS, "shr"); in EmitShr()