feat(big): add InsertLowPart

This commit is contained in:
fallenoak 2023-02-01 22:12:20 -06:00
parent 5d875631a6
commit 2b8cc51ad8
No known key found for this signature in database
GPG key ID: 7628F8E61AEA070D
3 changed files with 32 additions and 0 deletions

View file

@ -95,6 +95,10 @@ uint32_t HighBitPos(const BigBuffer& buffer) {
return 0; return 0;
} }
void InsertLowPart(uint64_t& value, uint32_t low) {
value = (value << 32) | low;
}
uint64_t MakeLarge(uint32_t low, uint32_t high) { uint64_t MakeLarge(uint32_t low, uint32_t high) {
return low + (static_cast<uint64_t>(high) << 32); return low + (static_cast<uint64_t>(high) << 32);
} }

View file

@ -21,6 +21,8 @@ void FromUnsigned(BigBuffer& buffer, uint32_t value);
uint32_t HighBitPos(const BigBuffer& a); uint32_t HighBitPos(const BigBuffer& a);
void InsertLowPart(uint64_t& value, uint32_t low);
uint64_t MakeLarge(uint32_t low, uint32_t high); uint64_t MakeLarge(uint32_t low, uint32_t high);
void Mul(BigBuffer& a, const BigBuffer& b, uint64_t c); void Mul(BigBuffer& a, const BigBuffer& b, uint64_t c);

View file

@ -263,6 +263,32 @@ TEST_CASE("HighBitPos", "[big]") {
} }
} }
TEST_CASE("InsertLowPart", "[big]") {
SECTION("inserts low part 0xABCD1111 into value 0") {
uint64_t value = 0;
uint32_t low = 0xABCD1111;
InsertLowPart(value, low);
CHECK(value == 0xABCD1111);
}
SECTION("inserts low part 0xABCD1111 into value 0xCCCCCCCC") {
uint64_t value = 0xCCCCCCCC;
uint32_t low = 0xABCD1111;
InsertLowPart(value, low);
CHECK(value == 0xCCCCCCCCABCD1111);
}
SECTION("inserts low part 0x12345678 into value 0xA0B1C2D3E4F5A6B7") {
uint64_t value = 0xA0B1C2D3E4F5A6B7;
uint32_t low = 0x12345678;
InsertLowPart(value, low);
CHECK(value == 0xE4F5A6B712345678);
}
}
TEST_CASE("Mul", "[big]") { TEST_CASE("Mul", "[big]") {
SECTION("multiplies 0 and 1") { SECTION("multiplies 0 and 1") {
BigData* a; BigData* a;