mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 02:33:24 -03:00
Squashed 'src/minisketch/' changes from 3472e2f5ec..eb37a9b8e7
eb37a9b8e7 Merge sipa/minisketch#87: Avoid copy in self-assign fe6557642e Merge sipa/minisketch#88: build: Add `-Wundef` 8ea298bfa7 Avoid copy in self-assign 978a3d8869 build: Add `-Wundef` 3387044179 Merge sipa/minisketch#86: doc: fix typo in sketch_impl.h 15c2d13b60 doc: fix typo in sketch_impl.h 7be08b8a46 Merge sipa/minisketch#85: Fixes for integer precision loss 00fb4a4d83 Avoid or make integer precision conversion explicit 9d62a4d27c Avoid the need to cast/convert to size_t for vector operations 19e06cc7af Prevent overflows from large capacity/max_elements git-subtree-dir: src/minisketch git-subtree-split: eb37a9b8e79f9e49d73b96a49bf97a96d9eb676c
This commit is contained in:
parent
1eea10a6d2
commit
cb59af38e7
7 changed files with 15 additions and 11 deletions
|
@ -102,6 +102,7 @@ case $host in
|
||||||
esac
|
esac
|
||||||
|
|
||||||
AX_CHECK_COMPILE_FLAG([-Wall],[WARN_CXXFLAGS="$WARN_CXXFLAGS -Wall"],,[[$CXXFLAG_WERROR]])
|
AX_CHECK_COMPILE_FLAG([-Wall],[WARN_CXXFLAGS="$WARN_CXXFLAGS -Wall"],,[[$CXXFLAG_WERROR]])
|
||||||
|
AX_CHECK_COMPILE_FLAG([-Wundef], [WARN_CXXFLAGS="$WARN_CXXFLAGS -Wundef"], [], [$CXXFLAG_WERROR])
|
||||||
AX_CHECK_COMPILE_FLAG([-fvisibility=hidden],[CXXFLAGS="$CXXFLAGS -fvisibility=hidden"],[],[$CXXFLAG_WERROR])
|
AX_CHECK_COMPILE_FLAG([-fvisibility=hidden],[CXXFLAGS="$CXXFLAGS -fvisibility=hidden"],[],[$CXXFLAG_WERROR])
|
||||||
|
|
||||||
if test "x$use_ccache" != "xno"; then
|
if test "x$use_ccache" != "xno"; then
|
||||||
|
|
|
@ -239,7 +239,7 @@ public:
|
||||||
/** Make this Minisketch a clone of the specified one. */
|
/** Make this Minisketch a clone of the specified one. */
|
||||||
Minisketch& operator=(const Minisketch& sketch) noexcept
|
Minisketch& operator=(const Minisketch& sketch) noexcept
|
||||||
{
|
{
|
||||||
if (sketch.m_minisketch) {
|
if (this != &sketch && sketch.m_minisketch) {
|
||||||
m_minisketch = std::unique_ptr<minisketch, Deleter>(minisketch_clone(sketch.m_minisketch.get()));
|
m_minisketch = std::unique_ptr<minisketch, Deleter>(minisketch_clone(sketch.m_minisketch.get()));
|
||||||
}
|
}
|
||||||
return *this;
|
return *this;
|
||||||
|
|
|
@ -81,7 +81,8 @@ uint64_t BaseFPBits(uint32_t bits, uint32_t capacity) {
|
||||||
|
|
||||||
size_t ComputeCapacity(uint32_t bits, size_t max_elements, uint32_t fpbits) {
|
size_t ComputeCapacity(uint32_t bits, size_t max_elements, uint32_t fpbits) {
|
||||||
if (bits == 0) return 0;
|
if (bits == 0) return 0;
|
||||||
uint64_t base_fpbits = BaseFPBits(bits, max_elements);
|
if (max_elements > 0xffffffff) return max_elements;
|
||||||
|
uint64_t base_fpbits = BaseFPBits(bits, static_cast<uint32_t>(max_elements));
|
||||||
// The fpbits provided by the base max_elements==capacity case are sufficient.
|
// The fpbits provided by the base max_elements==capacity case are sufficient.
|
||||||
if (base_fpbits >= fpbits) return max_elements;
|
if (base_fpbits >= fpbits) return max_elements;
|
||||||
// Otherwise, increment capacity by ceil(fpbits / bits) beyond that.
|
// Otherwise, increment capacity by ceil(fpbits / bits) beyond that.
|
||||||
|
@ -90,6 +91,7 @@ size_t ComputeCapacity(uint32_t bits, size_t max_elements, uint32_t fpbits) {
|
||||||
|
|
||||||
size_t ComputeMaxElements(uint32_t bits, size_t capacity, uint32_t fpbits) {
|
size_t ComputeMaxElements(uint32_t bits, size_t capacity, uint32_t fpbits) {
|
||||||
if (bits == 0) return 0;
|
if (bits == 0) return 0;
|
||||||
|
if (capacity > 0xffffffff) return capacity;
|
||||||
// Start with max_elements=capacity, and decrease max_elements until the corresponding capacity is capacity.
|
// Start with max_elements=capacity, and decrease max_elements until the corresponding capacity is capacity.
|
||||||
size_t max_elements = capacity;
|
size_t max_elements = capacity;
|
||||||
while (true) {
|
while (true) {
|
||||||
|
|
|
@ -159,7 +159,7 @@ static inline int CountBits(I val, int max) {
|
||||||
}
|
}
|
||||||
if (!ret) return 0;
|
if (!ret) return 0;
|
||||||
return index + 1;
|
return index + 1;
|
||||||
#elif HAVE_CLZ
|
#elif defined(HAVE_CLZ)
|
||||||
(void)max;
|
(void)max;
|
||||||
if (val == 0) return 0;
|
if (val == 0) return 0;
|
||||||
if (std::numeric_limits<unsigned>::digits >= std::numeric_limits<I>::digits) {
|
if (std::numeric_limits<unsigned>::digits >= std::numeric_limits<I>::digits) {
|
||||||
|
@ -210,7 +210,7 @@ public:
|
||||||
static constexpr inline int TopBits(I val) {
|
static constexpr inline int TopBits(I val) {
|
||||||
static_assert(Count > 0, "BitsInt::TopBits needs Count > 0");
|
static_assert(Count > 0, "BitsInt::TopBits needs Count > 0");
|
||||||
static_assert(Count <= BITS, "BitsInt::TopBits needs Offset <= BITS");
|
static_assert(Count <= BITS, "BitsInt::TopBits needs Offset <= BITS");
|
||||||
return val >> (BITS - Count);
|
return static_cast<int>(val >> (BITS - Count));
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline constexpr I CondXorWith(I val, bool cond, I v) {
|
static inline constexpr I CondXorWith(I val, bool cond, I v) {
|
||||||
|
|
|
@ -468,7 +468,7 @@ size_t minisketch_merge(minisketch* sketch, const minisketch* other_sketch) {
|
||||||
ssize_t minisketch_decode(const minisketch* sketch, size_t max_elements, uint64_t* output) {
|
ssize_t minisketch_decode(const minisketch* sketch, size_t max_elements, uint64_t* output) {
|
||||||
const Sketch* s = (const Sketch*)sketch;
|
const Sketch* s = (const Sketch*)sketch;
|
||||||
s->Check();
|
s->Check();
|
||||||
return s->Decode(max_elements, output);
|
return s->Decode(static_cast<int>(max_elements), output);
|
||||||
}
|
}
|
||||||
|
|
||||||
void minisketch_set_seed(minisketch* sketch, uint64_t seed) {
|
void minisketch_set_seed(minisketch* sketch, uint64_t seed) {
|
||||||
|
|
|
@ -29,7 +29,7 @@ public:
|
||||||
virtual ~Sketch() {}
|
virtual ~Sketch() {}
|
||||||
virtual size_t Syndromes() const = 0;
|
virtual size_t Syndromes() const = 0;
|
||||||
|
|
||||||
virtual void Init(int syndromes) = 0;
|
virtual void Init(size_t syndromes) = 0;
|
||||||
virtual void Add(uint64_t element) = 0;
|
virtual void Add(uint64_t element) = 0;
|
||||||
virtual void Serialize(unsigned char*) const = 0;
|
virtual void Serialize(unsigned char*) const = 0;
|
||||||
virtual void Deserialize(const unsigned char*) = 0;
|
virtual void Deserialize(const unsigned char*) = 0;
|
||||||
|
|
|
@ -92,7 +92,8 @@ template<typename F>
|
||||||
void Sqr(std::vector<typename F::Elem>& poly, const F& field) {
|
void Sqr(std::vector<typename F::Elem>& poly, const F& field) {
|
||||||
if (poly.size() == 0) return;
|
if (poly.size() == 0) return;
|
||||||
poly.resize(poly.size() * 2 - 1);
|
poly.resize(poly.size() * 2 - 1);
|
||||||
for (int x = poly.size() - 1; x >= 0; --x) {
|
for (size_t i = 0; i < poly.size(); ++i) {
|
||||||
|
auto x = poly.size() - i - 1;
|
||||||
poly[x] = (x & 1) ? 0 : field.Sqr(poly[x / 2]);
|
poly[x] = (x & 1) ? 0 : field.Sqr(poly[x / 2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -217,7 +218,7 @@ bool RecFindRoots(std::vector<std::vector<typename F::Elem>>& stack, size_t pos,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fully_factorizable) {
|
if (fully_factorizable) {
|
||||||
// Every succesful iteration of this algorithm splits the input
|
// Every successful iteration of this algorithm splits the input
|
||||||
// polynomial further into buckets, each corresponding to a subset
|
// polynomial further into buckets, each corresponding to a subset
|
||||||
// of 2^(BITS-depth) roots. If after depth splits the degree of
|
// of 2^(BITS-depth) roots. If after depth splits the degree of
|
||||||
// the polynomial is >= 2^(BITS-depth), something is wrong.
|
// the polynomial is >= 2^(BITS-depth), something is wrong.
|
||||||
|
@ -297,7 +298,7 @@ std::vector<typename F::Elem> BerlekampMassey(const std::vector<typename F::Elem
|
||||||
auto discrepancy = syndromes[n];
|
auto discrepancy = syndromes[n];
|
||||||
for (size_t i = 1; i < current.size(); ++i) discrepancy ^= table[n - i](current[i]);
|
for (size_t i = 1; i < current.size(); ++i) discrepancy ^= table[n - i](current[i]);
|
||||||
if (discrepancy != 0) {
|
if (discrepancy != 0) {
|
||||||
int x = n + 1 - (current.size() - 1) - (prev.size() - 1);
|
int x = static_cast<int>(n + 1 - (current.size() - 1) - (prev.size() - 1));
|
||||||
if (!b_have_inv) {
|
if (!b_have_inv) {
|
||||||
b_inv = field.Inv(b);
|
b_inv = field.Inv(b);
|
||||||
b_have_inv = true;
|
b_have_inv = true;
|
||||||
|
@ -366,7 +367,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t Syndromes() const override { return m_syndromes.size(); }
|
size_t Syndromes() const override { return m_syndromes.size(); }
|
||||||
void Init(int count) override { m_syndromes.assign(count, 0); }
|
void Init(size_t count) override { m_syndromes.assign(count, 0); }
|
||||||
|
|
||||||
void Add(uint64_t val) override
|
void Add(uint64_t val) override
|
||||||
{
|
{
|
||||||
|
@ -405,7 +406,7 @@ public:
|
||||||
for (const auto& root : roots) {
|
for (const auto& root : roots) {
|
||||||
*(out++) = m_field.ToUint64(root);
|
*(out++) = m_field.ToUint64(root);
|
||||||
}
|
}
|
||||||
return roots.size();
|
return static_cast<int>(roots.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t Merge(const Sketch* other_sketch) override
|
size_t Merge(const Sketch* other_sketch) override
|
||||||
|
|
Loading…
Add table
Reference in a new issue