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(protocol): allow block propose to pass a bytes32 input to L2 anchor #18569

Merged
merged 27 commits into from
Dec 16, 2024
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
0a057d6
1
dantaik Dec 8, 2024
728d390
support an bytes32-typed arbitrary anchor input
dantaik Dec 8, 2024
2010536
more
dantaik Dec 8, 2024
6e83eb7
rename
dantaik Dec 8, 2024
943259d
Update TaikoL1.sol
dantaik Dec 8, 2024
4959ac5
Update TaikoL1.sol
dantaik Dec 8, 2024
3909e4c
more
dantaik Dec 8, 2024
9e552dc
Merge branch 'pacaya_fork' into pass_data_anchor
dantaik Dec 8, 2024
c7b78df
Merge branch 'pacaya_fork' into pass_data_anchor
dantaik Dec 8, 2024
37ad5b3
Merge branch 'pacaya_fork' into pass_data_anchor
dantaik Dec 13, 2024
441054a
Update ITaikoL1.sol
dantaik Dec 13, 2024
83bd754
Update ITaikoL1.sol
dantaik Dec 13, 2024
371c68f
Merge branch 'pass_data_anchor' of https://github.com/taikoxyz/taiko-…
dantaik Dec 13, 2024
6677005
forge fmt & update contract layout tables
dantaik Dec 13, 2024
72871de
rename
dantaik Dec 14, 2024
17e3336
Update TaikoL2.sol
dantaik Dec 14, 2024
8950074
Merge branch 'pacaya_fork' into pass_data_anchor
dantaik Dec 14, 2024
1b1133f
more
dantaik Dec 14, 2024
2edf605
Create TaikoL1Test_Suite1.json
dantaik Dec 14, 2024
2ec0f21
more
dantaik Dec 14, 2024
5dbb020
layout
dantaik Dec 14, 2024
322694b
Merge branch 'pacaya_fork' into pass_data_anchor
dantaik Dec 15, 2024
16c1596
Merge branch 'pacaya_fork' into pass_data_anchor
dantaik Dec 15, 2024
564dcb6
forge fmt & update contract layout tables
dantaik Dec 15, 2024
9faba01
rename anchorV2 to anchorV3
dantaik Dec 16, 2024
a2d2377
Delete TaikoL1Test_Suite1.json
dantaik Dec 16, 2024
d946187
forge fmt & update contract layout tables
dantaik Dec 16, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions packages/protocol/contracts/layer1/based/ITaikoL1.sol
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ interface ITaikoL1 {
struct BlockParamsV3 {
bytes32 parentMetaHash;
uint64 anchorBlockId;
bytes32 anchorExtraInput;
uint64 timestamp;
uint32 txListOffset;
uint32 txListSize;
Expand All @@ -33,6 +34,7 @@ interface ITaikoL1 {
uint8 blobIndex;
uint64 anchorBlockId;
bytes32 anchorBlockHash;
bytes32 anchorExtraInput;
LibSharedData.BaseFeeConfig baseFeeConfig;
}

Expand Down Expand Up @@ -180,6 +182,7 @@ interface ITaikoL1 {
error ArraySizesMismatch();
error BlobIndexZero();
error BlobNotFound();
error BlobIndexZero();
dantaik marked this conversation as resolved.
Show resolved Hide resolved
error BlockNotFound();
error BlockVerified();
error ContractPaused();
Expand Down
12 changes: 6 additions & 6 deletions packages/protocol/contracts/layer1/based/TaikoL1.sol
Original file line number Diff line number Diff line change
Expand Up @@ -105,19 +105,18 @@ abstract contract TaikoL1 is EssentialContract, ITaikoL1 {

metas_ = new BlockMetadataV3[](_paramsArray.length);
bool calldataUsed = _txList.length != 0;
UpdatedParams memory updatedParams;

for (uint256 i; i < _paramsArray.length; ++i) {
require(calldataUsed || _paramsArray[i].blobIndex != 0, BlobIndexZero());
UpdatedParams memory updatedParams =
updatedParams =
_validateBlockParams(_paramsArray[i], config.maxAnchorHeightOffset, lastBlock);

// This section constructs the metadata for the proposed block, which is crucial for
// nodes/clients
// to process the block. The metadata itself is not stored on-chain; instead, only its
// hash is kept.
// nodes/clients to process the block. The metadata itself is not stored on-chain;
// instead, only its hash is kept.
// The metadata must be supplied as calldata prior to proving the block, enabling the
// computation
// and verification of its integrity through the comparison of the metahash.
// computation and verification of its integrity through the comparison of the metahash.
unchecked {
metas_[i] = BlockMetadataV3({
difficulty: keccak256(abi.encode("TAIKO_DIFFICULTY", stats2.numBlocks)),
Expand All @@ -139,6 +138,7 @@ abstract contract TaikoL1 is EssentialContract, ITaikoL1 {
blobIndex: calldataUsed ? 0 : _paramsArray[i].blobIndex,
anchorBlockId: updatedParams.anchorBlockId,
anchorBlockHash: blockhash(updatedParams.anchorBlockId),
anchorExtraInput: _paramsArray[i].anchorExtraInput,
baseFeeConfig: config.baseFeeConfig
});
}
Expand Down
7 changes: 6 additions & 1 deletion packages/protocol/contracts/layer2/based/TaikoL2.sol
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,9 @@ contract TaikoL2 is EssentialContract, IBlockHash, TaikoL2Deprecated {
/// @notice The L1's chain ID.
uint64 public l1ChainId;

uint256[46] private __gap;
mapping(uint256 blockNumber => bytes32 anchorExtraInput) public blockAnchorExtraInput;

uint256[45] private __gap;

/// @notice Emitted when the latest L1 block details are anchored to L2.
/// @param parentHash The hash of the parent block.
Expand Down Expand Up @@ -136,6 +138,7 @@ contract TaikoL2 is EssentialContract, IBlockHash, TaikoL2Deprecated {
function anchorV2(
davidtaikocha marked this conversation as resolved.
Show resolved Hide resolved
uint64 _anchorBlockId,
bytes32 _anchorStateRoot,
bytes32 _anchorExtraInput,
uint32 _parentGasUsed,
LibSharedData.BaseFeeConfig calldata _baseFeeConfig
)
Expand All @@ -154,6 +157,8 @@ contract TaikoL2 is EssentialContract, IBlockHash, TaikoL2Deprecated {
_verifyBaseFeeAndUpdateGasExcess(_parentGasUsed, _baseFeeConfig);
_syncChainData(_anchorBlockId, _anchorStateRoot);
_updateParentHashAndTimestamp(parentId);

blockAnchorExtraInput[block.number] = _anchorExtraInput;
}

/// @notice Withdraw token or Ether from this address.
Expand Down
4 changes: 2 additions & 2 deletions packages/protocol/snapshots/TaikoL1Test_Suite1.json
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
{
"proposeBlocksV3": "84386",
"proveBlocksV3": "133470"
"proposeBlocksV3": "85029",
"proveBlocksV3": "133593"
}
4 changes: 2 additions & 2 deletions packages/protocol/test/layer2/TaikoL2.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,7 @@ contract TestTaikoL2 is Layer2Test {

bytes32 anchorStateRoot = bytes32(uint256(1));
vm.prank(taikoL2.GOLDEN_TOUCH_ADDRESS());
taikoL2.anchorV2(++anchorBlockId, anchorStateRoot, _parentGasUsed, baseFeeConfig);
taikoL2.anchorV2(++anchorBlockId, anchorStateRoot, 0x0, _parentGasUsed, baseFeeConfig);

(uint256 basefee, uint64 newGasTarget,) =
taikoL2.getBasefeeV2(_parentGasUsed, baseFeeConfig);
Expand All @@ -157,6 +157,6 @@ contract TestTaikoL2 is Layer2Test {
minGasExcess: 1_340_000_000,
maxGasIssuancePerBlock: 600_000_000 // two minutes
});
taikoL2.anchorV2(++anchorBlockId, anchorStateRoot, parentGasUsed, baseFeeConfig);
taikoL2.anchorV2(++anchorBlockId, anchorStateRoot, 0x0, parentGasUsed, baseFeeConfig);
}
}
Loading