diff --git a/IGC/AdaptorCommon/FastMathConstantHandling.cpp b/IGC/AdaptorCommon/FastMathConstantHandling.cpp index 485b8844dec5..ae7ac9a1669d 100644 --- a/IGC/AdaptorCommon/FastMathConstantHandling.cpp +++ b/IGC/AdaptorCommon/FastMathConstantHandling.cpp @@ -27,6 +27,9 @@ class FastMathConstantHandling : public FunctionPass, public InstVisitor= 10 + void visitFNeg(Instruction& I); +#endif virtual llvm::StringRef getPassName() const override { return "Fast Math Constant Handling"; } void getAnalysisUsage(AnalysisUsage& AU) const override @@ -61,7 +64,7 @@ void FastMathConstantHandling::visitInstruction(Instruction& I) bool hasInf = false; bool hasNan = false; bool hasNegZero = false; - } BSC; + }BSC; for (auto &Op : I.operands()) { @@ -84,6 +87,20 @@ void FastMathConstantHandling::visitInstruction(Instruction& I) I.setHasNoSignedZeros(false); } } +#if LLVM_VERSION_MAJOR >= 10 +void FastMathConstantHandling::visitFNeg(Instruction& I) +{ + auto* fp_val = dyn_cast(I.getOperand(0)); + if (fp_val && fp_val->getValueAPF().isZero()) + { + for (auto* UI : I.users()) + { + if (isa(UI)) + cast(UI)->setHasNoSignedZeros(false); + } + } +} +#endif bool FastMathConstantHandling::runOnFunction(Function& F) {