Skip to content
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

Ethereum Core Devs Meeting 109 Agenda #289

Closed
timbeiko opened this issue Mar 29, 2021 · 17 comments
Closed

Ethereum Core Devs Meeting 109 Agenda #289

timbeiko opened this issue Mar 29, 2021 · 17 comments

Comments

@timbeiko
Copy link
Collaborator

timbeiko commented Mar 29, 2021

ACD 109: April 2, 2021

Note, with DST ending, the meeting time may be different in your region. Please double-check the meeting time in the section below. UTC time does not "move".

Meeting Info

Agenda

  1. Berlin Updates
  2. London Updates
    • Client implementation updates
  3. Shanghai & The Merge Proposals:
    • Shanghai delayed with focus on merge #278
      • "Merge sprint" from mid-April to mid-May
    • Shanghai in October (no merge) #267
  4. EIP Discussions
    1. EIP-3403 - Partial Removal of Refunds #277
    2. BASE FEE Opcode #270
    3. EIP-3074 - AUTH and AUTHCALL opcodes #260
    4. EIP-2537 - Precompile for BLS12-381 curve operations #269
    5. EIP-2327 - BEGINDATA #262
    6. EIP-2677 - Limit size of initcode #271
    7. EIP-2935 - Save historical block hashes in state #279
    8. [Aleady in London] EIP-3238 - Difficulty Bomb #256
      • Need to agree on pushback period
  5. [Announcement] EVM working group For 109 agenda: EVM working group #292
@timbeiko
Copy link
Collaborator Author

(example comment):

I would like to discuss XYZ on this call, more information can be found in issue #999

@timbeiko
Copy link
Collaborator Author

Removed EIP-3322 from the agenda because it was agreed on ACD 108 not to include in London. See #266 (comment)

@evertonfraga
Copy link
Member

Berlin is out of the door for most testnets right now. Could we aim to move EIPs 2930 and 2929 from Preview to Last Call and then Final?

@timbeiko
Copy link
Collaborator Author

@evertonfraga good point! @holiman @MicahZoltu could you please move EIPs 2718, 2929 and 2930 to Last Call? We should move them to Final in the call after.

@gcolvin
Copy link

gcolvin commented Apr 1, 2021

@timbeiko Whether it comes before or after the merge, I think a clear candidate for a future "feature" fork is to pull together our outstanding EVM proposals into a coherent whole.

I've re-opened an EVM group on the Magician's as a place to start on these and others.

@jochem-brouwer

This comment has been minimized.

@CryptoBlockchainTechnologies
Copy link

CryptoBlockchainTechnologies commented Apr 1, 2021

The same thing is also caused by for instance EIP1559, which had an old reference implementation based upon a much older spec in it for a long time.

Why does the EIP not have a security process?

I agree. 1559 presents a huge security risk due to the major changes in base fees calculations and burning. The later has never been done before for any crypto currency. I found the admission in the EIP alarming that they have no idea what impact fee burning will have. I would have expected at least two seperate audits before 1559 was accepted since there are different security risks associated with those two.

1559 lists four securiry concerns, none of which had formal audits, why? Also it may help to understand the guidelines (not sure there are any) if we can list EIPs that have been audited before in the past and why? I will start the list:

  • 1057 - Not sure why it had to be audited but it was
  • I am sure there are others someone help me here

@holiman
Copy link

holiman commented Apr 1, 2021

Why does the EIP not have a security process?

EIPs have a security section. It's expected that EIPs are vetted in various discussion forums, and the implementations vetted, tested, audited, just like every single thing that ever touches how clients reach consensus.

Take EIP2929 for instance, these access lists could maybe lead to some very sophisticated behavior where an attacker can use the gas used after a message call to determine if a slot was already accessed in a prior call or not (I can't think of a case where this would be useful, but EIP2929 leaks some info on touched storage slots by the gas schedule, based upon if the slot was on the warm slots or not).

Yes. So do you think that behaviour is worse, from a security perspective, than the unbounded state growth which is a clear and present DoS vector against all nodes on the network? And if so, how come you have not raised this in the discussion-forums, or ACD channel or call?

I find it also disturbing to know that the YoloV3 testnet to test Berlin hardfork on did not include any EIP2315 (subroutines) transactions

2315 was fuzzed quite a lot. It was also again fuzzed in the first testnet. The idea behind the feature-testnets was to test the features, yolov3 focused on 2930 and 2929, which were new. We didn't focus on the non-features. I think the amount of people who actually sent transactions on yolov3 can be counted on one hand. With fingers to spare.

In general I think we should move to a much more secure EIP process, where there are several stages of security considerations and upgrades in terms of testing (first some basic tests, then when two clients think they are OK, implement ethereum/tests, and also audit these tests to ensure that they cover each case).

Does that mean "the geth team should set up more testnets, and the test-team should work harder", or does it mean "we'll take more responsibility for cross-client testing going forward".

Sorry if I sound angry, I felt a bit personally attacked here, and I probably should have not responded right now. It's a bit annoying that when we do find issues, it's more or less "ok, thanks, fixed, let's move on", while when something slips through it's a lot of high and mighty outrage about "the process".

@timbeiko
Copy link
Collaborator Author

timbeiko commented Apr 1, 2021

A few more comments:

Why are these EIPs not on the right status? This looks kind of sloppy to me and signals that there either is no management or there is no interest to keep these EIPs updated.

The challenge here is that EIP authors are the only people who can update their EIPs, so there is a limit to what "management" can do.

take EIP1559 for instance, a few transactions together with their expected signatures and hashes would already be a great help to implement these

Those tests are not written yet, and they typically are done later in the upgrade process. We are about to work on them, and I had planned to ask about them on tomorrow's call.

@vbuterin
Copy link
Collaborator

vbuterin commented Apr 1, 2021

I agree. 1559 presents a huge security risk due to the major changes in base fees calculations and burning. The later has never been done before for any crypto currency.

It's worth noting that there has been unprecedentedly extensive economic review and audits on EIP 1559's economics, including concerns about the consequences of burning (this is of course separate from the question of whether the code correctly implements the economics, but that's not a bigger problem for this EIP than for any other). This all happened throughout 2019 and 2020. So I don't see any good reason to reopen that can of worms. Technical tests of the spec/code should of course be done as with any EIP.

@vbuterin
Copy link
Collaborator

vbuterin commented Apr 1, 2021

EIP-2935 - Save historical block hashes in state #279

On this topic, one thing to keep in mind is that with an accelerated merge this is probably not worth it, because the beacon chain already stores historical beacon roots in the beacon state, and so the first post-merge fork that adds a BEACONBLOCKROOT opcode can easily provide similar functionality.

@CryptoBlockchainTechnologies
Copy link

CryptoBlockchainTechnologies commented Apr 1, 2021

It's worth noting that there has been unprecedentedly extensive economic review and audits on EIP 1559's economics, including concerns about the consequences of burning (this is of course separate from the question of whether the code correctly implements the economics, but that's not a bigger problem for this EIP than for any other). This all happened throughout 2019 and 2020

I am not aware of any formal audits done for 1559 by third party independant agencies and where the funding came from. Can you elaborate more, perhaps provide some links to the formal audit reports and shed some light on the third party auditors and who funded the audits?

When I did a google search for Ethereum audits I came up with this for 1057, could not find anything on 1559. https://leastauthority.com/static/publications/LeastAuthority-ProgPow-Algorithm-Final-Audit-Report.pdf

Can you provide a likewise audit of 1559?

I also found 2.0 has been audited so that makes two audits that I know of, well actually only one for Eth 1.0
https://leastauthority.com/static/publications/LeastAuthority-Ethereum-2.0-Specifications-Audit-Report.pdf

Found this on Discord 1559-fee-market
image

Perhaps Micah has a great point. This is where the distrust of miners and the EIP process began and continues to this day with 1559 being implemented without the same dick move requiring an audit, using Micah's elegant words
image

It also seems there was money allocated for a formal audit from the grant @timbeiko was this ever done?
image

.

@jochem-brouwer
Copy link
Member

@holiman I am sorry that you felt personally attacked. The goal of the raising this point was to create a safer ecosystem and not to (indirectly) attack people. You are absolutely right, I should not have raised this issue here and instead asked questions elsewhere like allcoredevs. I also seem to lack a lot of knowledge of what is going on to increase security. Sorry for being so ignorant, and sorry for making you feel bad. I have retracted my post.

@timbeiko
Copy link
Collaborator Author

timbeiko commented Apr 2, 2021

@CryptoBlockchainTechnologies if you have concerns w.r.t. 1559, please share them on the EIP's "discussions-to" link. Quick FYI: not all EIPs have technical audits. 1559's biggest change was economic, not technical, and there was a 50 page paper analyzing it: https://timroughgarden.org/papers/eip1559.pdf

We also ran extensive client testing to assess its impact, and have built several testnets (and will do more, along with reference tests) to check consensus between clients.

@CryptoBlockchainTechnologies
Copy link

CryptoBlockchainTechnologies commented Apr 2, 2021

@CryptoBlockchainTechnologies if you have concerns w.r.t. 1559, please share them on the EIP's "discussions-to" link. Quick FYI: not all EIPs have technical audits. 1559's biggest change was economic, not technical, and there was a 50 page paper analyzing it: https://timroughgarden.org/papers/eip1559.pdf

We also ran extensive client testing to assess its impact, and have built several testnets (and will do more, along with reference tests) to check consensus between clients.

I was asking questions in response to Vitalik's comment and in fact agreed with Micah and filled in some of the questions myself. Thanks for the update also. I do agree with the OP that the ACD needs to come up with governance rules on when an audit is required and what type of EIP would require this.

@timbeiko
Copy link
Collaborator Author

timbeiko commented Apr 2, 2021

Closed in favor of #293

@timbeiko timbeiko closed this as completed Apr 2, 2021
@eteryko
Copy link

eteryko commented Aug 11, 2021

ACD 109: April 2, 2021

Note, with DST ending, the meeting time may be different in your region. Please double-check the meeting time in the section below. UTC time does not "move".

Meeting Info

Agenda

  1. Berlin Updates

  2. London Updates

    • Client implementation updates
  3. Shanghai & The Merge Proposals:

    • Shanghai delayed with focus on merge #278

      • "Merge sprint" from mid-April to mid-May
    • Shanghai in October (no merge) #267

  4. EIP Discussions

    1. EIP-3403 - Partial Removal of Refunds #277

    2. BASE FEE Opcode #270

    3. EIP-3074 - AUTH and AUTHCALL opcodes #260

    4. EIP-2537 - Precompile for BLS12-381 curve operations #269

    5. EIP-2327 - BEGINDATA #262

    6. EIP-2677 - Limit size of initcode #271

    7. EIP-2935 - Save historical block hashes in state #279

    8. [Aleady in London] EIP-3238 - Difficulty Bomb #256

      • Need to agree on pushback period
  5. [Announcement] EVM working group For 109 agenda: EVM working group #292

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants