Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Proposal for supporting Blake2b #2024
Proposal for supporting Blake2b #2024
Changes from 50 commits
230647f
585958c
ae2a9ef
2fed08b
9044f99
57f2504
1649ded
bb26ea7
ebea49b
9c45bf9
f33bbe1
34f649e
10004d4
00da725
8e59a8d
5798cb7
db85771
f4e2fd8
2d4ea31
e8117c6
0afe99a
240cabc
39f7c3f
6003de7
ef115c1
36a7845
ef02974
0d659c3
7354cb4
601cc35
46babcb
c260a55
f592757
ebe1d11
719318b
072efb9
e403a10
e774c44
b4fcd68
3671f14
5e745da
9258414
8613c50
ceaa653
5fa430f
e79b430
285c6f7
53dfa16
90d9ce6
9ac83ee
9d73b0b
9f5008e
0ec6181
b55bd38
a1ff047
495062d
9ed4e96
5e6d488
433a6ce
af982f1
0fb666b
b1dd057
6f35f9f
c2eca1e
27b24eb
6894462
fe44e99
9531351
6366821
2015ea3
d428749
7c10d58
36d2992
0755e0c
f417718
d6dfa55
ae59591
f993edd
d2aa4ae
5996a13
4fe5a9a
ea827e8
656aeda
cef55f5
d7db470
ae038c8
dbf67d4
e8098d2
fdf8508
1f7987f
8b8d2ea
e2f9ace
734934e
fc56b06
3f181cb
a573835
9af2a9b
4b676ff
9fa08d1
69217d8
ae0c0d8
9b1c22d
638b740
32b82ef
622136a
96e8093
186c1db
9084f86
5b3345b
550fb10
5b60eb6
36f02df
f1df387
5a0665c
9a35c0a
e3c2db1
95dfa34
296ba62
7b6925e
193fdeb
914c3ba
4694622
c873524
083129d
9457546
63a04a1
4f239f0
d95612c
db441bb
9691bd6
4ea97fa
39d47ef
89a8794
843d377
3bcce1d
c3f4c68
92916e1
764ff73
15c3352
552e602
5a29338
5d203c4
ad01be2
02568c4
487aea3
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not fully sure this summary reflects this EIP. This EIP will not cause ZEC to be implemented. This block seems to be make more sense as part of the "Motivation" section.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So what is currently required for Equihash verification?
480000 + 90 * (2**7 * 128)
which is ~2M gas?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe you're misreading. The verification cost for Equihash is
2**k
invocations of the hash function (and2**k
XORs), which would make the gas requirement greater than480,000 * 2 ** k
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure why are you writing
2**7
. The128
looks much less scary.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
k
is a parameter, so we write2**k
. Zcash uses Equihash withk = 9
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You really starts annoying me. If ZCash uses
k = 9
WHY have you written its from 5 to 7?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Instead of shifts your linked blake2 implementation uses exponentiation which is (extremely) expensive.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You're talking about Zac Williams .huff implementation here mentioned by @cdetrio here. Can we say Zac's code is the best smart contract implementation with the current EVM we're going to see and use that for @cdetrio's benchmark? Zac got it to 6,821,545 gas with pre-Istanbul EVM.
In Eth-wizards Zac suggested an equihash could get as low as 70k gas with an engine like @chfast's evmone. If James/Matt are saying they can provide a precompile that matches or beats Zac's estimate, that's what we want to see, right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think its an unreasonable ask. This was done for the ECMUL/ECPAIRING precompiles before Byzantium (including an example solidity contract that used the ECPAIRING precompile to verify a snark proof that came from a zcash tx).
Yes, Zac said there probably isn't much room left for optimizing the huff implementation (I believe him). What isn't fully clear (to me) is whether the 6.8 million gas number is sufficient to verify a zcash block. And if it is, why is 245 million cited above instead. What's annoying is to see people going around in circles here and on ACD calls with napkin math. Would be good if some champion could just write the solidity code to verify a zcash block or whatever the usecase for the precompile is (again, like was done for the snark precompiles).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We're working on it- our team has focused on the
F
precompile first considering where that discussion went. I'll have an EIP PR forF
out today where we link to our initial implementation, then we'll circle back hereThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed, there will be benchmarks- first take will be for gas estimation of
F
, then another forblake2b
. Full Zcash header verification is a stretch though we'll see what we can do.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I had a comment for this in the previous PR: #131
However my general comment is that this section is ambiguous.
Is that array a byte array? Is
OUTSIZE
a single byte (uint8)? Does that meanINSIZE
is the length of input and the first byte of the input is considered asOUTSIZE
while the rest is the actual input to hash?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you just clarify this as:
Function accepts a variable length input interpreted as an array of bytes:
[OUTSIZE, D1, D2, ..., DINSIZE]
where
INSIZE
is the length in bytes of the input. Throws if the value ofOUTSIZE
is greater than 64.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This also is correct.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If
INSIZE
includes the configuration parameter of output hash size (OUTSIZE
) shouldn't this calculation be Gblakebase + Gblakeword + floor((INSIZE - 1) / 32)?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, this correct.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should gas depend on the value of
OUTSIZE
?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We are digging further into this, and we are not sure yet. We found a golang library for blake2b and are going to do some benchmarking on it. I'll update the specification to say TBD based on benchmarking. https://github.com/golang/crypto/tree/master/blake2b