// Copyright (c) 2009-2010 Satoshi Nakamoto // Copyright (c) 2009-2013 The Bitcoin Core developers // Distributed under the MIT software license, see the accompanying // file COPYING or https://www.opensource.org/licenses/mit-license.php . #ifndef BITCOIN_MINER_H #define BITCOIN_MINER_H #include "primitives/block.h" #include #include #include class CBlockIndex; class CChainParams; class CScript; namespace Consensus { struct Params; }; static const bool DEFAULT_GENERATE = false; static const int DEFAULT_GENERATE_THREADS = 1; static const bool DEFAULT_PRINTPRIORITY = false; class InvalidMinerAddress { public: friend bool operator==(const InvalidMinerAddress &a, const InvalidMinerAddress &b) { return true; } friend bool operator<(const InvalidMinerAddress &a, const InvalidMinerAddress &b) { return true; } }; typedef std::variant< InvalidMinerAddress, libzcash::SaplingPaymentAddress, boost::shared_ptr> MinerAddress; class ExtractMinerAddress { public: ExtractMinerAddress() {} MinerAddress operator()(const libzcash::InvalidEncoding &invalid) const { return InvalidMinerAddress(); } MinerAddress operator()(const libzcash::SproutPaymentAddress &addr) const { return InvalidMinerAddress(); } MinerAddress operator()(const libzcash::SaplingPaymentAddress &addr) const { return addr; } MinerAddress operator()(const libzcash::UnifiedAddress &addr) const { auto recipient = RecipientForPaymentAddress()(addr); if (recipient) { return std::visit(ExtractMinerAddress(), *recipient); } else { // Either the UA only contains unknown shielded receivers (unlikely that we // wouldn't know about them), or it only contains transparent receivers // (which are invalid). return InvalidMinerAddress(); } } }; class KeepMinerAddress { public: KeepMinerAddress() {} void operator()(const InvalidMinerAddress &invalid) const {} void operator()(const libzcash::SaplingPaymentAddress &pa) const {} void operator()(const boost::shared_ptr &coinbaseScript) const { coinbaseScript->KeepScript(); } }; bool IsShieldedMinerAddress(const MinerAddress& minerAddr); class IsValidMinerAddress { public: IsValidMinerAddress() {} bool operator()(const InvalidMinerAddress &invalid) const { return false; } bool operator()(const libzcash::SaplingPaymentAddress &pa) const { return true; } bool operator()(const boost::shared_ptr &coinbaseScript) const { // Return false if no script was provided. This can happen // due to some internal error but also if the keypool is empty. // In the latter case, already the pointer is NULL. return coinbaseScript.get() && !coinbaseScript->reserveScript.empty(); } }; struct CBlockTemplate { CBlock block; // Cached whenever we update `block`, so we can update hashBlockCommitments // when we change the coinbase transaction. uint256 hashChainHistoryRoot; std::vector vTxFees; std::vector vTxSigOps; }; CMutableTransaction CreateCoinbaseTransaction(const CChainParams& chainparams, CAmount nFees, const MinerAddress& minerAddress, int nHeight); /** Generate a new block, without valid proof-of-work */ CBlockTemplate* CreateNewBlock(const CChainParams& chainparams, const MinerAddress& minerAddress, const std::optional& next_coinbase_mtx = std::nullopt); #ifdef ENABLE_MINING /** Get -mineraddress */ void GetMinerAddress(MinerAddress &minerAddress); /** Modify the extranonce in a block */ void IncrementExtraNonce( CBlockTemplate* pblocktemplate, const CBlockIndex* pindexPrev, unsigned int& nExtraNonce, const Consensus::Params& consensusParams); /** Run the miner threads */ void GenerateBitcoins(bool fGenerate, int nThreads, const CChainParams& chainparams); #endif void UpdateTime(CBlockHeader* pblock, const Consensus::Params& consensusParams, const CBlockIndex* pindexPrev); #endif // BITCOIN_MINER_H