mirror of https://github.com/hyperledger/besu
An enterprise-grade Java-based, Apache 2.0 licensed Ethereum client https://wiki.hyperledger.org/display/besu
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.3 KiB
40 lines
1.3 KiB
5 years ago
|
# Trace RPC API Notes
|
||
|
|
||
|
This document outlines major differences for `trace_replayBlockTransactions`
|
||
|
compared to other implementations.
|
||
|
|
||
|
## `stateDiff`
|
||
|
|
||
|
No major differences were observed in the `stateDiff` field.
|
||
|
|
||
|
## `trace`
|
||
|
|
||
|
Besu reports `gasUsed` after applying the effects of gas refunds. Future
|
||
|
implementations of Besu might track gas refunds separately.
|
||
|
|
||
|
## `vmTrace`
|
||
|
|
||
|
### Returned Memory from Calls
|
||
|
|
||
|
In the `vmTrace` `ope.ex.mem` fields Besu only reports actual data returned
|
||
|
from a `RETURN` opcode. Other implementations return the contents of the
|
||
|
reserved output space for the call operations. Note two major differences:
|
||
|
|
||
|
1. Besu reports `null` when a call operation ends because of a `STOP`, `HALT`,
|
||
|
`REVERT`, running out of instructions, or any exceptional halts.
|
||
|
2. When a `RETURN` operation returns data of a different length than the space
|
||
|
reserved by the call only the data passed to the `RETURN` operation is
|
||
|
reported. Other implementations will include pre-existing memory data or
|
||
|
trim the returned data.
|
||
|
|
||
|
### Precompiled Contracts Calls
|
||
|
|
||
|
Besu reports only the actual cost of the precompiled contract call in the
|
||
|
`cost` field.
|
||
|
|
||
|
### Out of Gas
|
||
|
|
||
|
Besu reports the operation that causes out fo gas exceptions, including
|
||
|
calculated gas cost. The operation is not executed so no `ex` values are
|
||
|
reported.
|