diff options
| author | Pieter Wuille <[email protected]> | 2016-07-18 20:57:20 +0200 |
|---|---|---|
| committer | Pieter Wuille <[email protected]> | 2016-07-19 12:31:49 +0200 |
| commit | ab942c15bd3854650afa810d7c22d7fd30d346c1 (patch) | |
| tree | b1b4aeac333ab2f3b3b21a31d614e1674e0774f3 /src/policy | |
| parent | Merge #8367: [Wallet] Ensure <0.13 clients can't open HD wallets (diff) | |
| download | discoin-ab942c15bd3854650afa810d7c22d7fd30d346c1.tar.xz discoin-ab942c15bd3854650afa810d7c22d7fd30d346c1.zip | |
Treat high-sigop transactions as larger rather than rejecting them
Diffstat (limited to 'src/policy')
| -rw-r--r-- | src/policy/policy.cpp | 10 | ||||
| -rw-r--r-- | src/policy/policy.h | 8 |
2 files changed, 12 insertions, 6 deletions
diff --git a/src/policy/policy.cpp b/src/policy/policy.cpp index 8617db00c..0cd3ac711 100644 --- a/src/policy/policy.cpp +++ b/src/policy/policy.cpp @@ -151,12 +151,14 @@ bool AreInputsStandard(const CTransaction& tx, const CCoinsViewCache& mapInputs) return true; } -int64_t GetVirtualTransactionSize(int64_t nWeight) +unsigned int nBytesPerSigOp = DEFAULT_BYTES_PER_SIGOP; + +int64_t GetVirtualTransactionSize(int64_t nWeight, int64_t nSigOpCost) { - return (nWeight + WITNESS_SCALE_FACTOR - 1) / WITNESS_SCALE_FACTOR; + return (std::max(nWeight, nSigOpCost * nBytesPerSigOp) + WITNESS_SCALE_FACTOR - 1) / WITNESS_SCALE_FACTOR; } -int64_t GetVirtualTransactionSize(const CTransaction& tx) +int64_t GetVirtualTransactionSize(const CTransaction& tx, int64_t nSigOpCost) { - return GetVirtualTransactionSize(GetTransactionWeight(tx)); + return GetVirtualTransactionSize(GetTransactionWeight(tx), nSigOpCost); } diff --git a/src/policy/policy.h b/src/policy/policy.h index f5f8652fb..b82c9e66b 100644 --- a/src/policy/policy.h +++ b/src/policy/policy.h @@ -28,6 +28,8 @@ static const unsigned int MAX_P2SH_SIGOPS = 15; static const unsigned int MAX_STANDARD_TX_SIGOPS_COST = MAX_BLOCK_SIGOPS_COST/5; /** Default for -maxmempool, maximum megabytes of mempool memory usage */ static const unsigned int DEFAULT_MAX_MEMPOOL_SIZE = 300; +/** Default for -bytespersigop */ +static const unsigned int DEFAULT_BYTES_PER_SIGOP = 20; /** * Standard script verification flags that standard transactions will comply * with. However scripts violating these flags may still be present in valid @@ -66,8 +68,10 @@ bool IsStandardTx(const CTransaction& tx, std::string& reason); */ bool AreInputsStandard(const CTransaction& tx, const CCoinsViewCache& mapInputs); +extern unsigned int nBytesPerSigOp; + /** Compute the virtual transaction size (weight reinterpreted as bytes). */ -int64_t GetVirtualTransactionSize(int64_t nWeight); -int64_t GetVirtualTransactionSize(const CTransaction& tx); +int64_t GetVirtualTransactionSize(int64_t nWeight, int64_t nSigOpCost); +int64_t GetVirtualTransactionSize(const CTransaction& tx, int64_t nSigOpCost = 0); #endif // BITCOIN_POLICY_POLICY_H |