Branch data Line data Source code
1 : : // Copyright (c) 2009-2010 Satoshi Nakamoto
2 : : // Copyright (c) 2009-present The Bitcoin Core developers
3 : : // Distributed under the MIT software license, see the accompanying
4 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 : :
6 : : #ifndef BITCOIN_SCRIPT_SIGCACHE_H
7 : : #define BITCOIN_SCRIPT_SIGCACHE_H
8 : :
9 : : #include <consensus/amount.h>
10 : : #include <crypto/sha256.h>
11 : : #include <cuckoocache.h>
12 : : #include <script/interpreter.h>
13 : : #include <span.h>
14 : : #include <uint256.h>
15 : : #include <util/byte_units.h>
16 : : #include <util/hasher.h>
17 : :
18 : : #include <cstddef>
19 : : #include <shared_mutex>
20 : : #include <vector>
21 : :
22 : : class CPubKey;
23 : : class CTransaction;
24 : : class XOnlyPubKey;
25 : :
26 : : // DoS prevention: limit cache size to 32MiB (over 1000000 entries on 64-bit
27 : : // systems). Due to how we count cache size, actual memory usage is slightly
28 : : // more (~32.25 MiB)
29 : : static constexpr size_t DEFAULT_VALIDATION_CACHE_BYTES{32_MiB};
30 : : static constexpr size_t DEFAULT_SIGNATURE_CACHE_BYTES{DEFAULT_VALIDATION_CACHE_BYTES / 2};
31 : : static constexpr size_t DEFAULT_SCRIPT_EXECUTION_CACHE_BYTES{DEFAULT_VALIDATION_CACHE_BYTES / 2};
32 : : static_assert(DEFAULT_VALIDATION_CACHE_BYTES == DEFAULT_SIGNATURE_CACHE_BYTES + DEFAULT_SCRIPT_EXECUTION_CACHE_BYTES);
33 : :
34 : : /**
35 : : * Valid signature cache, to avoid doing expensive ECDSA signature checking
36 : : * twice for every transaction (once when accepted into memory pool, and
37 : : * again when accepted into the block chain)
38 : : */
39 : 1250 : class SignatureCache
40 : : {
41 : : private:
42 : : //! Entries are SHA256(nonce || 'E' or 'S' || 31 zero bytes || signature hash || public key || signature):
43 : : CSHA256 m_salted_hasher_ecdsa;
44 : : CSHA256 m_salted_hasher_schnorr;
45 : : typedef CuckooCache::cache<uint256, SignatureCacheHasher> map_type;
46 : : map_type setValid;
47 : : std::shared_mutex cs_sigcache;
48 : :
49 : : public:
50 : : SignatureCache(size_t max_size_bytes);
51 : :
52 : : SignatureCache(const SignatureCache&) = delete;
53 : : SignatureCache& operator=(const SignatureCache&) = delete;
54 : :
55 : : void ComputeEntryECDSA(uint256& entry, const uint256 &hash, const std::vector<unsigned char>& vchSig, const CPubKey& pubkey) const;
56 : :
57 : : void ComputeEntrySchnorr(uint256& entry, const uint256 &hash, std::span<const unsigned char> sig, const XOnlyPubKey& pubkey) const;
58 : :
59 : : bool Get(const uint256& entry, bool erase);
60 : :
61 : : void Set(const uint256& entry);
62 : : };
63 : :
64 [ + + ]: 216149 : class CachingTransactionSignatureChecker : public TransactionSignatureChecker
65 : : {
66 : : private:
67 : : bool store;
68 : : SignatureCache& m_signature_cache;
69 : :
70 : : public:
71 [ + - ]: 216149 : CachingTransactionSignatureChecker(const CTransaction* txToIn, unsigned int nInIn, const CAmount& amountIn, bool storeIn, SignatureCache& signature_cache, PrecomputedTransactionData& txdataIn) : TransactionSignatureChecker(txToIn, nInIn, amountIn, txdataIn, MissingDataBehavior::ASSERT_FAIL), store(storeIn), m_signature_cache(signature_cache) {}
72 : :
73 : : bool VerifyECDSASignature(const std::vector<unsigned char>& vchSig, const CPubKey& vchPubKey, const uint256& sighash) const override;
74 : : bool VerifySchnorrSignature(std::span<const unsigned char> sig, const XOnlyPubKey& pubkey, const uint256& sighash) const override;
75 : : };
76 : :
77 : : #endif // BITCOIN_SCRIPT_SIGCACHE_H
|