mirror of
https://github.com/bitcoin/bips.git
synced 2025-01-18 05:12:47 +01:00
bip-0141: clarify the sigop count calculation for CHECKMULTISIG
Since the sigOpCount calculation was copied from P2SH, and P2SH restricts the use of CHECKMULTISIG with pushed integers the reference implementation would not take into account the number of public keys for 17 to 20 keys (not representable with an OP_N) even for P2WSH. Therefore it fallbacks to accounting for 20 sigops in this case, which this sentence seemed to mismatch with. Btcd and Libbitcoin use the same calculation as in Bitcoin Core. Signed-off-by: Antoine Poinsot <darosior@protonmail.com>
This commit is contained in:
parent
cf0b529e78
commit
644610f7b8
@ -127,7 +127,7 @@ Sigops per block is currently limited to 20,000. We change this restriction as f
|
||||
Sigops in the current pubkey script, signature script, and P2SH check script are counted at 4 times their previous value.
|
||||
The sigop limit is likewise quadrupled to ≤ 80,000.
|
||||
|
||||
Each P2WPKH input is counted as 1 sigop. In addition, opcodes within a P2WSH <code>witnessScript</code> are counted identically as previously within the P2SH <code>redeemScript</code>. That is, CHECKSIG is counted as only 1 sigop, and CHECKMULTISIG is counted as 1 to 20 sigops according to the arguments. This rule applies to both native witness program and P2SH witness program.
|
||||
Each P2WPKH input is counted as 1 sigop. In addition, opcodes within a P2WSH <code>witnessScript</code> are counted identically as previously within the P2SH <code>redeemScript</code>. That is, CHECKSIG is counted as only 1 sigop. When preceded by OP_1 to OP_16 CHECKMULTISIG is counted as 1 to 16 sigops respectively, otherwise it is counted as 20 sigops. This rule applies to both native witness program and P2SH witness program.
|
||||
|
||||
=== Additional definitions ===
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user