aboutsummaryrefslogtreecommitdiff
path: root/lib/Bitcode/Reader/BitcodeReader.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Bitcode/Reader/BitcodeReader.cpp')
-rw-r--r--lib/Bitcode/Reader/BitcodeReader.cpp15
1 files changed, 15 insertions, 0 deletions
diff --git a/lib/Bitcode/Reader/BitcodeReader.cpp b/lib/Bitcode/Reader/BitcodeReader.cpp
index d3c8678578..f31637e044 100644
--- a/lib/Bitcode/Reader/BitcodeReader.cpp
+++ b/lib/Bitcode/Reader/BitcodeReader.cpp
@@ -2044,7 +2044,22 @@ bool BitcodeReader::ParseFunctionBody(Function *F) {
Opc == Instruction::AShr) {
if (Record[OpNum] & (1 << bitc::PEO_EXACT))
cast<BinaryOperator>(I)->setIsExact(true);
+ } else if (isa<FPMathOperator>(I)) {
+ FastMathFlags FMF;
+ FMF.UnsafeAlgebra =
+ 0 != (Record[OpNum] & (1 << bitc::FMF_UNSAFE_ALGEBRA));
+ FMF.NoNaNs
+ = 0 != (Record[OpNum] & (1 << bitc::FMF_NO_NANS));
+ FMF.NoInfs
+ = 0 != (Record[OpNum] & (1 << bitc::FMF_NO_INFS));
+ FMF.NoSignedZeros
+ = 0 != (Record[OpNum] & (1 << bitc::FMF_NO_SIGNED_ZEROS));
+ FMF.AllowReciprocal
+ = 0 != (Record[OpNum] & (1 << bitc::FMF_ALLOW_RECIPROCAL));
+ if (FMF.any())
+ I->setFastMathFlags(FMF);
}
+
}
break;
}