From ad340b4225f8280a78c0c3aab3c0412dde57888c Mon Sep 17 00:00:00 2001 From: josibake Date: Thu, 7 Nov 2024 11:44:30 +0100 Subject: [PATCH] make custom Batch type for secp256k1_batch this is a bit of a hack, we can probably be smarter using a named api struct for the batch verification module --- src/batchverify.cpp | 21 ++++++++++++++++----- src/batchverify.h | 5 ++--- 2 files changed, 18 insertions(+), 8 deletions(-) diff --git a/src/batchverify.cpp b/src/batchverify.cpp index 57f3b212085202..1f9d749b516336 100644 --- a/src/batchverify.cpp +++ b/src/batchverify.cpp @@ -12,6 +12,14 @@ #include #include +class Batch { +private: + secp256k1_batch* m_batch; +public: + Batch(secp256k1_batch* batch) : m_batch(batch) {} + secp256k1_batch* get() const { return m_batch; } +}; + BatchSchnorrVerifier::BatchSchnorrVerifier() { unsigned char rnd[16]; GetRandBytes(rnd); @@ -20,26 +28,29 @@ BatchSchnorrVerifier::BatchSchnorrVerifier() { // still efficient. const size_t max_batch_size{106}; secp256k1_batch* batch{secp256k1_batch_create(secp256k1_context_static, max_batch_size, rnd)}; - m_batch = batch; + m_batch = new Batch(batch); } BatchSchnorrVerifier::~BatchSchnorrVerifier() { - (void)secp256k1_batch_destroy(secp256k1_context_static, m_batch); + if (m_batch) { + (void)secp256k1_batch_destroy(secp256k1_context_static, m_batch->get()); + delete m_batch; + } } bool BatchSchnorrVerifier::Add(const Span sig, const XOnlyPubKey& pubkey, const uint256& sighash) { LOCK(m_batch_mutex); - if (secp256k1_batch_usable(secp256k1_context_static, m_batch) == 0) { + if (secp256k1_batch_usable(secp256k1_context_static, m_batch->get()) == 0) { LogPrintf("ERROR: BatchSchnorrVerifier m_batch unusable\n"); return false; } secp256k1_xonly_pubkey pubkey_parsed; if (!secp256k1_xonly_pubkey_parse(secp256k1_context_static, &pubkey_parsed, pubkey.data())) return false; - return secp256k1_batch_add_schnorrsig(secp256k1_context_static, m_batch, sig.data(), sighash.begin(), 32, &pubkey_parsed); + return secp256k1_batch_add_schnorrsig(secp256k1_context_static, m_batch->get(), sig.data(), sighash.begin(), 32, &pubkey_parsed); } bool BatchSchnorrVerifier::Verify() { LOCK(m_batch_mutex); - return secp256k1_batch_verify(secp256k1_context_static, m_batch); + return secp256k1_batch_verify(secp256k1_context_static, m_batch->get()); } diff --git a/src/batchverify.h b/src/batchverify.h index dc69130cfd2177..77d3f3d982cb86 100644 --- a/src/batchverify.h +++ b/src/batchverify.h @@ -8,11 +8,10 @@ #include #include -#include - +class Batch; class BatchSchnorrVerifier { private: - secp256k1_batch* m_batch GUARDED_BY(m_batch_mutex); + Batch* m_batch GUARDED_BY(m_batch_mutex); mutable Mutex m_batch_mutex; public: