-
Notifications
You must be signed in to change notification settings - Fork 39
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
fix: BlockCapturer for Created Accounts #1291
fix: BlockCapturer for Created Accounts #1291
Conversation
The block capturer had an issue capturing accounts which were created during the execution of the conflation being captured. The problematic scenario required an account to exist at the beginning of the conflation, but which was then the subject of a CREATE/CREATE2 contract creation. This is permitted in certain situations, such as when the account only has a balance (but no storage). To resolve this case, we have to be a little more careful when creating storage snapshots. Specifically, when an account only partially exists (i.e. has no storage, but only a balance) then we never create storage snapshots. Finally, this also adds a debugging mode to ReplayExecutionEnvironment to assist debugging the BlockCapturer.
arithmetization/src/main/java/net/consensys/linea/blockcapture/snapshots/StorageSnapshot.java
Show resolved
Hide resolved
// for accounts which are created *during* the conflation. Such accounts may have technically | ||
// existed before the conflation (e.g. they had a non-zero balance) but could still have been | ||
// "created" during the conflation. In such case, this snapshot would be simply assigning 0x0 | ||
// to the given storage locations. However, we don't want to create a storage snapshot in such |
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.
Does taking a storage snapshot insert a storage value ?
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.
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.
Also, at least according to the current EYP
Yeah, but at the end of the day, we are not measuring against the EYP. We are comparing against execution on MAINNET using BESU. What I'm looking at is what BESU does. If that deviates from the EYP ... well, we still have to follow BESU.
However, I agree that it does seem wierd and I can follow up with BESU to see why they do it that way (or even it could be a bug).
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.
Does taking a storage snapshot insert a storage value ?
Yes, in the replay environment it does. See ReplayExecutionEnvironment.initWorld()
. One option might be to drop StorageSnapshots
which assign 0x0
at the beginning of the conflation. It has the same effect. Maybe you prefer this?
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.
But does taking a storage snapshot change the world state ? If so that is a massive problem.
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.
In any case we do want to define storage snapshots even if the target account has empty storage or doesn't even exist yet. Simply because it's possible in Ethereum and we will want to test that, see #1205, but it should be side-effect free
} | ||
} | ||
|
||
private static boolean accountExists(final Account account) { |
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.
AFAIU the EYP defines for an account
-
existence
as existence in the state, i.e.$\sigma[a] \neq \varnothing$ -
EMPTY
as having nontrivial nonce, balance or code -
DEAD
as either not existing or being empty - prohibited from being deployed at as existing and either having nontrivial nonce, code or storage
data:image/s3,"s3://crabby-images/6f200/6f200a8a87cf4e238b3e77ddc0857e5908ffc16c" alt="image"
data:image/s3,"s3://crabby-images/4e9e2/4e9e28ce0f3b65aadca468a45d4c850a796438e5" alt="image"
along with EIP-7610
So maybe a more accurate name would be accountMayNotBeDeployedAt
/ deploymentIsProhibitedAt
or so.
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.
LGTM though there were parts where I'm not sure what's going on (e.g. the executeFrom
)
The block capturer had an issue capturing accounts which were created during the execution of the conflation being captured. The problematic scenario required an account to exist at the beginning of the conflation, but which was then the subject of a CREATE/CREATE2 contract creation. This is permitted in certain situations, such as when the account only has a balance (but no storage).
To resolve this case, we have to be a little more careful when creating storage snapshots. Specifically, when an account only partially exists (i.e. has no storage, but only a balance) then we never create storage snapshots.
Finally, this also adds a debugging mode to ReplayExecutionEnvironment to assist debugging the BlockCapturer.