mirror of
https://github.com/thunderbrewhq/squall.git
synced 2025-12-12 10:32:29 +00:00
feat(big): add SBigSub
This commit is contained in:
parent
6e62f0a604
commit
5d875631a6
5 changed files with 146 additions and 0 deletions
|
|
@ -28,6 +28,10 @@ void SBigMul(BigData* a, BigData* b, BigData* c) {
|
|||
Mul(a->Primary(), b->Primary(), c->Primary(), a->Stack());
|
||||
}
|
||||
|
||||
void SBigSub(BigData* a, BigData* b, BigData* c) {
|
||||
Sub(a->Primary(), b->Primary(), c->Primary());
|
||||
}
|
||||
|
||||
void SBigToBinaryBuffer(BigData* num, uint8_t* data, uint32_t maxBytes, uint32_t* bytes) {
|
||||
auto& output = num->Output();
|
||||
ToBinary(output, num->Primary());
|
||||
|
|
|
|||
|
|
@ -16,6 +16,8 @@ void SBigMul(BigData* a, BigData* b, BigData* c);
|
|||
|
||||
void SBigNew(BigData** num);
|
||||
|
||||
void SBigSub(BigData* a, BigData* b, BigData* c);
|
||||
|
||||
void SBigToBinaryBuffer(BigData* num, uint8_t* data, uint32_t maxBytes, uint32_t* bytes);
|
||||
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -141,6 +141,19 @@ void SetZero(BigBuffer& buffer) {
|
|||
buffer.Clear();
|
||||
}
|
||||
|
||||
void Sub(BigBuffer& a, const BigBuffer& b, const BigBuffer& c) {
|
||||
uint64_t borrow = 0;
|
||||
uint32_t i = 0;
|
||||
for (i = 0; b.IsUsed(i) || c.IsUsed(i); i++) {
|
||||
borrow += b[i] - static_cast<uint64_t>(c[i]);
|
||||
a[i] = ExtractLowPartSx(borrow);
|
||||
}
|
||||
|
||||
a.SetCount(i);
|
||||
|
||||
STORM_ASSERT(!borrow);
|
||||
}
|
||||
|
||||
void ToBinaryAppend(TSGrowableArray<uint8_t>& output, const BigBuffer& buffer) {
|
||||
for (uint32_t i = 0; i < buffer.Count() * 4; i++) {
|
||||
auto byte = buffer[i / 4] >> (8 * (i & 3));
|
||||
|
|
|
|||
|
|
@ -31,6 +31,8 @@ void SetOne(BigBuffer& buffer);
|
|||
|
||||
void SetZero(BigBuffer& buffer);
|
||||
|
||||
void Sub(BigBuffer& a, const BigBuffer& b, const BigBuffer& c);
|
||||
|
||||
void ToBinary(TSGrowableArray<uint8_t>& output, const BigBuffer& buffer);
|
||||
|
||||
#endif
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue