mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-12 13:38:21 +00:00
[ADT] Implement the 'logb' functionality for APFloat. This is necessary
to implement complex division in the constant folder of Clang. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@219471 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -2691,4 +2691,55 @@ TEST(APFloatTest, operatorOverloads) {
|
||||
EXPECT_TRUE(Two.bitwiseIsEqual(One * Two));
|
||||
EXPECT_TRUE(One.bitwiseIsEqual(Two / Two));
|
||||
}
|
||||
|
||||
TEST(APFloatTest, logb) {
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "0x0p+0")
|
||||
.bitwiseIsEqual(logb(APFloat(APFloat::IEEEsingle, "0x1p+0"))));
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "0x0p+0")
|
||||
.bitwiseIsEqual(logb(APFloat(APFloat::IEEEsingle, "-0x1p+0"))));
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "0x2Ap+0")
|
||||
.bitwiseIsEqual(logb(APFloat(APFloat::IEEEsingle, "0x1p+42"))));
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "-0x2Ap+0")
|
||||
.bitwiseIsEqual(logb(APFloat(APFloat::IEEEsingle, "0x1p-42"))));
|
||||
|
||||
APFloat PInf = APFloat::getInf(APFloat::IEEEsingle, false);
|
||||
APFloat MInf = APFloat::getInf(APFloat::IEEEsingle, true);
|
||||
APFloat PZero = APFloat::getZero(APFloat::IEEEsingle, false);
|
||||
APFloat MZero = APFloat::getZero(APFloat::IEEEsingle, true);
|
||||
APFloat QNaN = APFloat::getNaN(APFloat::IEEEsingle, false);
|
||||
APFloat SNaN = APFloat::getSNaN(APFloat::IEEEsingle, false);
|
||||
|
||||
EXPECT_TRUE(PInf.bitwiseIsEqual(logb(PInf)));
|
||||
EXPECT_TRUE(PInf.bitwiseIsEqual(logb(MInf)));
|
||||
EXPECT_TRUE(PZero.bitwiseIsEqual(logb(PZero)));
|
||||
EXPECT_TRUE(MZero.bitwiseIsEqual(logb(MZero)));
|
||||
EXPECT_TRUE(QNaN.bitwiseIsEqual(logb(QNaN)));
|
||||
EXPECT_TRUE(SNaN.bitwiseIsEqual(logb(SNaN)));
|
||||
|
||||
APFloat PLargestValue = APFloat::getLargest(APFloat::IEEEsingle, false);
|
||||
APFloat MLargestValue = APFloat::getLargest(APFloat::IEEEsingle, true);
|
||||
APFloat PSmallestValue = APFloat::getSmallest(APFloat::IEEEsingle, false);
|
||||
APFloat MSmallestValue = APFloat::getSmallest(APFloat::IEEEsingle, true);
|
||||
APFloat PSmallestNormalized =
|
||||
APFloat::getSmallestNormalized(APFloat::IEEEsingle, false);
|
||||
APFloat MSmallestNormalized =
|
||||
APFloat::getSmallestNormalized(APFloat::IEEEsingle, true);
|
||||
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "0x7Fp+0").bitwiseIsEqual(logb(PLargestValue)));
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "0x7Fp+0").bitwiseIsEqual(logb(MLargestValue)));
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "-0x7Ep+0").bitwiseIsEqual(logb(PSmallestValue)));
|
||||
EXPECT_TRUE(
|
||||
APFloat(APFloat::IEEEsingle, "-0x7Ep+0").bitwiseIsEqual(logb(MSmallestValue)));
|
||||
EXPECT_TRUE(APFloat(APFloat::IEEEsingle, "-0x7Ep+0")
|
||||
.bitwiseIsEqual(logb(PSmallestNormalized)));
|
||||
EXPECT_TRUE(APFloat(APFloat::IEEEsingle, "-0x7Ep+0")
|
||||
.bitwiseIsEqual(logb(MSmallestNormalized)));
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user