mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2024-12-29 07:07:16 +00:00
a4b70f9ee9
* core/vm/runtime/tests: add more benchmarks * core/vm: initial work on improving alloc count for calls to precompiles name old time/op new time/op delta SimpleLoop/identity-precompile-10M-6 117ms ±75% 43ms ± 1% -63.09% (p=0.008 n=5+5) SimpleLoop/loop-10M-6 79.6ms ± 4% 70.5ms ± 1% -11.42% (p=0.008 n=5+5) name old alloc/op new alloc/op delta SimpleLoop/identity-precompile-10M-6 24.4MB ± 0% 4.9MB ± 0% -79.94% (p=0.008 n=5+5) SimpleLoop/loop-10M-6 13.2kB ± 0% 13.2kB ± 0% ~ (p=0.357 n=5+5) name old allocs/op new allocs/op delta SimpleLoop/identity-precompile-10M-6 382k ± 0% 153k ± 0% -59.99% (p=0.000 n=5+4) SimpleLoop/loop-10M-6 40.0 ± 0% 40.0 ± 0% ~ (all equal) * core/vm: don't allocate big.int for touch name old time/op new time/op delta SimpleLoop/identity-precompile-10M-6 43.3ms ± 1% 42.4ms ± 7% ~ (p=0.151 n=5+5) SimpleLoop/loop-10M-6 70.5ms ± 1% 76.7ms ± 1% +8.67% (p=0.008 n=5+5) name old alloc/op new alloc/op delta SimpleLoop/identity-precompile-10M-6 4.90MB ± 0% 2.46MB ± 0% -49.83% (p=0.008 n=5+5) SimpleLoop/loop-10M-6 13.2kB ± 0% 13.2kB ± 1% ~ (p=0.571 n=5+5) name old allocs/op new allocs/op delta SimpleLoop/identity-precompile-10M-6 153k ± 0% 76k ± 0% -49.98% (p=0.029 n=4+4) SimpleLoop/loop-10M-6 40.0 ± 0% 40.0 ± 0% ~ (all equal) * core/vm: reduce allocs in staticcall name old time/op new time/op delta SimpleLoop/identity-precompile-10M-6 42.4ms ± 7% 37.5ms ± 6% -11.68% (p=0.008 n=5+5) SimpleLoop/loop-10M-6 76.7ms ± 1% 69.1ms ± 1% -9.82% (p=0.008 n=5+5) name old alloc/op new alloc/op delta SimpleLoop/identity-precompile-10M-6 2.46MB ± 0% 0.02MB ± 0% -99.35% (p=0.008 n=5+5) SimpleLoop/loop-10M-6 13.2kB ± 1% 13.2kB ± 0% ~ (p=0.143 n=5+5) name old allocs/op new allocs/op delta SimpleLoop/identity-precompile-10M-6 76.4k ± 0% 0.1k ± 0% ~ (p=0.079 n=4+5) SimpleLoop/loop-10M-6 40.0 ± 0% 40.0 ± 0% ~ (all equal) * trie: better use of hasher keccakState * core/state/statedb: reduce allocations in getDeletedStateObject * core/vm: reduce allocations in all call derivates * core/vm: reduce allocations in call variants - Make returnstack `uint32` - Use a `sync.Pool` of `stack`s * core/vm: fix tests * core/vm: goimports * core/vm: tracer fix + staticcall gas fix * core/vm: add back snapshot to staticcall * core/vm: review concerns + make returnstack pooled + enable returndata in traces * core/vm: fix some test tracer method signatures * core/vm: run gencodec, minor comment polish Co-authored-by: Péter Szilágyi <peterke@gmail.com> # Conflicts: # core/state/statedb.go # core/vm/contracts_test.go # core/vm/evm.go # core/vm/instructions.go # core/vm/interpreter.go # core/vm/logger.go # core/vm/logger_json.go # core/vm/logger_test.go # core/vm/runtime/runtime_test.go # core/vm/stack/stack.go # eth/tracers/tracer.go # eth/tracers/tracer_test.go # trie/secure_trie.go
206 lines
4.8 KiB
Go
206 lines
4.8 KiB
Go
// Copyright 2014 The go-ethereum Authors
|
|
// This file is part of go-ethereum.
|
|
//
|
|
// go-ethereum is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// go-ethereum is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
// evm executes EVM code snippets.
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"math/big"
|
|
"os"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/cmd/utils"
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
var gitCommit = "" // Git SHA1 commit hash of the release (set via linker flags)
|
|
var gitDate = ""
|
|
|
|
var (
|
|
app = flags.NewApp(gitCommit, gitDate, "the evm command line interface")
|
|
|
|
DebugFlag = cli.BoolFlag{
|
|
Name: "debug",
|
|
Usage: "output full trace logs",
|
|
}
|
|
MemProfileFlag = cli.StringFlag{
|
|
Name: "memprofile",
|
|
Usage: "creates a memory profile at the given path",
|
|
}
|
|
CPUProfileFlag = cli.StringFlag{
|
|
Name: "cpuprofile",
|
|
Usage: "creates a CPU profile at the given path",
|
|
}
|
|
StatDumpFlag = cli.BoolFlag{
|
|
Name: "statdump",
|
|
Usage: "displays stack and heap memory information",
|
|
}
|
|
CodeFlag = cli.StringFlag{
|
|
Name: "code",
|
|
Usage: "EVM code",
|
|
}
|
|
CodeFileFlag = cli.StringFlag{
|
|
Name: "codefile",
|
|
Usage: "File containing EVM code. If '-' is specified, code is read from stdin ",
|
|
}
|
|
GasFlag = cli.Uint64Flag{
|
|
Name: "gas",
|
|
Usage: "gas limit for the evm",
|
|
Value: 10000000000,
|
|
}
|
|
PriceFlag = utils.BigFlag{
|
|
Name: "price",
|
|
Usage: "price set for the evm",
|
|
Value: new(big.Int),
|
|
}
|
|
ValueFlag = utils.BigFlag{
|
|
Name: "value",
|
|
Usage: "value set for the evm",
|
|
Value: new(big.Int),
|
|
}
|
|
DumpFlag = cli.BoolFlag{
|
|
Name: "dump",
|
|
Usage: "dumps the state after the run",
|
|
}
|
|
InputFlag = cli.StringFlag{
|
|
Name: "input",
|
|
Usage: "input for the EVM",
|
|
}
|
|
InputFileFlag = cli.StringFlag{
|
|
Name: "inputfile",
|
|
Usage: "file containing input for the EVM",
|
|
}
|
|
VerbosityFlag = cli.IntFlag{
|
|
Name: "verbosity",
|
|
Usage: "sets the verbosity level",
|
|
}
|
|
BenchFlag = cli.BoolFlag{
|
|
Name: "bench",
|
|
Usage: "benchmark the execution",
|
|
}
|
|
CreateFlag = cli.BoolFlag{
|
|
Name: "create",
|
|
Usage: "indicates the action should be create rather than call",
|
|
}
|
|
GenesisFlag = cli.StringFlag{
|
|
Name: "prestate",
|
|
Usage: "JSON file with prestate (genesis) config",
|
|
}
|
|
MachineFlag = cli.BoolFlag{
|
|
Name: "json",
|
|
Usage: "output trace logs in machine readable format (json)",
|
|
}
|
|
SenderFlag = cli.StringFlag{
|
|
Name: "sender",
|
|
Usage: "The transaction origin",
|
|
}
|
|
ReceiverFlag = cli.StringFlag{
|
|
Name: "receiver",
|
|
Usage: "The transaction receiver (execution context)",
|
|
}
|
|
DisableMemoryFlag = cli.BoolFlag{
|
|
Name: "nomemory",
|
|
Usage: "disable memory output",
|
|
}
|
|
DisableStackFlag = cli.BoolFlag{
|
|
Name: "nostack",
|
|
Usage: "disable stack output",
|
|
}
|
|
DisableStorageFlag = cli.BoolFlag{
|
|
Name: "nostorage",
|
|
Usage: "disable storage output",
|
|
}
|
|
DisableReturnDataFlag = cli.BoolFlag{
|
|
Name: "noreturndata",
|
|
Usage: "disable return data output",
|
|
}
|
|
EVMInterpreterFlag = cli.StringFlag{
|
|
Name: "vm.evm",
|
|
Usage: "External EVM configuration (default = built-in interpreter)",
|
|
Value: "",
|
|
}
|
|
)
|
|
|
|
var stateTransitionCommand = cli.Command{
|
|
Name: "transition",
|
|
Aliases: []string{"t8n"},
|
|
Usage: "executes a full state transition",
|
|
Action: t8ntool.Main,
|
|
Flags: []cli.Flag{
|
|
t8ntool.TraceFlag,
|
|
t8ntool.TraceDisableMemoryFlag,
|
|
t8ntool.TraceDisableStackFlag,
|
|
t8ntool.TraceDisableReturnDataFlag,
|
|
t8ntool.OutputAllocFlag,
|
|
t8ntool.OutputResultFlag,
|
|
t8ntool.InputAllocFlag,
|
|
t8ntool.InputEnvFlag,
|
|
t8ntool.InputTxsFlag,
|
|
t8ntool.ForknameFlag,
|
|
t8ntool.ChainIDFlag,
|
|
t8ntool.RewardFlag,
|
|
t8ntool.VerbosityFlag,
|
|
},
|
|
}
|
|
|
|
func init() {
|
|
app.Flags = []cli.Flag{
|
|
BenchFlag,
|
|
CreateFlag,
|
|
DebugFlag,
|
|
VerbosityFlag,
|
|
CodeFlag,
|
|
CodeFileFlag,
|
|
GasFlag,
|
|
PriceFlag,
|
|
ValueFlag,
|
|
DumpFlag,
|
|
InputFlag,
|
|
InputFileFlag,
|
|
MemProfileFlag,
|
|
CPUProfileFlag,
|
|
StatDumpFlag,
|
|
GenesisFlag,
|
|
MachineFlag,
|
|
SenderFlag,
|
|
ReceiverFlag,
|
|
DisableMemoryFlag,
|
|
DisableStackFlag,
|
|
DisableStorageFlag,
|
|
DisableReturnDataFlag,
|
|
EVMInterpreterFlag,
|
|
}
|
|
app.Commands = []cli.Command{
|
|
compileCommand,
|
|
disasmCommand,
|
|
runCommand,
|
|
stateTestCommand,
|
|
stateTransitionCommand,
|
|
}
|
|
cli.CommandHelpTemplate = flags.OriginCommandHelpTemplate
|
|
}
|
|
|
|
func main() {
|
|
if err := app.Run(os.Args); err != nil {
|
|
code := 1
|
|
if ec, ok := err.(*t8ntool.NumberedError); ok {
|
|
code = ec.Code()
|
|
}
|
|
fmt.Fprintln(os.Stderr, err)
|
|
os.Exit(code)
|
|
}
|
|
}
|