diff options
author | Ramkumar Ramachandra <ramkumar.ramachandra@codasip.com> | 2024-06-15 10:22:53 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-15 10:22:53 +0100 |
commit | bfd95a003139a8f930874b2234c3cab545d504a1 (patch) | |
tree | 79e08321585afcfe2968510ed940c35f3ce55a07 /llvm/unittests/Support/MathExtrasTest.cpp | |
parent | 23c1b488fee99ac598203b6c3972be3b404dfbbe (diff) | |
download | llvm-bfd95a003139a8f930874b2234c3cab545d504a1.zip llvm-bfd95a003139a8f930874b2234c3cab545d504a1.tar.gz llvm-bfd95a003139a8f930874b2234c3cab545d504a1.tar.bz2 |
MathExtras: rewrite some methods to never overflow (#95556)
Rewrite divideCeil, divideNearest, divideFloorSigned, and
divideCeilSigned to never overflow.
Diffstat (limited to 'llvm/unittests/Support/MathExtrasTest.cpp')
-rw-r--r-- | llvm/unittests/Support/MathExtrasTest.cpp | 38 |
1 files changed, 36 insertions, 2 deletions
diff --git a/llvm/unittests/Support/MathExtrasTest.cpp b/llvm/unittests/Support/MathExtrasTest.cpp index bcccb96..bd09bab 100644 --- a/llvm/unittests/Support/MathExtrasTest.cpp +++ b/llvm/unittests/Support/MathExtrasTest.cpp @@ -459,15 +459,37 @@ TEST(MathExtras, DivideNearest) { EXPECT_EQ(divideNearest(14, 3), 5u); EXPECT_EQ(divideNearest(15, 3), 5u); EXPECT_EQ(divideNearest(0, 3), 0u); + EXPECT_EQ(divideNearest(5, 4), 1u); + EXPECT_EQ(divideNearest(6, 4), 2u); + EXPECT_EQ(divideNearest(3, 1), 3u); + EXPECT_EQ(divideNearest(3, 6), 1u); + EXPECT_EQ(divideNearest(3, 7), 0u); EXPECT_EQ(divideNearest(std::numeric_limits<uint32_t>::max(), 2), - 2147483648u); + std::numeric_limits<uint32_t>::max() / 2 + 1); + EXPECT_EQ(divideNearest(std::numeric_limits<uint64_t>::max(), 2), + std::numeric_limits<uint64_t>::max() / 2 + 1); + EXPECT_EQ(divideNearest(std::numeric_limits<uint64_t>::max(), 1), + std::numeric_limits<uint64_t>::max()); + EXPECT_EQ(divideNearest(std::numeric_limits<uint64_t>::max() - 1, + std::numeric_limits<uint64_t>::max()), + 1u); } TEST(MathExtras, DivideCeil) { EXPECT_EQ(divideCeil(14, 3), 5u); EXPECT_EQ(divideCeil(15, 3), 5u); EXPECT_EQ(divideCeil(0, 3), 0u); - EXPECT_EQ(divideCeil(std::numeric_limits<uint32_t>::max(), 2), 2147483648u); + EXPECT_EQ(divideCeil(5, 4), 2u); + EXPECT_EQ(divideCeil(6, 4), 2u); + EXPECT_EQ(divideCeil(3, 1), 3u); + EXPECT_EQ(divideCeil(3, 6), 1u); + EXPECT_EQ(divideCeil(3, 7), 1u); + EXPECT_EQ(divideCeil(std::numeric_limits<uint32_t>::max(), 2), + std::numeric_limits<uint32_t>::max() / 2 + 1); + EXPECT_EQ(divideCeil(std::numeric_limits<uint64_t>::max(), 2), + std::numeric_limits<uint64_t>::max() / 2 + 1); + EXPECT_EQ(divideCeil(std::numeric_limits<uint64_t>::max(), 1), + std::numeric_limits<uint64_t>::max()); EXPECT_EQ(divideCeilSigned(14, 3), 5); EXPECT_EQ(divideCeilSigned(15, 3), 5); @@ -479,8 +501,14 @@ TEST(MathExtras, DivideCeil) { EXPECT_EQ(divideCeilSigned(0, -3), 0); EXPECT_EQ(divideCeilSigned(std::numeric_limits<int32_t>::max(), 2), std::numeric_limits<int32_t>::max() / 2 + 1); + EXPECT_EQ(divideCeilSigned(std::numeric_limits<int64_t>::max(), 2), + std::numeric_limits<int64_t>::max() / 2 + 1); EXPECT_EQ(divideCeilSigned(std::numeric_limits<int32_t>::max(), -2), std::numeric_limits<int32_t>::min() / 2 + 1); + EXPECT_EQ(divideCeilSigned(std::numeric_limits<int64_t>::max(), -2), + std::numeric_limits<int64_t>::min() / 2 + 1); + EXPECT_EQ(divideCeilSigned(std::numeric_limits<int64_t>::min(), 1), + std::numeric_limits<int64_t>::min()); } TEST(MathExtras, DivideFloorSigned) { @@ -494,8 +522,14 @@ TEST(MathExtras, DivideFloorSigned) { EXPECT_EQ(divideFloorSigned(0, -3), 0); EXPECT_EQ(divideFloorSigned(std::numeric_limits<int32_t>::max(), 2), std::numeric_limits<int32_t>::max() / 2); + EXPECT_EQ(divideFloorSigned(std::numeric_limits<int64_t>::max(), 2), + std::numeric_limits<int64_t>::max() / 2); EXPECT_EQ(divideFloorSigned(std::numeric_limits<int32_t>::max(), -2), std::numeric_limits<int32_t>::min() / 2); + EXPECT_EQ(divideFloorSigned(std::numeric_limits<int64_t>::max(), -2), + std::numeric_limits<int64_t>::min() / 2); + EXPECT_EQ(divideFloorSigned(std::numeric_limits<int64_t>::min(), 1), + std::numeric_limits<int64_t>::min()); } TEST(MathExtras, Mod) { |