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

Add timeboosted information to broadcast feed #2695

Merged

Conversation

ganeshvanahalli
Copy link
Contributor

@ganeshvanahalli ganeshvanahalli commented Sep 24, 2024

This PR adds a new field blockMetadata to the BroadcastFeedMessage struct that represents whether a particular transaction in the block was time-boosted or not.

The field blockMetadata is an array of bytes and it starts with a 0 (version) followed by ceil(N/8) number of bytes where N is the number of txs in the block. Basically nth bit of the kth byte of blockMetadata byte array represents the status of 8*(k-1)+(n+1) th transaction, if its 1 means the tx was timeboosted else it wasn't.
Example: if blockMetadata array viewed as bits is 00000000 01100101 then 2nd, 3rd, 6th and 8th transactions in the block were timeboosted.

Resolves NIT-2779

@cla-bot cla-bot bot added the s Automatically added by the CLA bot if the creator of a PR is registered as having signed the CLA. label Sep 24, 2024
@ganeshvanahalli ganeshvanahalli marked this pull request as ready for review September 24, 2024 12:49
Copy link
Member

@Tristan-Wilson Tristan-Wilson left a comment

Choose a reason for hiding this comment

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

Overall it looks good, just a few comments.

broadcaster/message/message.go Outdated Show resolved Hide resolved
broadcaster/message/message_serialization_test.go Outdated Show resolved Hide resolved
execution/gethexec/executionengine.go Outdated Show resolved Hide resolved
execution/gethexec/executionengine.go Outdated Show resolved Hide resolved
system_tests/timeboost_test.go Outdated Show resolved Hide resolved
system_tests/timeboost_test.go Outdated Show resolved Hide resolved
arbnode/schema.go Outdated Show resolved Hide resolved
@ganeshvanahalli ganeshvanahalli changed the title Add timeboosted field to broadcast feed Add timeboosted information to broadcast feed Oct 2, 2024
arbnode/schema.go Outdated Show resolved Hide resolved
Copy link
Member

@Tristan-Wilson Tristan-Wilson left a comment

Choose a reason for hiding this comment

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

LGTM.

This still needs design review from @tsahee.

From my previous discussion with @tsahee I think the plan is to wait until #2561 is merged into master before merging this and your other metadata related PRs.

Copy link
Contributor

@tsahee tsahee left a comment

Choose a reason for hiding this comment

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

generally LGTM. small comments

arbnode/transaction_streamer.go Outdated Show resolved Hide resolved
arbnode/transaction_streamer.go Show resolved Hide resolved
BlockHash: &msgResult.BlockHash,
// maybe if blockhash is differing we clear out previous timeboosted and not send timeboosted info to broadcasting?
Copy link
Contributor

Choose a reason for hiding this comment

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

Good idea. If blockHash doesn't agree clear BlockMetadata.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Cool. I think the best place to implement this is in Bulk syncing of missing BlockMetadata PR, since it tracks missing blockMetadata and in there we can clear out blockMetadata and mark it as missing in DB so that it will be refetched later on

arbnode/transaction_streamer.go Show resolved Hide resolved
arbos/arbostypes/messagewithmeta.go Outdated Show resolved Hide resolved
@CLAassistant
Copy link

CLAassistant commented Nov 26, 2024

CLA assistant check
All committers have signed the CLA.

broadcaster/message/message.go Outdated Show resolved Hide resolved
@Tristan-Wilson Tristan-Wilson merged commit 6b99351 into express-lane-timeboost Dec 27, 2024
10 checks passed
@Tristan-Wilson Tristan-Wilson deleted the add-timeboosted-broadcastfeedmessage branch December 27, 2024 16:14
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
s Automatically added by the CLA bot if the creator of a PR is registered as having signed the CLA.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants