Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
Benjamin Allred
crown-core
Commits
3b72fdfb
Commit
3b72fdfb
authored
10 years ago
by
Wladimir J. van der Laan
Browse files
Options
Download
Email Patches
Plain Diff
Revert "Reject transactions with excessive numbers of sigops"
This reverts commit
4fad8e6d
.
parent
8ebe4243
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
src/main.cpp
+3
-12
src/main.cpp
src/main.h
+0
-2
src/main.h
with
3 additions
and
14 deletions
+3
-14
src/main.cpp
View file @
3b72fdfb
...
...
@@ -956,18 +956,9 @@ bool AcceptToMemoryPool(CTxMemPool& pool, CValidationState &state, const CTransa
if
(
Params
().
RequireStandard
()
&&
!
AreInputsStandard
(
tx
,
view
))
return
error
(
"AcceptToMemoryPool: : nonstandard transaction input"
);
// Check that the transaction doesn't have an excessive number of
// sigops, making it impossible to mine. Since the coinbase transaction
// itself can contain sigops MAX_TX_SIGOPS is less than
// MAX_BLOCK_SIGOPS; we still consider this an invalid rather than
// merely non-standard transaction.
unsigned
int
nSigOps
=
GetLegacySigOpCount
(
tx
);
nSigOps
+=
GetP2SHSigOpCount
(
tx
,
view
);
if
(
nSigOps
>
MAX_TX_SIGOPS
)
return
state
.
DoS
(
0
,
error
(
"AcceptToMemoryPool : too many sigops %s, %d > %d"
,
hash
.
ToString
(),
nSigOps
,
MAX_TX_SIGOPS
),
REJECT_NONSTANDARD
,
"bad-txns-too-many-sigops"
);
// Note: if you modify this code to accept non-standard transactions, then
// you should add code here to check that the transaction does a
// reasonable number of ECDSA signature verifications.
int64_t
nValueOut
=
tx
.
GetValueOut
();
int64_t
nFees
=
nValueIn
-
nValueOut
;
...
...
This diff is collapsed.
Click to expand it.
src/main.h
View file @
3b72fdfb
...
...
@@ -45,8 +45,6 @@ static const unsigned int MAX_STANDARD_TX_SIZE = 100000;
static
const
unsigned
int
MAX_BLOCK_SIGOPS
=
MAX_BLOCK_SIZE
/
50
;
/** Maxiumum number of signature check operations in an IsStandard() P2SH script */
static
const
unsigned
int
MAX_P2SH_SIGOPS
=
15
;
/** The maximum number of sigops we're willing to relay/mine in a single tx */
static
const
unsigned
int
MAX_TX_SIGOPS
=
MAX_BLOCK_SIGOPS
/
5
;
/** The maximum number of orphan transactions kept in memory */
static
const
unsigned
int
MAX_ORPHAN_TRANSACTIONS
=
MAX_BLOCK_SIZE
/
100
;
/** Default for -maxorphanblocks, maximum number of orphan blocks kept in memory */
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment