Return-Path: Received: from smtp2.osuosl.org (smtp2.osuosl.org [140.211.166.133]) by lists.linuxfoundation.org (Postfix) with ESMTP id A323BC000E for ; Mon, 5 Jul 2021 17:20:36 +0000 (UTC) Received: from localhost (localhost [127.0.0.1]) by smtp2.osuosl.org (Postfix) with ESMTP id 9C7FD403A6 for ; Mon, 5 Jul 2021 17:20:36 +0000 (UTC) X-Virus-Scanned: amavisd-new at osuosl.org X-Spam-Flag: NO X-Spam-Score: -1.9 X-Spam-Level: X-Spam-Status: No, score=-1.9 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001] autolearn=ham autolearn_force=no Authentication-Results: smtp2.osuosl.org (amavisd-new); dkim=pass (2048-bit key) header.d=blockstream-com.20150623.gappssmtp.com Received: from smtp2.osuosl.org ([127.0.0.1]) by localhost (smtp2.osuosl.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id bOBvYJyk1ERF for ; Mon, 5 Jul 2021 17:20:35 +0000 (UTC) X-Greylist: whitelisted by SQLgrey-1.8.0 Received: from mail-qk1-x72d.google.com (mail-qk1-x72d.google.com [IPv6:2607:f8b0:4864:20::72d]) by smtp2.osuosl.org (Postfix) with ESMTPS id D1F6D401BA for ; Mon, 5 Jul 2021 17:20:34 +0000 (UTC) Received: by mail-qk1-x72d.google.com with SMTP id j184so17561828qkd.6 for ; Mon, 05 Jul 2021 10:20:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=blockstream-com.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to; bh=a1dGkc+Xe2D+uZT/hEe8X1/m3rz2VK0oFA38z8bHJhk=; b=XlShtAJ/uAkgSO16X5dbfWZEZUIxDjastkIvkpz/pr9kSX6rrwf6hRL2SzWayWLv3Z 4/beoM16a853nFWtcgTGCmSGSTQZN8XHYbbJWjtpXl7eVemYB4wGpUzfh3erMSIonL+B 0l8RpIi4OnbG6rWdvI0P3vAhYPTyCHboYMnZKuLNwwCY9l08atqYJkxNyv6hkT9YDeQw Nl6UEPlSqs8e6KLNSN/Yylh+wdgHBo4k9QB35O7apUGcLNCE8P+bgM3ICHft252/ssfQ 79Qo/t/smPX89uoJwRONPsquftSM9xyqjgU6lSY4ZlR/8ZjT5EwGCSc8aqcrSatU1gma +9PA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to; bh=a1dGkc+Xe2D+uZT/hEe8X1/m3rz2VK0oFA38z8bHJhk=; b=N8gL7PWvrtXA3W+0PUqcT3qM/vRWwgmxe/AgGGhC63F5iZnFxHJvNAp32p5K5opZ69 xUE6DJ+6dtsHNfA/i9Ye8iVNWCMjo+/NcL8p44jLHNWP6DQeH4uWHUfoJKSgpdmsXRhH r+KjAG9oxBqKyWJbXdVjd5zAGiYhRCBTDfenKo2Q96MUY8zqUATUOlbqwUdq4HkHCtLJ jHlHvxMafWGk8YzcWhEzQ5dBusLRdGZxR7Vs2xh2CCQsnQnNB4Wlpm8QK7U94F75cJsE 1kY7hzQfgIGCnZxBy4Bjph8eKVpfFBMu8Ws7tlZLKQDzP4NPr2SgjNLa34Ftzvma1lBr pYoQ== X-Gm-Message-State: AOAM531JdToX62nuoxeP5Elw/ofLlrez/txTmznokkscB44dDCuI/epg AmSrGxRcTFboJeS0knQaJyXfhqwkPA+EFn9T/A7ddw== X-Google-Smtp-Source: ABdhPJwkP2i1PTFuRICfjBnUMz5a45L3C/OGcwHpg6g5fT9nahprQvJmI+qWyZInk6CRAvGz/i49Caj9htHeiNyHiVM= X-Received: by 2002:a05:620a:d42:: with SMTP id o2mr14938523qkl.233.1625505633609; Mon, 05 Jul 2021 10:20:33 -0700 (PDT) MIME-Version: 1.0 References: <20210704011341.ddbiruuomqovrjn6@ganymede> <20210704203230.37hlpdyzr4aijiet@ganymede> <5keA_aPvmCO5yBh_mBQ6Z5SwnnvEW0T-3vahesaDh57f-qv4FbG1SFAzDvT3rFhre6kFl282VsxV_pynwn_CdvF7fzH2q9NW1ZQHPH1pmdo=@protonmail.com> In-Reply-To: <5keA_aPvmCO5yBh_mBQ6Z5SwnnvEW0T-3vahesaDh57f-qv4FbG1SFAzDvT3rFhre6kFl282VsxV_pynwn_CdvF7fzH2q9NW1ZQHPH1pmdo=@protonmail.com> From: "Russell O'Connor" Date: Mon, 5 Jul 2021 13:20:22 -0400 Message-ID: To: ZmnSCPxj , Bitcoin Protocol Discussion Content-Type: multipart/alternative; boundary="000000000000df411705c6638560" Subject: Re: [bitcoin-dev] Unlimited covenants, was Re: CHECKSIGFROMSTACK/{Verify} BIP for Bitcoin X-BeenThere: bitcoin-dev@lists.linuxfoundation.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: Bitcoin Protocol Discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 05 Jul 2021 17:20:36 -0000 --000000000000df411705c6638560 Content-Type: text/plain; charset="UTF-8" Hi ZmnSCPxj, I don't believe we need to ban Turing completeness for the sake of banning Turing completeness. My concerns have always been around ensuring that transaction and block validation is not unduly burdensome for nodes. So for Bitcoin Script, we want to bound the amount of resources needed to execute it, preferably as a linear function of weight[1], and preferably have it clear what the evaluation costs are going to be prior to evaluation[2]. We also want to keep Script execution as a pure function of the transaction data so that nodes do not need to reevaluate their mempool on every new block. For consensus purposes we prefer to have simple primitive operations that have clear and precise semantics that are as likely as possible to be reimplemented correctly if they are reimplemented (or at least let us not make this problem worse than it already is). In particular, Script needs to be easy to parse to avoid weird parsing machines that lead to security vulnerabilities within node software. While the above design constraints imply a prohibition on Turing complete computation within a single Script, they do not imply a prohibition on arbitrary, covenant-enabled computations that spans across multiple transactions. Neither would these constraints prohibit some kind of STARK or SNARK tapleaf version that was somehow capable of succinctly representing arbitrary computations, so long as validation costs remain bounded. And while it is true that covenant-enabled computations could allow users to put their funds at risk through weird machines that manipulate their money on the blockchain, as longs as that weirdness stays at that level of the abstract Bitcoin Script machine, then I suppose it is *caveat emptor*; don't send your funds to random unverified Bitcoin Scripts, advice that is already the case today. We can keep that potential weirdness at bay by keeping Script simple, and maintaining our understanding that the Script programs (like the rest of the blockchain data) are untrusted inputs and they need to be validated and scrutinized before interpretation. [1] In tapscript I believe all operations are linear time with the exception of OP_ROLL. However OP_ROLL is still constrained by global limits on stack size, etc. [2] In Bitcoin Script, without loops of any kind, every opcode is evaluated at most once, so counting opcodes is an easy way to put an upper bound on your costs before evaluation. On Sun, Jul 4, 2021 at 8:51 PM ZmnSCPxj via bitcoin-dev < bitcoin-dev@lists.linuxfoundation.org> wrote: > Good morning Dave, > > > On Sun, Jul 04, 2021 at 11:39:44AM -0700, Jeremy wrote: > > > > > However, I think the broader community is unconvinced by the cost > benefit > > > of arbitrary covenants. See > > > > https://medium.com/block-digest-mempool/my-worries-about-too-generalized-covenants-5eff33affbb6 > > > as a recent example. Therefore as a critical part of building > consensus on > > > various techniques I've worked to emphasize that specific additions do > not > > > entail risk of accidentally introducing more than was bargained for to > > > respect the concerns of others. > > > > Respecting the concerns of others doesn't require lobotomizing useful > > tools. Being respectful can also be accomplished by politely showing > > that their concerns are unfounded (or at least less severe than they > > thought). This is almost always the better course IMO---it takes much > > more effort to satisfy additional engineering constraints (and prove to > > reviewers that you've done so!) than it does to simply discuss those > > concerns with reasonable stakeholders. As a demonstration, let's look > > at the concerns from Shinobi's post linked above: > > > > They seem to be worried that some Bitcoin users will choose to accept > > coins that can't subsequently be fungibily mixed with other bitcoins. > > But that's already been the case for a decade: users can accept altcoins > > that are non-fungible with bitcoins. > > > > They talk about covenants where spending is controlled by governments, > > but that seems to me exactly like China's CBDC trial. > > > > They talk about exchanges depositing users' BTC into a covenant, but > > that's just a variation on the classic not-your-keys-not-your-bitcoins > > problem. For all you know, your local exchange is keeping most of its > > BTC balance commitments in ETH or USDT. > > > > To me, it seems like the worst-case problems Shinobi describes with > > covenants are some of the same problems that already exist with > > altcoins. I don't see how recursive covenants could make any of those > > problems worse, and so I don't see any point in limiting Bitcoin's > > flexibility to avoid those problems when there are so many interesting > > and useful things that unlimited covenants could do. > > The "altcoins are even worse" argument does seem quite convincing, and if > Bitcoin can survive altcoins, surely it can survive covenants too? > > In before "turns out covenants are the next ICO". > i.e. ICOs are just colored coins, which are useful for keeping track of > various stuff, but have then been used as a vehicle to scam people. > But I suppose that is a problem that humans will always have: limited > cognition, so that *good* popular things that are outside your specific > field of study are indistinguishable from *bad* popular things. > So perhaps it should not be a concern on a technical level. > Maybe we should instead make articles about covenants so boring nobody > will hype about it (^^;)v. > > Increased functionality implies increased processing, and hopefully > computation devices are getting cheap enough that the increased processing > implied by new features should not be too onerous. > > > > To my mind, an "inescapable" covenant (i.e. one that requires the output > to be paid to the same covenant) is basically a Turing machine, and > equivalent to a `while (true);` loop. > In a `while (true);` loop, the state of the machine reverts back to the > same state, and it repeats again. > In an inescpable covenant, the control of some amount of funds reverts > back to the same controlling SCRIPT, and it repeats again. > Yes, you can certainly add more functionality on top of that loop, just > think of program main loops for games or daemons, which are, in essence, > "just" `while (true) ...`. > But basically, such unbounded infinite loops are possible only under > Turing machines, thus I consider covenants to be Turing-complete. > Principle of Least Power should make us wonder if we need full Turing > machines for the functionality. > > On the other hand --- codata processing *does* allow for unbounded loops, > without requiring full Turing-completeness; they just require total > functionality, not partial (and Turing-completeness is partial, not total). > Basically, data structures are unbounded storage, while codata structures > are unbounded processing. > Perhaps covenants can encode an upper bound on the number of recursions, > which prevents full Turing-completeness while allowing for a large number > of use-cases. > > (if the above paragraph makes no sense to you, hopefully this Wikipedia > article will help: > https://en.wikipedia.org/wiki/Total_functional_programming ) > (basically my argument here is based on academic programming stuff, and > might not actually matter in real life) > > Regards, > ZmnSCPxj > _______________________________________________ > bitcoin-dev mailing list > bitcoin-dev@lists.linuxfoundation.org > https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-dev > --000000000000df411705c6638560 Content-Type: text/html; charset="UTF-8" Content-Transfer-Encoding: quoted-printable
Hi ZmnSCPxj,

I don't bel= ieve we need to ban Turing completeness for the sake of banning Turing comp= leteness.=C2=A0 My concerns have always been around ensuring that transacti= on and block validation is not unduly burdensome for nodes.=C2=A0 So for Bi= tcoin Script, we want to bound the amount of resources needed to execute it= , preferably as a linear function of weight[1], and preferably have it clea= r what the evaluation costs are going to be prior to evaluation[2].=C2=A0 W= e also want to keep Script execution as a pure function of the transaction = data so that nodes do not need to reevaluate their mempool on every new blo= ck.=C2=A0 For consensus purposes we prefer to have simple primitive operati= ons that have clear and precise semantics that are as likely as possible to= be reimplemented correctly if they are reimplemented (or at least let us n= ot make this problem worse than it already is).=C2=A0 In particular, Script= needs to be easy to parse to avoid weird parsing machines that lead to sec= urity vulnerabilities within node software.

Wh= ile the above design constraints imply a prohibition on Turing complete com= putation within a single Script, they do not imply a prohibition on arbitra= ry, covenant-enabled computations that spans across multiple transactions.= =C2=A0 Neither would these constraints prohibit some kind of STARK or SNARK= tapleaf version that was somehow capable of succinctly representing arbitr= ary computations, so long as validation costs remain bounded.
And while it is true that covenant-enabled computations could a= llow users to put their funds at risk through weird machines that manipulat= e their money on the blockchain, as longs as that weirdness stays at that l= evel of the abstract Bitcoin Script machine, then I suppose it is caveat= emptor; don't send your funds to random unverified Bitcoin Scripts= , advice that is already the case today.=C2=A0 We can keep that potential w= eirdness at bay by keeping Script simple, and maintaining our understanding= that the Script programs (like the rest of the blockchain data) are untrus= ted inputs and they need to be validated and scrutinized before interpretat= ion.

[1] In tapscript I believe all operations= are linear time with the exception of OP_ROLL.=C2=A0 However OP_ROLL is st= ill constrained by global limits on stack size, etc.
[2] In Bitco= in Script, without loops of any kind, every opcode is evaluated at most onc= e, so counting opcodes is an easy way to put an upper bound on your costs b= efore evaluation.

On Sun, Jul 4, 2021 at 8:51 PM ZmnSCPxj via bitcoin-de= v <bitcoin-dev@= lists.linuxfoundation.org> wrote:
Good morning Dave,

> On Sun, Jul 04, 2021 at 11:39:44AM -0700, Jeremy wrote:
>
> > However, I think the broader community is unconvinced by the cost= benefit
> > of arbitrary covenants. See
> > https://medium.com/block-digest-mempool/my-worries-about-too-generaliz= ed-covenants-5eff33affbb6
> > as a recent example. Therefore as a critical part of building con= sensus on
> > various techniques I've worked to emphasize that specific add= itions do not
> > entail risk of accidentally introducing more than was bargained f= or to
> > respect the concerns of others.
>
> Respecting the concerns of others doesn't require lobotomizing use= ful
> tools. Being respectful can also be accomplished by politely showing > that their concerns are unfounded (or at least less severe than they > thought). This is almost always the better course IMO---it takes much<= br> > more effort to satisfy additional engineering constraints (and prove t= o
> reviewers that you've done so!) than it does to simply discuss tho= se
> concerns with reasonable stakeholders. As a demonstration, let's l= ook
> at the concerns from Shinobi's post linked above:
>
> They seem to be worried that some Bitcoin users will choose to accept<= br> > coins that can't subsequently be fungibily mixed with other bitcoi= ns.
> But that's already been the case for a decade: users can accept al= tcoins
> that are non-fungible with bitcoins.
>
> They talk about covenants where spending is controlled by governments,=
> but that seems to me exactly like China's CBDC trial.
>
> They talk about exchanges depositing users' BTC into a covenant, b= ut
> that's just a variation on the classic not-your-keys-not-your-bitc= oins
> problem. For all you know, your local exchange is keeping most of its<= br> > BTC balance commitments in ETH or USDT.
>
> To me, it seems like the worst-case problems Shinobi describes with > covenants are some of the same problems that already exist with
> altcoins. I don't see how recursive covenants could make any of th= ose
> problems worse, and so I don't see any point in limiting Bitcoin&#= 39;s
> flexibility to avoid those problems when there are so many interesting=
> and useful things that unlimited covenants could do.

The "altcoins are even worse" argument does seem quite convincing= , and if Bitcoin can survive altcoins, surely it can survive covenants too?=

In before "turns out covenants are the next ICO".
i.e. ICOs are just colored coins, which are useful for keeping track of var= ious stuff, but have then been used as a vehicle to scam people.
But I suppose that is a problem that humans will always have: limited cogni= tion, so that *good* popular things that are outside your specific field of= study are indistinguishable from *bad* popular things.
So perhaps it should not be a concern on a technical level.
Maybe we should instead make articles about covenants so boring nobody will= hype about it (^^;)v.

Increased functionality implies increased processing, and hopefully computa= tion devices are getting cheap enough that the increased processing implied= by new features should not be too onerous.



To my mind, an "inescapable" covenant (i.e. one that requires the= output to be paid to the same covenant) is basically a Turing machine, and= equivalent to a `while (true);` loop.
In a `while (true);` loop, the state of the machine reverts back to the sam= e state, and it repeats again.
In an inescpable covenant, the control of some amount of funds reverts back= to the same controlling SCRIPT, and it repeats again.
Yes, you can certainly add more functionality on top of that loop, just thi= nk of program main loops for games or daemons, which are, in essence, "= ;just" `while (true) ...`.
But basically, such unbounded infinite loops are possible only under Turing= machines, thus I consider covenants to be Turing-complete.
Principle of Least Power should make us wonder if we need full Turing machi= nes for the functionality.

On the other hand --- codata processing *does* allow for unbounded loops, w= ithout requiring full Turing-completeness; they just require total function= ality, not partial (and Turing-completeness is partial, not total).
Basically, data structures are unbounded storage, while codata structures a= re unbounded processing.
Perhaps covenants can encode an upper bound on the number of recursions, wh= ich prevents full Turing-completeness while allowing for a large number of = use-cases.

(if the above paragraph makes no sense to you, hopefully this Wikipedia art= icle will help: https://en.wikipedia.org/w= iki/Total_functional_programming )
(basically my argument here is based on academic programming stuff, and mig= ht not actually matter in real life)

Regards,
ZmnSCPxj
_______________________________________________
bitcoin-dev mailing list
= bitcoin-dev@lists.linuxfoundation.org
https://lists.linuxfoundation.org/mail= man/listinfo/bitcoin-dev
--000000000000df411705c6638560--