diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2007-02-27 01:28:10 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2007-02-27 01:28:10 +0000 |
commit | 30f44f3287e13213b439b8924df037190c9cc363 (patch) | |
tree | f6d06e1abc00d1c58fe4a480740b2d4581b63753 /lib/Support/APInt.cpp | |
parent | 532d0ce208809545dc46d2de70c0384c036470d1 (diff) |
Simplify and document RoundDoubleToAPInt.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34648 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Support/APInt.cpp')
-rw-r--r-- | lib/Support/APInt.cpp | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/lib/Support/APInt.cpp b/lib/Support/APInt.cpp index 31327cb6c4..965182f5ec 100644 --- a/lib/Support/APInt.cpp +++ b/lib/Support/APInt.cpp @@ -803,15 +803,27 @@ APInt llvm::APIntOps::RoundDoubleToAPInt(double Double) { uint64_t I; } T; T.D = Double; + + // Get the sign bit from the highest order bit bool isNeg = T.I >> 63; + + // Get the 11-bit exponent and adjust for the 1023 bit bias int64_t exp = ((T.I >> 52) & 0x7ff) - 1023; + + // If the exponent is negative, the value is < 0 so just return 0. if (exp < 0) - return APInt(64ull, 0u); - uint64_t mantissa = ((T.I << 12) >> 12) | (1ULL << 52); + return APInt(64u, 0u); + + // Extract the mantissa by clearing the top 12 bits (sign + exponent). + uint64_t mantissa = (T.I & (~0ULL >> 12)) | 1ULL << 52; + + // If the exponent doesn't shift all bits out of the mantissa if (exp < 52) return isNeg ? -APInt(64u, mantissa >> (52 - exp)) : APInt(64u, mantissa >> (52 - exp)); - APInt Tmp(exp + 1, mantissa); + + // Otherwise, we have to shift the mantissa bits up to the right location + APInt Tmp(exp+1, mantissa); Tmp = Tmp.shl(exp - 52); return isNeg ? -Tmp : Tmp; } |