Have the bitcode reader/writer just use FPMathOperator's fast math enum directly
authorMichael Ilseman <milseman@apple.com>
Sun, 9 Dec 2012 20:23:16 +0000 (20:23 +0000)
committerMichael Ilseman <milseman@apple.com>
Sun, 9 Dec 2012 20:23:16 +0000 (20:23 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@169710 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Bitcode/LLVMBitCodes.h
lib/Bitcode/Reader/BitcodeReader.cpp
lib/Bitcode/Writer/BitcodeWriter.cpp

index ad8c40217a73a8ac29c1cb13fd3c52215bb8dee0..601777d11a8d62f8927da3860643a042f25ca742 100644 (file)
@@ -242,16 +242,6 @@ namespace bitc {
     PEO_EXACT = 0
   };
 
-  /// Flags for serializing FPMathOperator's
-  /// SubclassOptionalData contents.
-  enum FastMathFlags {
-    FMF_UNSAFE_ALGEBRA   = 0,
-    FMF_NO_NANS          = 1,
-    FMF_NO_INFS          = 2,
-    FMF_NO_SIGNED_ZEROS  = 3,
-    FMF_ALLOW_RECIPROCAL = 4
-  };
-
   /// Encoded AtomicOrdering values.
   enum AtomicOrderingCodes {
     ORDERING_NOTATOMIC = 0,
index cb1a83518582d90ea971a1c432ac068ea7061622..131151f5354c6025d2f35708370e6e0d82b263e2 100644 (file)
@@ -2048,15 +2048,15 @@ bool BitcodeReader::ParseFunctionBody(Function *F) {
         } else if (isa<FPMathOperator>(I)) {
           FastMathFlags FMF;
           FMF.UnsafeAlgebra =
-            0 != (Record[OpNum] & (1 << bitc::FMF_UNSAFE_ALGEBRA));
+            0 != (Record[OpNum] & FPMathOperator::UnsafeAlgebra);
           FMF.NoNaNs =
-            0 != (Record[OpNum] & (1 << bitc::FMF_NO_NANS));
+            0 != (Record[OpNum] & FPMathOperator::NoNaNs);
           FMF.NoInfs =
-            0 != (Record[OpNum] & (1 << bitc::FMF_NO_INFS));
+            0 != (Record[OpNum] & FPMathOperator::NoInfs);
           FMF.NoSignedZeros =
-            0 != (Record[OpNum] & (1 << bitc::FMF_NO_SIGNED_ZEROS));
+            0 != (Record[OpNum] & FPMathOperator::NoSignedZeros);
           FMF.AllowReciprocal =
-            0 != (Record[OpNum] & (1 << bitc::FMF_ALLOW_RECIPROCAL));
+            0 != (Record[OpNum] & FPMathOperator::AllowReciprocal);
           if (FMF.any())
             I->setFastMathFlags(FMF);
         }
index d616eda9b9922460c9ce4160c8fb892ebfce65c8..f2fe0aef68f564e51121938ecc973939c3db09fe 100644 (file)
@@ -552,15 +552,15 @@ static uint64_t GetOptimizationFlags(const Value *V) {
   } else if (const FPMathOperator *FPMO =
              dyn_cast<const FPMathOperator>(V)) {
     if (FPMO->hasUnsafeAlgebra())
-      Flags |= 1 << bitc::FMF_UNSAFE_ALGEBRA;
+      Flags |= FPMathOperator::UnsafeAlgebra;
     if (FPMO->hasNoNaNs())
-      Flags |= 1 << bitc::FMF_NO_NANS;
+      Flags |= FPMathOperator::NoNaNs;
     if (FPMO->hasNoInfs())
-      Flags |= 1 << bitc::FMF_NO_INFS;
+      Flags |= FPMathOperator::NoInfs;
     if (FPMO->hasNoSignedZeros())
-      Flags |= 1 << bitc::FMF_NO_SIGNED_ZEROS;
+      Flags |= FPMathOperator::NoSignedZeros;
     if (FPMO->hasAllowReciprocal())
-      Flags |= 1 << bitc::FMF_ALLOW_RECIPROCAL;
+      Flags |= FPMathOperator::AllowReciprocal;
   }
 
   return Flags;