From f66bf79bff6bf0d93ced5d727b6a0d6aeed1b4f6 Mon Sep 17 00:00:00 2001 From: Ignacio Hagopian Date: Tue, 24 Oct 2023 16:36:58 -0300 Subject: [PATCH 1/3] update proof generation Signed-off-by: Ignacio Hagopian --- core/state_processor_test.go | 2 +- go.mod | 2 +- go.sum | 4 ++-- trie/verkle.go | 29 +++++++++++++---------------- 4 files changed, 17 insertions(+), 20 deletions(-) diff --git a/core/state_processor_test.go b/core/state_processor_test.go index 6cdb2e9a4f33..8ed660a5042e 100644 --- a/core/state_processor_test.go +++ b/core/state_processor_test.go @@ -518,7 +518,7 @@ func TestProcessVerkle(t *testing.T) { //f.Write(buf.Bytes()) //fmt.Printf("root= %x\n", chain[0].Root()) // check the proof for the last block - err := trie.DeserializeAndVerifyVerkleProof(proofs[1], chain[0].Root().Bytes(), keyvals[1]) + err := trie.DeserializeAndVerifyVerkleProof(proofs[1], chain[0].Root().Bytes(), chain[1].Root().Bytes(), keyvals[1]) if err != nil { t.Fatal(err) } diff --git a/go.mod b/go.mod index bb1e8dc0027b..7888ae6d4f3c 100644 --- a/go.mod +++ b/go.mod @@ -26,7 +26,7 @@ require ( github.com/fjl/memsize v0.0.0-20190710130421-bcb5799ab5e5 github.com/fsnotify/fsnotify v1.6.0 github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff - github.com/gballet/go-verkle v0.1.1-0.20231020124853-d124d1998b1a + github.com/gballet/go-verkle v0.1.1-0.20231024193227-1127148c02ea github.com/go-stack/stack v1.8.1 github.com/gofrs/flock v0.8.1 github.com/golang-jwt/jwt/v4 v4.3.0 diff --git a/go.sum b/go.sum index 4a9016a0b5b9..68de2d14a032 100644 --- a/go.sum +++ b/go.sum @@ -144,8 +144,8 @@ github.com/garslo/gogen v0.0.0-20170306192744-1d203ffc1f61/go.mod h1:Q0X6pkwTILD github.com/gavv/httpexpect v2.0.0+incompatible/go.mod h1:x+9tiU1YnrOvnB725RkpoLv1M62hOWzwo5OXotisrKc= github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff h1:tY80oXqGNY4FhTFhk+o9oFHGINQ/+vhlm8HFzi6znCI= github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff/go.mod h1:x7DCsMOv1taUwEWCzT4cmDeAkigA5/QCwUodaVOe8Ww= -github.com/gballet/go-verkle v0.1.1-0.20231020124853-d124d1998b1a h1:kqhR2nTIep0lw7zJBp2ju+fWbqP3PojUw3L+jv1qBK4= -github.com/gballet/go-verkle v0.1.1-0.20231020124853-d124d1998b1a/go.mod h1:7JamHhSTnnHDhcI3G8r4sWaD9XlleriqVlC3FeAQJKM= +github.com/gballet/go-verkle v0.1.1-0.20231024193227-1127148c02ea h1:KCYUHLdBxifnVeuqSGpG9OV+kWguN742PlpXHY1Zw/Q= +github.com/gballet/go-verkle v0.1.1-0.20231024193227-1127148c02ea/go.mod h1:7JamHhSTnnHDhcI3G8r4sWaD9XlleriqVlC3FeAQJKM= github.com/getkin/kin-openapi v0.53.0/go.mod h1:7Yn5whZr5kJi6t+kShccXS8ae1APpYTW6yheSwk8Yi4= github.com/getkin/kin-openapi v0.61.0/go.mod h1:7Yn5whZr5kJi6t+kShccXS8ae1APpYTW6yheSwk8Yi4= github.com/getsentry/sentry-go v0.12.0/go.mod h1:NSap0JBYWzHND8oMbyi0+XZhUalc1TBdRL1M71JZW2c= diff --git a/trie/verkle.go b/trie/verkle.go index d0a914fde87b..f9b6afc5876a 100644 --- a/trie/verkle.go +++ b/trie/verkle.go @@ -336,27 +336,16 @@ func ProveAndSerialize(pretrie, posttrie *VerkleTrie, keys [][]byte, resolver ve return p, kvps, nil } -type set = map[string]struct{} - -func addKey(s set, key []byte) { - s[string(key)] = struct{}{} -} - -func DeserializeAndVerifyVerkleProof(vp *verkle.VerkleProof, root []byte, statediff verkle.StateDiff) error { - rootC := new(verkle.Point) - rootC.SetBytes(root) - - var others set = set{} // Mark when an "other" stem has been seen +func DeserializeAndVerifyVerkleProof(vp *verkle.VerkleProof, preStateRoot []byte, postStateRoot []byte, statediff verkle.StateDiff) error { + // TODO: check that `others` have expected length and values. proof, err := verkle.DeserializeProof(vp, statediff) if err != nil { return fmt.Errorf("verkle proof deserialization error: %w", err) } - for _, stem := range proof.PoaStems { - addKey(others, stem) - } - + rootC := new(verkle.Point) + rootC.SetBytes(preStateRoot) pretree, err := verkle.PreStateTreeFromProof(proof, rootC) if err != nil { return fmt.Errorf("error rebuilding the pre-tree from proof: %w", err) @@ -385,12 +374,20 @@ func DeserializeAndVerifyVerkleProof(vp *verkle.VerkleProof, root []byte, stated } } + // TODO: this is necessary to verify that the post-values are the correct ones. + // But all this can be avoided with a even faster way. The EVM block execution can + // keep track of the written keys, and compare that list with this post-values list. + // This can avoid regenerating the post-tree which is somewhat expensive. posttree, err := verkle.PostStateTreeFromStateDiff(pretree, statediff) if err != nil { return fmt.Errorf("error rebuilding the post-tree from proof: %w", err) } + regeneratedPostTreeRoot := posttree.Commitment().Bytes() + if !bytes.Equal(regeneratedPostTreeRoot[:], postStateRoot) { + return fmt.Errorf("post tree root mismatch: %x != %x", regeneratedPostTreeRoot, postStateRoot) + } - return verkle.VerifyVerkleProofWithPreAndPostTrie(proof, pretree, posttree) + return verkle.VerifyVerkleProofWithPreState(proof, pretree) } // ChunkedCode represents a sequence of 32-bytes chunks of code (31 bytes of which From ac60a21d14634bb8a23e80ff828e82d6466a3156 Mon Sep 17 00:00:00 2001 From: Ignacio Hagopian Date: Tue, 24 Oct 2023 18:48:30 -0300 Subject: [PATCH 2/3] simplification and comment Signed-off-by: Ignacio Hagopian --- consensus/beacon/consensus.go | 17 ----------------- trie/verkle.go | 2 +- 2 files changed, 1 insertion(+), 18 deletions(-) diff --git a/consensus/beacon/consensus.go b/consensus/beacon/consensus.go index 4627b4d837bc..2ca701c42f56 100644 --- a/consensus/beacon/consensus.go +++ b/consensus/beacon/consensus.go @@ -426,23 +426,6 @@ func (beacon *Beacon) FinalizeAndAssemble(chain consensus.ChainHeaderReader, hea panic("invalid tree type") } if okpre && okpost { - // TODO: see if this can be captured at the witness - // level, like it used to. - for _, key := range keys { - // WORKAROUND: the post trie would normally not - // need to be searched for keys, as all of them - // were resolved during block execution. - // But since the prefetcher isn't currently used - // with verkle, the values that are read but not - // written to, are not resolved as they are read - // straight from the snapshot. They must be read - // in order to build the proof. - _, err = vtrpost.GetWithHashedKey(key) - if err != nil { - panic(err) - } - } - if len(keys) > 0 { p, k, err = trie.ProveAndSerialize(vtrpre, vtrpost, keys, vtrpre.FlatdbNodeResolver) if err != nil { diff --git a/trie/verkle.go b/trie/verkle.go index f9b6afc5876a..748464ecdd56 100644 --- a/trie/verkle.go +++ b/trie/verkle.go @@ -337,7 +337,7 @@ func ProveAndSerialize(pretrie, posttrie *VerkleTrie, keys [][]byte, resolver ve } func DeserializeAndVerifyVerkleProof(vp *verkle.VerkleProof, preStateRoot []byte, postStateRoot []byte, statediff verkle.StateDiff) error { - // TODO: check that `others` have expected length and values. + // TODO: check that `OtherStems` have expected length and values. proof, err := verkle.DeserializeProof(vp, statediff) if err != nil { From ec187bda394a0c421e8d578a9673547458bc6fc1 Mon Sep 17 00:00:00 2001 From: Ignacio Hagopian Date: Wed, 25 Oct 2023 12:59:03 -0300 Subject: [PATCH 3/3] update go-verkle Signed-off-by: Ignacio Hagopian --- go.mod | 4 ++-- go.sum | 8 ++++---- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/go.mod b/go.mod index 7888ae6d4f3c..25fb4e4ae0f7 100644 --- a/go.mod +++ b/go.mod @@ -14,7 +14,7 @@ require ( github.com/cloudflare/cloudflare-go v0.14.0 github.com/cockroachdb/pebble v0.0.0-20230209160836-829675f94811 github.com/consensys/gnark-crypto v0.12.1 - github.com/crate-crypto/go-ipa v0.0.0-20231015184653-ceac2650f699 + github.com/crate-crypto/go-ipa v0.0.0-20231025140028-3c0104f4b233 github.com/crate-crypto/go-kzg-4844 v0.3.0 github.com/davecgh/go-spew v1.1.1 github.com/deckarep/golang-set/v2 v2.1.0 @@ -26,7 +26,7 @@ require ( github.com/fjl/memsize v0.0.0-20190710130421-bcb5799ab5e5 github.com/fsnotify/fsnotify v1.6.0 github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff - github.com/gballet/go-verkle v0.1.1-0.20231024193227-1127148c02ea + github.com/gballet/go-verkle v0.1.1-0.20231025151349-87337dd2894a github.com/go-stack/stack v1.8.1 github.com/gofrs/flock v0.8.1 github.com/golang-jwt/jwt/v4 v4.3.0 diff --git a/go.sum b/go.sum index 68de2d14a032..5d3e1567d16a 100644 --- a/go.sum +++ b/go.sum @@ -84,8 +84,8 @@ github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwc github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= github.com/cpuguy83/go-md2man/v2 v2.0.2 h1:p1EgwI/C7NhT0JmVkwCD2ZBK8j4aeHQX2pMHHBfMQ6w= github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= -github.com/crate-crypto/go-ipa v0.0.0-20231015184653-ceac2650f699 h1:ng/jln5iPr92iLbq6dHHa5dbObAgUmAoQO7Zjx1vYHM= -github.com/crate-crypto/go-ipa v0.0.0-20231015184653-ceac2650f699/go.mod h1:J+gsi6D4peY0kyhaklyXFRVHOQWI2I5uU0c2+/90HYc= +github.com/crate-crypto/go-ipa v0.0.0-20231025140028-3c0104f4b233 h1:d28BXYi+wUpz1KBmiF9bWrjEMacUEREV6MBi2ODnrfQ= +github.com/crate-crypto/go-ipa v0.0.0-20231025140028-3c0104f4b233/go.mod h1:geZJZH3SzKCqnz5VT0q/DyIG/tvu/dZk+VIfXicupJs= github.com/crate-crypto/go-kzg-4844 v0.3.0 h1:UBlWE0CgyFqqzTI+IFyCzA7A3Zw4iip6uzRv5NIXG0A= github.com/crate-crypto/go-kzg-4844 v0.3.0/go.mod h1:SBP7ikXEgDnUPONgm33HtuDZEDtWa3L4QtN1ocJSEQ4= github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= @@ -144,8 +144,8 @@ github.com/garslo/gogen v0.0.0-20170306192744-1d203ffc1f61/go.mod h1:Q0X6pkwTILD github.com/gavv/httpexpect v2.0.0+incompatible/go.mod h1:x+9tiU1YnrOvnB725RkpoLv1M62hOWzwo5OXotisrKc= github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff h1:tY80oXqGNY4FhTFhk+o9oFHGINQ/+vhlm8HFzi6znCI= github.com/gballet/go-libpcsclite v0.0.0-20190607065134-2772fd86a8ff/go.mod h1:x7DCsMOv1taUwEWCzT4cmDeAkigA5/QCwUodaVOe8Ww= -github.com/gballet/go-verkle v0.1.1-0.20231024193227-1127148c02ea h1:KCYUHLdBxifnVeuqSGpG9OV+kWguN742PlpXHY1Zw/Q= -github.com/gballet/go-verkle v0.1.1-0.20231024193227-1127148c02ea/go.mod h1:7JamHhSTnnHDhcI3G8r4sWaD9XlleriqVlC3FeAQJKM= +github.com/gballet/go-verkle v0.1.1-0.20231025151349-87337dd2894a h1:UV5Et3Ab62e6hQ6vDZC0h0i9hmKm8KKtV78zDOzud08= +github.com/gballet/go-verkle v0.1.1-0.20231025151349-87337dd2894a/go.mod h1:QNpY22eby74jVhqH4WhDLDwxc/vqsern6pW+u2kbkpc= github.com/getkin/kin-openapi v0.53.0/go.mod h1:7Yn5whZr5kJi6t+kShccXS8ae1APpYTW6yheSwk8Yi4= github.com/getkin/kin-openapi v0.61.0/go.mod h1:7Yn5whZr5kJi6t+kShccXS8ae1APpYTW6yheSwk8Yi4= github.com/getsentry/sentry-go v0.12.0/go.mod h1:NSap0JBYWzHND8oMbyi0+XZhUalc1TBdRL1M71JZW2c=