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

Impl eth_call state override feature #3027

Open
wants to merge 7 commits into
base: master
Choose a base branch
from

Conversation

Pana
Copy link
Member

@Pana Pana commented Jan 2, 2025

This change is Reviewable

@Pana Pana requested a review from ChenxingLi January 2, 2025 07:36
Copy link
Contributor

@ChenxingLi ChenxingLi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewed 11 of 18 files at r1, all commit messages.
Reviewable status: 11 of 18 files reviewed, 4 unresolved discussions (waiting on @Pana)


crates/cfxcore/executor/src/state/overlay_account/mod.rs line 187 at r1 (raw file):

    /// Inditcates if this account's storage entries and lazily loaded fields on
    /// db are marked invalid (so an entry is empty if not in cache).
    pub fn fresh_storage(&self) -> bool {

fresh_storage should take storage_overrided into consideration.


crates/cfxcore/executor/src/state/state_object/state_override.rs line 26 at r1 (raw file):

            };

            self.prefetch(&addr_with_space, RequireFields::Code)?;

I think the following logic should be in the initialization of OverlayAccount, by adding a function like new_loaded_with_overrided, rather than repeatedly modifying the OverlayAccount here through state.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 201 at r1 (raw file):

        Ok(if let Some(value) = self.cached_entry_at(key) {
            value
        } else if self.fresh_storage() || self.storage_overrided {

Update fresh_storage and remove this.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 245 at r1 (raw file):

    // used for state override.diff
    pub fn update_storage_read_cache(&mut self, key: Vec<u8>, value: U256) {
        let owner = if self.address.space == Space::Native {

Assert empty checkpoint here.

Copy link
Member Author

@Pana Pana left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewable status: 10 of 19 files reviewed, 4 unresolved discussions (waiting on @ChenxingLi)


crates/cfxcore/executor/src/state/overlay_account/mod.rs line 187 at r1 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

fresh_storage should take storage_overrided into consideration.

Done.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 201 at r1 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

Update fresh_storage and remove this.

Done.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 245 at r1 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

Assert empty checkpoint here.

Done.


crates/cfxcore/executor/src/state/state_object/state_override.rs line 26 at r1 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

I think the following logic should be in the initialization of OverlayAccount, by adding a function like new_loaded_with_overrided, rather than repeatedly modifying the OverlayAccount here through state.

Done.

Copy link
Contributor

@ChenxingLi ChenxingLi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewed 3 of 18 files at r1, 1 of 5 files at r2, all commit messages.
Reviewable status: 14 of 19 files reviewed, 11 unresolved discussions (waiting on @Pana)


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 58 at r2 (raw file):

    }

    pub fn from_loaded_and_override(

from_loaded_with_override


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 65 at r2 (raw file):

        if let Some(balance) = acc_overrides.balance {
            let curr_balance = acc.balance().clone();

*acc.balance()


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 76 at r2 (raw file):

        }

        if let Some(code) = acc_overrides.code.clone() {

Don't clone in the reading part, use as_ref instead.


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 81 at r2 (raw file):

        match (
            acc_overrides.state.clone(),

Same, use as_ref


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 90 at r2 (raw file):

                acc.override_storage_read_cache(&diff, false);
            }
            (Some(_state), Some(_diff)) => unreachable!(), /* the rpc layer */

It is better to translate the rpc type into a new type to avoid unreachable here.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 254 at r2 (raw file):

        self.storage_read_cache
            .write()
            .insert(key.to_vec(), storage_value);

key is already an Vec.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 258 at r2 (raw file):

    pub fn override_storage_read_cache(
        &mut self, state: &HashMap<H256, H256>, complete_override: bool,

Confuse with the State in the whole execution layer. Consider using the account_storage.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 264 at r2 (raw file):

            self.storage_overrided = true;
        }
        for (key, value) in state.iter() {

I believe the compiler doesn't require an iter() here.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 267 at r2 (raw file):

            let key = key.as_bytes().to_vec();
            let value = U256::from_big_endian(value.as_bytes());
            self.update_storage_read_cache(key, value);

What about putting all the implementation about update_storage_read_cache directly?

And assert empty checkpoints once.


crates/cfxcore/executor/src/state/overlay_account/account_entry.rs line 41 at r2 (raw file):

    }

    pub fn from_loaded_and_override(

from_loaded_with_override


crates/cfxcore/executor/src/state/state_object/state_override.rs line 28 at r2 (raw file):

            );

            self.cache.write().insert(addr_with_space, account_entry);

Use let cache = self.cache.write() before the for loop.

Copy link
Member Author

@Pana Pana left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewable status: 14 of 19 files reviewed, 11 unresolved discussions (waiting on @ChenxingLi)


crates/cfxcore/executor/src/state/overlay_account/account_entry.rs line 41 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

from_loaded_with_override

Done.


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 58 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

from_loaded_with_override

Done.


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 65 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

*acc.balance()

Done.


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 76 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

Don't clone in the reading part, use as_ref instead.

Done.


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 81 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

Same, use as_ref

Done.


crates/cfxcore/executor/src/state/overlay_account/factory.rs line 90 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

It is better to translate the rpc type into a new type to avoid unreachable here.

Done.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 254 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

key is already an Vec.

Done.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 258 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

Confuse with the State in the whole execution layer. Consider using the account_storage.

Done.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 264 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

I believe the compiler doesn't require an iter() here.

Done.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 267 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

What about putting all the implementation about update_storage_read_cache directly?

And assert empty checkpoints once.

Done.


crates/cfxcore/executor/src/state/state_object/state_override.rs line 28 at r2 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

Use let cache = self.cache.write() before the for loop.

Done.

@Pana
Copy link
Member Author

Pana commented Jan 8, 2025

retest this please

2 similar comments
@Pana
Copy link
Member Author

Pana commented Jan 8, 2025

retest this please

@Pana
Copy link
Member Author

Pana commented Jan 8, 2025

retest this please

@Pana
Copy link
Member Author

Pana commented Jan 10, 2025

#2997

Copy link
Contributor

@ChenxingLi ChenxingLi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewed 1 of 18 files at r1, 3 of 4 files at r3, all commit messages.
Reviewable status: 18 of 19 files reviewed, 3 unresolved discussions (waiting on @Pana)


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 243 at r3 (raw file):

    }

    pub fn override_storage_read_cache(

Should it be a private function? I suggest putting all the related functions (this function and from_loaded_with_override) in a new module called override (override.rs) together.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 248 at r3 (raw file):

    ) {
        if complete_override {
            self.storage_read_cache.write().clear();

In this function, we must assume we are working on a fresh account. Otherwise, if not working on a fresh account, simply clear cache is not enough.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 251 at r3 (raw file):

            self.storage_overrided = true;
        }
        assert!(self.storage_write_checkpoint.is_none());

As we assume working on a fresh account, use the following code

let read_cache = Arc::get_mut(&mut self.storage_read_cache).expect("override should happen when no checkpoint").get_mut().unwrap();

@Pana Pana force-pushed the feat/ethCallStateOverrideImpl branch from f45f264 to 14a01cc Compare January 10, 2025 08:34
@Pana Pana force-pushed the feat/ethCallStateOverrideImpl branch from 14a01cc to b6d0752 Compare January 10, 2025 08:40
Copy link
Member Author

@Pana Pana left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewable status: 10 of 20 files reviewed, 3 unresolved discussions (waiting on @ChenxingLi)


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 243 at r3 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

Should it be a private function? I suggest putting all the related functions (this function and from_loaded_with_override) in a new module called override (override.rs) together.

Done.


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 248 at r3 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

In this function, we must assume we are working on a fresh account. Otherwise, if not working on a fresh account, simply clear cache is not enough.

Yes we assume it is a fresh account


crates/cfxcore/executor/src/state/overlay_account/storage.rs line 251 at r3 (raw file):

Previously, ChenxingLi (Chenxing Li) wrote…

As we assume working on a fresh account, use the following code

let read_cache = Arc::get_mut(&mut self.storage_read_cache).expect("override should happen when no checkpoint").get_mut().unwrap();

Done.

@Pana
Copy link
Member Author

Pana commented Jan 13, 2025

retest this please

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

Successfully merging this pull request may close these issues.

2 participants