Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
N
nebula
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
exchain
nebula
Commits
7ee57edf
Unverified
Commit
7ee57edf
authored
May 10, 2023
by
OptimismBot
Committed by
GitHub
May 10, 2023
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #5648 from ethereum-optimism/clabby/migration/min-gas-fix
feat(migration): Mimic `xdm.baseGas` in `migrate.go`
parents
931e1de0
7478004b
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
75 additions
and
9 deletions
+75
-9
migrate.go
op-chain-ops/crossdomain/migrate.go
+38
-5
message-utils.ts
packages/sdk/src/utils/message-utils.ts
+37
-4
No files found.
op-chain-ops/crossdomain/migrate.go
View file @
7ee57edf
...
...
@@ -19,6 +19,17 @@ var (
errLegacyStorageSlotNotFound
=
errors
.
New
(
"cannot find storage slot"
)
)
// Constants used by `CrossDomainMessenger.baseGas`
var
(
RelayConstantOverhead
uint64
=
200
_000
RelayPerByteDataCost
uint64
=
params
.
TxDataNonZeroGasEIP2028
MinGasDynamicOverheadNumerator
uint64
=
64
MinGasDynamicOverheadDenominator
uint64
=
63
RelayCallOverhead
uint64
=
40
_000
RelayReservedGas
uint64
=
40
_000
RelayGasCheckBuffer
uint64
=
5
_000
)
// MigrateWithdrawals will migrate a list of pending withdrawals given a StateDB.
func
MigrateWithdrawals
(
withdrawals
SafeFilteredWithdrawals
,
...
...
@@ -112,16 +123,38 @@ func MigrateWithdrawalGasLimit(data []byte, chainID *big.Int) uint64 {
// Compute the upper bound on the gas limit. This could be more
// accurate if individual 0 bytes and non zero bytes were accounted
// for.
dataCost
:=
uint64
(
len
(
data
))
*
params
.
TxDataNonZeroGasEIP2028
dataCost
:=
uint64
(
len
(
data
))
*
RelayPerByteDataCost
// Goerli has a lower gas limit than other chains.
overhead
:=
uint64
(
200
_000
)
if
chainID
.
Cmp
(
big
.
NewInt
(
420
))
!=
0
{
overhead
=
1
_000_000
var
overhead
uint64
if
chainID
.
Cmp
(
big
.
NewInt
(
420
))
==
0
{
overhead
=
uint64
(
200
_000
)
}
else
{
// Mimic `baseGas` from `CrossDomainMessenger.sol`
overhead
=
uint64
(
// Constant overhead
RelayConstantOverhead
+
// Dynamic overhead (EIP-150)
// We use a constant 1 million gas limit due to the overhead of simulating all migrated withdrawal
// transactions during the migration. This is a conservative estimate, and if a withdrawal
// uses more than the minimum gas limit, it will fail and need to be replayed with a higher
// gas limit.
(
MinGasDynamicOverheadNumerator
*
1
_000_000
)
/
MinGasDynamicOverheadDenominator
+
// Gas reserved for the worst-case cost of 3/5 of the `CALL` opcode's dynamic gas
// factors. (Conservative)
RelayCallOverhead
+
// Relay reserved gas (to ensure execution of `relayMessage` completes after the
// subcontext finishes executing) (Conservative)
RelayReservedGas
+
// Gas reserved for the execution between the `hasMinGas` check and the `CALL`
// opcode. (Conservative)
RelayGasCheckBuffer
,
)
}
// Set the outer gas limit. This cannot be zero
// Set the outer
minimum
gas limit. This cannot be zero
gasLimit
:=
dataCost
+
overhead
// Cap the gas limit to be 25 million to prevent creating withdrawals
// that go over the block gas limit.
if
gasLimit
>
25
_000_000
{
...
...
packages/sdk/src/utils/message-utils.ts
View file @
7ee57edf
...
...
@@ -5,6 +5,15 @@ import { LowLevelMessage } from '../interfaces'
const
{
hexDataLength
}
=
utils
// Constants used by `CrossDomainMessenger.baseGas`
const
RELAY_CONSTANT_OVERHEAD
=
BigNumber
.
from
(
200
_000
)
const
RELAY_PER_BYTE_DATA_COST
=
BigNumber
.
from
(
16
)
const
MIN_GAS_DYNAMIC_OVERHEAD_NUMERATOR
=
BigNumber
.
from
(
64
)
const
MIN_GAS_DYNAMIC_OVERHEAD_DENOMINATOR
=
BigNumber
.
from
(
63
)
const
RELAY_CALL_OVERHEAD
=
BigNumber
.
from
(
40
_000
)
const
RELAY_RESERVED_GAS
=
BigNumber
.
from
(
40
_000
)
const
RELAY_GAS_CHECK_BUFFER
=
BigNumber
.
from
(
5
_000
)
/**
* Utility for hashing a LowLevelMessage object.
*
...
...
@@ -46,11 +55,35 @@ export const migratedWithdrawalGasLimit = (
chainID
:
number
):
BigNumber
=>
{
// Compute the gas limit and cap at 25 million
const
dataCost
=
BigNumber
.
from
(
hexDataLength
(
data
)).
mul
(
16
)
let
overhead
=
200
_000
if
(
chainID
!==
420
)
{
overhead
=
1
_000_000
const
dataCost
=
BigNumber
.
from
(
hexDataLength
(
data
)).
mul
(
RELAY_PER_BYTE_DATA_COST
)
let
overhead
:
BigNumber
if
(
chainID
===
420
)
{
overhead
=
BigNumber
.
from
(
200
_000
)
}
else
{
// Dynamic overhead (EIP-150)
// We use a constant 1 million gas limit due to the overhead of simulating all migrated withdrawal
// transactions during the migration. This is a conservative estimate, and if a withdrawal
// uses more than the minimum gas limit, it will fail and need to be replayed with a higher
// gas limit.
const
dynamicOverhead
=
MIN_GAS_DYNAMIC_OVERHEAD_NUMERATOR
.
mul
(
1
_000_000
).
div
(
MIN_GAS_DYNAMIC_OVERHEAD_DENOMINATOR
)
// Constant overhead
overhead
=
RELAY_CONSTANT_OVERHEAD
.
add
(
dynamicOverhead
)
.
add
(
RELAY_CALL_OVERHEAD
)
// Gas reserved for the worst-case cost of 3/5 of the `CALL` opcode's dynamic gas
// factors. (Conservative)
// Relay reserved gas (to ensure execution of `relayMessage` completes after the
// subcontext finishes executing) (Conservative)
.
add
(
RELAY_RESERVED_GAS
)
// Gas reserved for the execution between the `hasMinGas` check and the `CALL`
// opcode. (Conservative)
.
add
(
RELAY_GAS_CHECK_BUFFER
)
}
let
minGasLimit
=
dataCost
.
add
(
overhead
)
if
(
minGasLimit
.
gt
(
25
_000_000
))
{
minGasLimit
=
BigNumber
.
from
(
25
_000_000
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment