generated from Consensys/doctools.template-site
-
Notifications
You must be signed in to change notification settings - Fork 459
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Initial draft * Updates * Expand with detail about relevant API methods * Add sidebar link * Update project-words.txt * Address comments * Address comment * Addressing comments * Address comments
- Loading branch information
Showing
4 changed files
with
42 additions
and
1 deletion.
There are no files selected for viewing
39 changes: 39 additions & 0 deletions
39
docs/architecture/stack/trace-expansion-proving/prover-limits.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
--- | ||
title: Module limits | ||
description: How module limits ensure the prover can generate proofs. | ||
sidebar_position: 3 | ||
--- | ||
|
||
Linea uses module limits to keep proof complexity manageable and ensure that the prover can | ||
generate proofs efficiently without overwhelming the infrastructure. | ||
|
||
Linea's arithmetization specification is divided into modules, and each module represents a collection | ||
of EVM or Linea zkEVM operations (opcodes). Modules can: | ||
- Process transaction data. | ||
- Manage zkEVM memory. | ||
- Coordinate interactions between modules. | ||
|
||
Each module has a specific limit on the number of lines of data its operations can generate, | ||
regardless of its purpose. You can view these limits in the | ||
[Linea source code](https://github.com/Consensys/linea-monorepo/blob/main/config/common/traces-limits-besu-v2.toml). | ||
Additional lines are generated each time unique instructions are provided to a module's operations, | ||
but repeat calls with the same arguments do not generate new lines. | ||
|
||
High-complexity transactions that repeatedly use a large volume of operations may generate too many | ||
lines of data and exceed a module's limit. Transactions that reach this point are rejected by the | ||
[sequencer](../sequencer/index.mdx) to ensure that the trace data passed to the prover is of a | ||
manageable scope, and that a proof can be generated. | ||
|
||
Transactions rejected for exceeding module limits can be identified through the following | ||
methods, which return an error: | ||
|
||
- [`linea_estimateGas`](../../../developers/reference/api/linea-estimategas.mdx) | ||
- [`eth_sendRawTransaction`](../../../developers/reference/api/eth-sendrawtransaction.mdx) | ||
|
||
Use [`linea_getTransactionExclusionStatusV1`](../../../developers/reference/api/linea-gettransactionexclusionstatusv1.mdx) | ||
to get the rejection status of a transaction hash, if it was sent and didn't get rejected directly, | ||
nor included in a block. | ||
|
||
This API method can be used to query the reason for transaction rejection in edge cases where | ||
`linea_estimateGas` or `eth_sendRawTransaction` did not return an error. It's intended to be used | ||
only in cases the transaction execution differs between an RPC node and the sequencer. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -301,6 +301,7 @@ gcsize | |
gctime | ||
genkey | ||
getopts | ||
gettransactionexclusionstatusv | ||
gitgraph | ||
gitpod | ||
Gizathon | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters