From e197a88ca99ceea4d3a0720823a6f9cee60e2a4c Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Fri, 25 Oct 2024 16:52:59 +0800 Subject: [PATCH 1/7] Update LibVerifying.sol --- .../contracts/layer1/based/LibVerifying.sol | 25 ++++++++++--------- 1 file changed, 13 insertions(+), 12 deletions(-) diff --git a/packages/protocol/contracts/layer1/based/LibVerifying.sol b/packages/protocol/contracts/layer1/based/LibVerifying.sol index 0957acb859f..82cdba18bd3 100644 --- a/packages/protocol/contracts/layer1/based/LibVerifying.sol +++ b/packages/protocol/contracts/layer1/based/LibVerifying.sol @@ -98,20 +98,21 @@ library LibVerifying { if (ts.contester != address(0)) { break; - } else { - if (local.tierRouter == ITierRouter(address(0))) { - local.tierRouter = - ITierRouter(_resolver.resolve(LibStrings.B_TIER_ROUTER, false)); - } + } - uint24 cooldown = ITierProvider(local.tierRouter.getProvider(local.blockId)) - .getTier(local.tier).cooldownWindow; + if (local.tierRouter == ITierRouter(address(0))) { + local.tierRouter = + ITierRouter(_resolver.resolve(LibStrings.B_TIER_ROUTER, false)); + } - if (!LibUtils.isPostDeadline(ts.timestamp, local.b.lastUnpausedAt, cooldown)) { - // If cooldownWindow is 0, the block can theoretically - // be proved and verified within the same L1 block. - break; - } + uint24 cooldown = ITierProvider(local.tierRouter.getProvider(local.blockId)).getTier( + local.tier + ).cooldownWindow; + + if (!LibUtils.isPostDeadline(ts.timestamp, local.b.lastUnpausedAt, cooldown)) { + // If cooldownWindow is 0, the block can theoretically + // be proved and verified within the same L1 block. + break; } // Update variables From 11df9637abecb81216ea9fc5f1e493660b062440 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Fri, 25 Oct 2024 16:53:19 +0800 Subject: [PATCH 2/7] Update LibProving.sol --- packages/protocol/contracts/layer1/based/LibProving.sol | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/protocol/contracts/layer1/based/LibProving.sol b/packages/protocol/contracts/layer1/based/LibProving.sol index 3ead8de2ed5..d5f127138cb 100644 --- a/packages/protocol/contracts/layer1/based/LibProving.sol +++ b/packages/protocol/contracts/layer1/based/LibProving.sol @@ -648,7 +648,7 @@ library LibProving { /// @dev Returns the reward after applying 12.5% friction. function _rewardAfterFriction(uint256 _amount) private pure returns (uint256) { - return _amount == 0 ? 0 : (_amount * 7) >> 3; + return (_amount * 7) >> 3; } /// @dev Returns if the liveness bond shall be returned. From 2033687bc1db3fa7ccfd18636e7bbe0bcbea07d1 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Fri, 25 Oct 2024 16:53:46 +0800 Subject: [PATCH 3/7] Update LibProposing.sol --- .../contracts/layer1/based/LibProposing.sol | 54 +++++++++---------- 1 file changed, 25 insertions(+), 29 deletions(-) diff --git a/packages/protocol/contracts/layer1/based/LibProposing.sol b/packages/protocol/contracts/layer1/based/LibProposing.sol index 3552bbae332..53d25aa9ef8 100644 --- a/packages/protocol/contracts/layer1/based/LibProposing.sol +++ b/packages/protocol/contracts/layer1/based/LibProposing.sol @@ -228,35 +228,31 @@ library LibProposing { // the block data to be stored on-chain for future integrity checks. // If we choose to persist all data fields in the metadata, it will // require additional storage slots. - unchecked { - meta_ = TaikoData.BlockMetadataV2({ - anchorBlockHash: blockhash(local.params.anchorBlockId), - difficulty: keccak256(abi.encode("TAIKO_DIFFICULTY", local.b.numBlocks)), - blobHash: 0, // to be initialized below - // To make sure each L2 block can be exexucated deterministiclly by the client - // without referering to its metadata on Ethereum, we need to encode - // config.sharingPctg into the extraData. - extraData: local.postFork - ? _encodeBaseFeeConfig(_config.baseFeeConfig) - : local.extraData, - coinbase: local.params.coinbase, - id: local.b.numBlocks, - gasLimit: _config.blockMaxGasLimit, - timestamp: local.params.timestamp, - anchorBlockId: local.params.anchorBlockId, - minTier: 0, // to be initialized below - blobUsed: _txList.length == 0, - parentMetaHash: local.params.parentMetaHash, - proposer: local.params.proposer, - livenessBond: _config.livenessBond, - proposedAt: uint64(block.timestamp), - proposedIn: uint64(block.number), - blobTxListOffset: local.params.blobTxListOffset, - blobTxListLength: local.params.blobTxListLength, - blobIndex: local.params.blobIndex, - baseFeeConfig: _config.baseFeeConfig - }); - } + meta_ = TaikoData.BlockMetadataV2({ + anchorBlockHash: blockhash(local.params.anchorBlockId), + difficulty: keccak256(abi.encode("TAIKO_DIFFICULTY", local.b.numBlocks)), + blobHash: 0, // to be initialized below + // To make sure each L2 block can be exexucated deterministiclly by the client + // without referering to its metadata on Ethereum, we need to encode + // config.sharingPctg into the extraData. + extraData: local.postFork ? _encodeBaseFeeConfig(_config.baseFeeConfig) : local.extraData, + coinbase: local.params.coinbase, + id: local.b.numBlocks, + gasLimit: _config.blockMaxGasLimit, + timestamp: local.params.timestamp, + anchorBlockId: local.params.anchorBlockId, + minTier: 0, // to be initialized below + blobUsed: _txList.length == 0, + parentMetaHash: local.params.parentMetaHash, + proposer: local.params.proposer, + livenessBond: _config.livenessBond, + proposedAt: uint64(block.timestamp), + proposedIn: uint64(block.number), + blobTxListOffset: local.params.blobTxListOffset, + blobTxListLength: local.params.blobTxListLength, + blobIndex: local.params.blobIndex, + baseFeeConfig: _config.baseFeeConfig + }); // Update certain meta fields if (meta_.blobUsed) { From 7f73e81760f9062b34f89d27c91afb1a355f88b3 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Fri, 25 Oct 2024 17:03:11 +0800 Subject: [PATCH 4/7] Update LibProposing.sol --- packages/protocol/contracts/layer1/based/LibProposing.sol | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/packages/protocol/contracts/layer1/based/LibProposing.sol b/packages/protocol/contracts/layer1/based/LibProposing.sol index 53d25aa9ef8..1e82cf0edd7 100644 --- a/packages/protocol/contracts/layer1/based/LibProposing.sol +++ b/packages/protocol/contracts/layer1/based/LibProposing.sol @@ -178,11 +178,11 @@ library LibProposing { local.params.coinbase = local.params.proposer; } - if (!local.postFork || local.params.anchorBlockId == 0) { + if (local.params.anchorBlockId == 0) { local.params.anchorBlockId = uint64(block.number - 1); } - if (!local.postFork || local.params.timestamp == 0) { + if (local.params.timestamp == 0) { local.params.timestamp = uint64(block.timestamp); } @@ -288,8 +288,8 @@ library LibProposing { assignedProver: address(0), livenessBond: local.postFork ? 0 : meta_.livenessBond, blockId: local.b.numBlocks, - proposedAt: local.postFork ? local.params.timestamp : uint64(block.timestamp), - proposedIn: local.postFork ? local.params.anchorBlockId : uint64(block.number), + proposedAt: local.params.timestamp, + proposedIn: local.params.anchorBlockId, // For a new block, the next transition ID is always 1, not 0. nextTransitionId: 1, livenessBondReturned: false, From b26e0969a58a5dc27c6fe22cadde334e92cfebd4 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Fri, 25 Oct 2024 17:14:39 +0800 Subject: [PATCH 5/7] Update LibProposing.sol --- packages/protocol/contracts/layer1/based/LibProposing.sol | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/protocol/contracts/layer1/based/LibProposing.sol b/packages/protocol/contracts/layer1/based/LibProposing.sol index 1e82cf0edd7..12b520afdb2 100644 --- a/packages/protocol/contracts/layer1/based/LibProposing.sol +++ b/packages/protocol/contracts/layer1/based/LibProposing.sol @@ -289,7 +289,7 @@ library LibProposing { livenessBond: local.postFork ? 0 : meta_.livenessBond, blockId: local.b.numBlocks, proposedAt: local.params.timestamp, - proposedIn: local.params.anchorBlockId, + proposedIn: local.postFork ? local.params.anchorBlockId : uint64(block.number), // For a new block, the next transition ID is always 1, not 0. nextTransitionId: 1, livenessBondReturned: false, From ba59976d67fe2304913dd92c0a60d8c89b7c4360 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Fri, 25 Oct 2024 17:22:13 +0800 Subject: [PATCH 6/7] Update LibProposing.sol --- packages/protocol/contracts/layer1/based/LibProposing.sol | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/packages/protocol/contracts/layer1/based/LibProposing.sol b/packages/protocol/contracts/layer1/based/LibProposing.sol index 12b520afdb2..a64786652ff 100644 --- a/packages/protocol/contracts/layer1/based/LibProposing.sol +++ b/packages/protocol/contracts/layer1/based/LibProposing.sol @@ -179,7 +179,8 @@ library LibProposing { } if (local.params.anchorBlockId == 0) { - local.params.anchorBlockId = uint64(block.number - 1); + local.params.anchorBlockId = + local.postFork ? uint64(block.number - 1) : uint64(block.number); } if (local.params.timestamp == 0) { @@ -289,7 +290,7 @@ library LibProposing { livenessBond: local.postFork ? 0 : meta_.livenessBond, blockId: local.b.numBlocks, proposedAt: local.params.timestamp, - proposedIn: local.postFork ? local.params.anchorBlockId : uint64(block.number), + proposedIn: local.params.anchorBlockId, // For a new block, the next transition ID is always 1, not 0. nextTransitionId: 1, livenessBondReturned: false, From e50b159b988e8ab1c6e3f95f7ace44a6d710b57b Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Fri, 25 Oct 2024 17:33:04 +0800 Subject: [PATCH 7/7] Update LibProposing.sol --- .../contracts/layer1/based/LibProposing.sol | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/packages/protocol/contracts/layer1/based/LibProposing.sol b/packages/protocol/contracts/layer1/based/LibProposing.sol index a64786652ff..a3437d83685 100644 --- a/packages/protocol/contracts/layer1/based/LibProposing.sol +++ b/packages/protocol/contracts/layer1/based/LibProposing.sol @@ -14,6 +14,8 @@ import "./LibVerifying.sol"; library LibProposing { using LibAddress for address; + uint256 internal constant SECONDS_PER_BLOCK = 12; + struct Local { TaikoData.SlotB b; TaikoData.BlockParamsV2 params; @@ -179,8 +181,10 @@ library LibProposing { } if (local.params.anchorBlockId == 0) { - local.params.anchorBlockId = - local.postFork ? uint64(block.number - 1) : uint64(block.number); + unchecked { + local.params.anchorBlockId = + local.postFork ? uint64(block.number - 1) : uint64(block.number); + } } if (local.params.timestamp == 0) { @@ -188,8 +192,10 @@ library LibProposing { } // Verify params against the parent block. - TaikoData.BlockV2 storage parentBlk = - _state.blocks[(local.b.numBlocks - 1) % _config.blockRingBufferSize]; + TaikoData.BlockV2 storage parentBlk; + unchecked { + parentBlk = _state.blocks[(local.b.numBlocks - 1) % _config.blockRingBufferSize]; + } if (local.postFork) { // Verify the passed in L1 state block number. @@ -209,8 +215,8 @@ library LibProposing { // The other constraint is that the timestamp needs to be larger than or equal the // one in the previous L2 block. if ( - local.params.timestamp + _config.maxAnchorHeightOffset * 12 < block.timestamp - || local.params.timestamp > block.timestamp + local.params.timestamp + _config.maxAnchorHeightOffset * SECONDS_PER_BLOCK + < block.timestamp || local.params.timestamp > block.timestamp || local.params.timestamp < parentBlk.proposedAt ) { revert L1_INVALID_TIMESTAMP();