From 9c51fbc36e0f89eb8f963a5acab9ac2eb91d70e8 Mon Sep 17 00:00:00 2001 From: peter klausler Date: Thu, 31 May 2018 16:32:36 -0700 Subject: [PATCH] [flang] More tests Original-commit: flang-compiler/f18@e4371fca37a16c5dd9eea5a846248ce19c9cdb6b Reviewed-on: https://github.com/flang-compiler/f18/pull/101 Tree-same-pre-rewrite: false --- flang/lib/evaluate/bit-population-count.h | 3 +- flang/lib/evaluate/fixed-point.h | 10 +++---- flang/test/evaluate/fixed-point-test.cc | 34 +++++++++++++++++++---- 3 files changed, 35 insertions(+), 12 deletions(-) diff --git a/flang/lib/evaluate/bit-population-count.h b/flang/lib/evaluate/bit-population-count.h index 8e63ad4aea46..081a9b058c84 100644 --- a/flang/lib/evaluate/bit-population-count.h +++ b/flang/lib/evaluate/bit-population-count.h @@ -76,8 +76,7 @@ inline constexpr int BitPopulationCount(std::uint8_t x) { return (x & 0xf) + (x >> 4); } -template -inline constexpr bool Parity(UINT x) { +template inline constexpr bool Parity(UINT x) { return BitPopulationCount(x) & 1; } diff --git a/flang/lib/evaluate/fixed-point.h b/flang/lib/evaluate/fixed-point.h index d5e9559cfd28..e49076242922 100644 --- a/flang/lib/evaluate/fixed-point.h +++ b/flang/lib/evaluate/fixed-point.h @@ -21,8 +21,8 @@ // are distinguished from each other with distinct member function interfaces. // ("Signed" here means two's-complement, just to be clear.) -#include "leading-zero-bit-count.h" #include "bit-population-count.h" +#include "leading-zero-bit-count.h" #include #include #include @@ -139,7 +139,7 @@ public: } } - static constexpr FixedPoint HUGE() { return MASKR(bits-1); } + static constexpr FixedPoint HUGE() { return MASKR(bits - 1); } // Returns the number of full decimal digits that can be represented. static constexpr int RANGE() { @@ -216,7 +216,7 @@ public: return bits; // was zero } else { // x ^ (x-1) has all bits set at and below original least-order set bit. - return POPCNT(IEOR(minus1.value)) - 1; + return IEOR(minus1.value).POPCNT() - 1; } } @@ -512,8 +512,8 @@ public: return result; } - constexpr FixedPoint MERGE_BITS(const FixedPoint &y, - const FixedPoint &mask) const { + constexpr FixedPoint MERGE_BITS( + const FixedPoint &y, const FixedPoint &mask) const { return IAND(mask).IOR(y.IAND(mask.NOT())); } diff --git a/flang/test/evaluate/fixed-point-test.cc b/flang/test/evaluate/fixed-point-test.cc index 3436b1936b15..c71057309f61 100644 --- a/flang/test/evaluate/fixed-point-test.cc +++ b/flang/test/evaluate/fixed-point-test.cc @@ -20,7 +20,6 @@ using Fortran::evaluate::FixedPoint; using Fortran::evaluate::Ordering; template> void exhaustiveTesting() { - COMPARE(BITS, ==, FP::bits); std::uint64_t maxUnsignedValue{(std::uint64_t{1} << BITS) - 1}; std::int64_t maxPositiveSignedValue{(std::int64_t{1} << (BITS - 1)) - 1}; std::int64_t mostNegativeSignedValue{-(std::int64_t{1} << (BITS - 1))}; @@ -28,8 +27,14 @@ template> void exhaustiveTesting() { std::snprintf(desc, sizeof desc, "BITS=%d, PARTBITS=%d, sizeof(Part)=%d, LE=%d", BITS, FP::partBits, static_cast(sizeof(typename FP::Part)), FP::littleEndian); + + MATCH(BITS, FP::bits)(desc); + MATCH(maxPositiveSignedValue, FP::HUGE().ToUInt64())(desc); FP zero; TEST(zero.IsZero())(desc); + MATCH(0, zero.ToUInt64())(desc); + MATCH(0, zero.ToInt64())(desc); + for (std::uint64_t x{0}; x <= maxUnsignedValue; ++x) { FP a{x}; MATCH(x, a.ToUInt64())(desc); @@ -43,7 +48,12 @@ template> void exhaustiveTesting() { auto negated{a.Negate()}; MATCH(x == std::uint64_t{1} << (BITS - 1), negated.overflow) ("%s, x=0x%llx", desc, x); - MATCH(negated.value.ToUInt64(), -x & maxUnsignedValue) + MATCH(-x & maxUnsignedValue, negated.value.ToUInt64()) + ("%s, x=0x%llx", desc, x); + auto abs{a.ABS()}; + MATCH(x == std::uint64_t{1} << (BITS - 1), abs.overflow) + ("%s, x=0x%llx", desc, x); + MATCH(x >> (BITS-1) ? -x & maxUnsignedValue : x, abs.value.ToUInt64()) ("%s, x=0x%llx", desc, x); int lzbc{a.LEADZ()}; COMPARE(lzbc, >=, 0)("%s, x=0x%llx", desc, x); @@ -58,6 +68,16 @@ template> void exhaustiveTesting() { } MATCH(popcheck, a.POPCNT())("%s, x=0x%llx", desc, x); MATCH(popcheck & 1, a.POPPAR())("%s, x=0x%llx", desc, x); + int trailcheck{0}; + for (; trailcheck < BITS; ++trailcheck) { + if ((x >> trailcheck) & 1) { + break; + } + } + MATCH(trailcheck, a.TRAILZ())("%s, x=0x%llx", desc, x); + // TODO test BTEST, DIM, MODULO, ISHFTC, DSHIFTL/R + // TODO test IBCLR, IBSET, IBITS, MAX, MIN, MERGE_BITS, RANGE, SIGN + Ordering ord{Ordering::Equal}; std::int64_t sx = x; if (x + x > maxUnsignedValue) { @@ -74,6 +94,7 @@ template> void exhaustiveTesting() { ord = Ordering::Equal; } } + TEST(sx == a.ToInt64())("%s, x=0x%llx %lld", desc, x, sx); TEST(a.CompareToZeroSigned() == ord)("%s, x=0x%llx %lld", desc, x, sx); for (int count{0}; count <= BITS + 1; ++count) { @@ -94,6 +115,7 @@ template> void exhaustiveTesting() { MATCH(sra, t.ToInt64()) ("%s, x=0x%llx, count=%d", desc, x, count); } + for (std::uint64_t y{0}; y <= maxUnsignedValue; ++y) { std::int64_t sy = y; if (y + y > maxUnsignedValue) { @@ -108,6 +130,10 @@ template> void exhaustiveTesting() { ord = Ordering::Equal; } TEST(a.CompareUnsigned(b) == ord)("%s, x=0x%llx, y=0x%llx", desc, x, y); + MATCH(x >= y, a.BGE(b))("%s, x=0x%llx, y=0x%llx", desc, x, y); + MATCH(x > y, a.BGT(b))("%s, x=0x%llx, y=0x%llx", desc, x, y); + MATCH(x <= y, a.BLE(b))("%s, x=0x%llx, y=0x%llx", desc, x, y); + MATCH(x < y, a.BLT(b))("%s, x=0x%llx, y=0x%llx", desc, x, y); if (sx < sy) { ord = Ordering::Less; } else if (sx > sy) { @@ -118,6 +144,7 @@ template> void exhaustiveTesting() { TEST(a.CompareSigned(b) == ord) ("%s, x=0x%llx %lld %d, y=0x%llx %lld %d", desc, x, sx, a.IsNegative(), y, sy, b.IsNegative()); + t = a.IAND(b); MATCH(x & y, t.ToUInt64())("%s, x=0x%llx, y=0x%llx", desc, x, y); t = a.IOR(b); @@ -186,9 +213,6 @@ template> void exhaustiveTesting() { MATCH(sx - sy * (sx / sy), quot.remainder.ToInt64()) ("%s, x=0x%llx, y=0x%llx", desc, x, y); } - // TODO test ABS, B[GL][ET], BTEST, DIM, HUGE, MODULO, ISHFTC, DSHIFTL/R - // TODO test IBCLR, IBSET, IBITS, MAX, MIN, MERGE_BITS, RANGE, SIGN - // TODO test TRAILZ } } }