doc: IsFinalTx comment about nSequence & OP_CLTV #18096

pull nothingmuch wants to merge 1 commits into bitcoin:master from nothingmuch:nLockTime-comment changing 2 files +12 −3
  1. nothingmuch commented at 8:53 pm on February 7, 2020: contributor
    It’s somewhat surprising that a transaction’s nLockTime field is ignored when all nSequence fields are final, so this change aims to clarify this behavior and cross reference relevant details of OP_CHECKLOCKTIMEVERIFY.
  2. amitiuttarwar commented at 9:11 pm on February 7, 2020: contributor
    ACK 5546ed61c65c167ba839df7b5277f8689242ae8b. Sheds light on a confusing corner of the code.
  3. DrahtBot added the label Consensus on Feb 7, 2020
  4. DrahtBot added the label Docs on Feb 7, 2020
  5. in src/script/interpreter.cpp:1748 in 5546ed61c6 outdated
    1352-    // finalized by setting nSequence to maxint. The
    1353+    // Finally the nLockTime feature can be disabled in IsFinalTx()
    1354+    // and thus CHECKLOCKTIMEVERIFY bypassed if every txin has
    1355+    // been finalized by setting nSequence to maxint. The
    1356     // transaction would be allowed into the blockchain, making
    1357     // the opcode ineffective.
    


    ariard commented at 9:30 pm on February 13, 2020:
    “This enable a lightweight onchain covenant where you can be safe than constrained output can’t be spent until reaching committed nBlockHeight/nBlockTime”

    nothingmuch commented at 2:09 pm on February 15, 2020:

    I expanded a bit on your suggestion in c4a022d4

    p.s. sorry for accidentally clicking resolve

  6. ariard approved
  7. ariard commented at 9:32 pm on February 13, 2020: member

    ACK 5546ed6

    Thanks for documenting this foresight of OP_CLTV design.

  8. nothingmuch referenced this in commit c4a022d4f7 on Feb 15, 2020
  9. DrahtBot commented at 4:31 am on February 17, 2020: member

    The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.

    Conflicts

    No conflicts as of last run.

  10. in src/consensus/tx_verify.cpp:25 in c4a022d4f7 outdated
    19@@ -20,6 +20,15 @@ bool IsFinalTx(const CTransaction &tx, int nBlockHeight, int64_t nBlockTime)
    20         return true;
    21     if ((int64_t)tx.nLockTime < ((int64_t)tx.nLockTime < LOCKTIME_THRESHOLD ? (int64_t)nBlockHeight : nBlockTime))
    22         return true;
    23+
    24+    // Even if tx.nLockTime isn't satisfied by nBlockHeight/nBlockTime, a
    25+    // transaction is still considered final if all nSequence values are final,
    


    michaelfolkson commented at 10:06 pm on May 9, 2020:
    nit: You could make clear that by final you mean if the nSequence values are maxed out to 0xffffffff. Perhaps this wording of final is clear to everyone else (in which case ignore).
  11. michaelfolkson commented at 10:09 pm on May 9, 2020: contributor
    ACK c4a022d4f75384ba9d6978971fcaeabd072a9acc. Nice addition.
  12. amitiuttarwar commented at 10:13 pm on May 9, 2020: contributor
    @nothingmuch could you squash the fixup commit ?
  13. nothingmuch force-pushed on May 10, 2020
  14. nothingmuch commented at 1:28 am on May 10, 2020: contributor
    Done. I’ve also included @michaelfolkson’s suggestion.
  15. nothingmuch force-pushed on May 10, 2020
  16. nothingmuch commented at 1:36 am on May 10, 2020: contributor
    After rereading the diff I added a minor rewording of the comment explaining nLockTime covenants, since I felt it lacked clarity, and force pushed that so that the PR is still squashed at the moment.
  17. nothingmuch force-pushed on May 10, 2020
  18. michaelfolkson commented at 3:51 pm on May 11, 2020: contributor
    ACK ae93eb3379604a5ee83242f420bb5431fa238b9e. British English spelling of “behaviour” but not worth another force push to change in my view.
  19. in src/script/interpreter.cpp:1744 in ae93eb3379 outdated
    1433@@ -1434,16 +1434,22 @@ bool GenericTransactionSignatureChecker<T>::CheckLockTime(const CScriptNum& nLoc
    1434     if (nLockTime > (int64_t)txTo->nLockTime)
    1435         return false;
    1436 
    1437-    // Finally the nLockTime feature can be disabled and thus
    1438-    // CHECKLOCKTIMEVERIFY bypassed if every txin has been
    1439-    // finalized by setting nSequence to maxint. The
    1440+    // Finally the nLockTime feature can be disabled in IsFinalTx()
    


    amitiuttarwar commented at 5:19 pm on May 15, 2020:

    I’m not a huge fan of having function names in the comments, because the code might change over time. eg. theoretically there could be another calling path that also disables, right?

    in this case I don’t think its a big deal esp bc its consensus code that seems quite unlikely to change


    nothingmuch commented at 6:47 pm on May 15, 2020:

    FWIW the rationale for adding it was specifically to cross reference these the two locations in the code, as they are more easily understood together.

    I can definitely see why this is not worth the risk of stale comments, but [edit to add: assuming it’s desired] couldn’t think of a simpler way.

    Maybe just mentioning CHECKLOCKTIMEVERIFY and SEQUENCE_FINAL is a good compromise, there are few false positives, and those are even less likely to change.


    amitiuttarwar commented at 10:00 pm on May 15, 2020:

    FWIW the rationale for adding it was specifically to cross reference these the two locations in the code, as they are more easily understood together.

    fair enough. makes sense in this case

  20. amitiuttarwar commented at 5:22 pm on May 15, 2020: contributor

    ACK ae93eb3379604a5ee83242f420bb5431fa238b9e

    one comment, but not worth holding up the PR. its been open for a while and overall this documentation helps clarify some unexpected logic, so def an improvement in my eyes.

  21. theStack commented at 9:14 pm on July 26, 2020: member
    Concept ACK, definitely makes sense to document unexpected behaviour in more detail.
  22. nothingmuch commented at 11:09 pm on July 26, 2020: contributor
    i fixed both “behaviour” and “the the”, will squash & rebase after i reread everything tomorrow
  23. nothingmuch force-pushed on Jul 28, 2020
  24. nothingmuch commented at 2:56 am on July 28, 2020: contributor
    so, despite previous ACKs i couldn’t resist rephrasing the paragraph about the locktime covenants, since i could barely understand what i had originally meant by it… squashed and rebased on master
  25. amitiuttarwar commented at 3:35 am on August 8, 2020: contributor

    ACK abc8f3bae2cd9a65e170528d77973307050c5b47.

    Hoping this PR can get merged soon!

  26. benthecarman commented at 11:42 pm on September 8, 2020: contributor
    ACK abc8f3b
  27. Zero-1729 commented at 3:53 am on September 9, 2020: contributor
    ACK abc8f3b. Looks good.
  28. in src/script/interpreter.cpp:1453 in abc8f3bae2 outdated
    1451+    // This additional constraint enables a kind of lightweight
    1452+    // covenant: by using OP_CHECKLOCKTIMEVERIFY an output may
    1453+    // be unspendable until a specific nBlockHeight/nBlockTime
    1454+    // committed in the scriptPubKey, as opposed to a spending
    1455+    // transaction's nLockTime only being constrained by
    1456+    // signature verification.
    


    MarcoFalke commented at 9:52 am on April 21, 2021:

    I think the Bitcoin Core source code (or interpreter source code) is the wrong place to document what is possible with each opcode. Better places to document this is the BIPs repo (or stackexchange, the mailing list, your private blog or website, …).

    In fact the BIP already mentions several use cases. See https://github.com/bitcoin/bips/blob/master/bip-0065.mediawiki#Motivation . Should the other use-cases be copy-pasted here as well? If a new use-case is found, should it be copied here, too? How much review/maintenance time is this going to consume?

    Also, you mention the word covenant, which isn’t defined in our source code, nor the BIP text. I think this section adds more confusion for anyone reading the BIP and then this section.


    nothingmuch commented at 2:35 pm on April 21, 2021:
    That sounds reasonable to me and fits in with the original motivation. @ariard since this was your suggestion do you mind if I remove it?

    nothingmuch commented at 3:14 am on April 24, 2021:
    I went ahead and removed this addition.

    ariard commented at 5:31 pm on April 26, 2021:

    Fine to remove it. IIRC, I did advise you this comment because I was surprised to see nowhere this relation between nLocktime enforcement and finality of inputs documented. At least not in BOLT3, where timeout transactions nSequence are carefully set to non-final.

    Overall I agree with @MarcoFalke. Though I would say some mechanism usage towards specific Bitcoin applications are already documented in the codebase. For e.g the carve-out rule in the mempool : https://github.com/bitcoin/bitcoin/blob/683dda2a70e7a210996fa34be23bd0c563971ba9/src/validation.cpp#L801

  29. MarcoFalke dismissed
  30. MarcoFalke commented at 9:54 am on April 21, 2021: member
    Seems fine to better explain how IsFinalTx works, but I am not sure about starting a section about “covenants”.
  31. nothingmuch force-pushed on Apr 24, 2021
  32. 78051301012 commented at 7:06 pm on April 24, 2021: none
    src/script/interpreter.cpp
  33. in src/consensus/tx_verify.cpp:25 in 047c6075ed outdated
    19@@ -20,6 +20,15 @@ bool IsFinalTx(const CTransaction &tx, int nBlockHeight, int64_t nBlockTime)
    20         return true;
    21     if ((int64_t)tx.nLockTime < ((int64_t)tx.nLockTime < LOCKTIME_THRESHOLD ? (int64_t)nBlockHeight : nBlockTime))
    22         return true;
    23+
    24+    // Even if tx.nLockTime isn't satisfied by nBlockHeight/nBlockTime, a
    25+    // transaction is still considered final if all nSequence == SEQUENCE_FINAL
    


    ariard commented at 5:31 pm on April 26, 2021:
    nit: if all inputs’s nSequence
  34. ariard commented at 5:32 pm on April 26, 2021: member
    ACK 047c607
  35. nothingmuch force-pushed on Apr 27, 2021
  36. doc: IsFinalTx comment about nSequence & OP_CLTV
    It's somewhat surprising that a transaction's nLockTime field is ignored
    when all nSequence fields are final, so this change aims to clarify this
    behavior and cross reference relevant details of OP_CHECKLOCKTIMEVERIFY.
    f9e37f33ce
  37. nothingmuch force-pushed on Apr 27, 2021
  38. nothingmuch requested review from MarcoFalke on Jun 28, 2021
  39. MarcoFalke commented at 7:44 am on June 29, 2021: member
    ACK f9e37f33ce2d8b463a0bcbe7189c9bc5b36530b7
  40. MarcoFalke merged this on Jun 30, 2021
  41. MarcoFalke closed this on Jun 30, 2021

  42. sidhujag referenced this in commit f86d791e0e on Jun 30, 2021
  43. PastaPastaPasta referenced this in commit 21eff66538 on Sep 21, 2021
  44. PastaPastaPasta referenced this in commit 4b6409fe26 on Sep 24, 2021
  45. kittywhiskers referenced this in commit b06e94cba9 on Oct 12, 2021
  46. gwillen referenced this in commit 29a49051ba on Jun 1, 2022
  47. DrahtBot locked this on Aug 18, 2022

github-metadata-mirror

This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-21 06:12 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me