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

Merged
merged 8 commits into from
Jan 18, 2025

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
bin/client/src/lib.rs Outdated Show resolved Hide resolved
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.

@hashcashier
Copy link
Contributor Author

@clabby I've resolved the conflicts with the recent refactor

@clabby
Copy link
Collaborator

clabby commented Jan 17, 2025

@clabby I've resolved the conflicts with the recent refactor

Amazing. Getting in #910, then will merge this today!

@clabby clabby added this pull request to the merge queue Jan 18, 2025
Merged via the queue into op-rs:main with commit f912b89 Jan 18, 2025
13 of 14 checks passed
@github-actions github-actions bot mentioned this pull request Jan 18, 2025
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
3 participants