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

feat(driver): Multi-block derivation #888

Open
wants to merge 5 commits into
base: main
Choose a base branch
from

Conversation

hashcashier
Copy link
Contributor

@hashcashier hashcashier commented Jan 8, 2025

This PR adds an optional PipelineCursor instance into OracleL2ChainProvider which enables the forward movement of the reference L2 block hash used to verifiably query L2 block data by number.

Using this cursor in the provider enables providing authenticated data to the pipeline beyond what could previously be validating only using the commitments in BootInfo.

This allows Driver::advance_to_target to iteratively process multiple sequential blocks, extending the usability of Kona in ZK fault proofs.

The PR also reduces some boilerplate by introducing convenience methods in HintType and OracleL2ChainProvider.

Closes #795

@hashcashier hashcashier changed the title feat(driver): Multi-block proofs feat(driver): Multi-block derivation Jan 8, 2025
Comment on lines +43 to +45

// Wrap the cursor in a shared read-write lock
Ok(Arc::new(RwLock::new(cursor)))
Copy link
Collaborator

Choose a reason for hiding this comment

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

Is there a reason you chose to return the Arc<RwLock<PipelineCursor>> instead of doing this when it's consumed?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

There's just one usage of the method in client so I thought not to clog up the client's run code.

Copy link
Collaborator

@refcell refcell left a comment

Choose a reason for hiding this comment

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

I support this - one pedantic nit is holding the RwLock across multiple asynchronous operations, but since it will not deadlock, it's acceptable.

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.

feat(driver): Multi-block derivation
2 participants