forked from maticnetwork/bor
-
Notifications
You must be signed in to change notification settings - Fork 4
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
merge V0.2.12 candidate (#7) #8
Merged
Merged
Conversation
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
* core/vm: rework jumpdest analysis benchmarks (#23499) * core/vm: rework jumpdest analysis benchmarks For BenchmarkJumpdestOpAnalysis use fixed code size of ~1.2MB and classic benchmark loop. * core/vm: clear bitvec in jumpdest analysis benchmark * docs: add links to more audits in SECURITY.md (#23482) * core: fix typo in iterator.go (#23502) strorage -> storage * common: fixes format verb (#23495) * core: fix race conditions in txpool (#23474) * core: fix race conditions in txpool * core: fixed races in the txpool * core: rebased on master * core: move reheap mutex * core: renamed mutex * core: revert Reheap changes * cmd/evm: add tests for evm t8n (#23507) * trie: add missing copyright header (#23530) * Add missing copyright header * Update stacktrie_test.go Co-authored-by: Péter Szilágyi <peterke@gmail.com> * docs: add post-mortem (#23518) * docs: add post-mortem * Update docs/postmortems/2021-08-22-split-postmortem.md Co-authored-by: Sina Mahmoodi <1591639+s1na@users.noreply.github.com> * Update docs/postmortems/2021-08-22-split-postmortem.md Co-authored-by: Sina Mahmoodi <1591639+s1na@users.noreply.github.com> * Update docs/postmortems/2021-08-22-split-postmortem.md Co-authored-by: Sina Mahmoodi <1591639+s1na@users.noreply.github.com> * Update docs/postmortems/2021-08-22-split-postmortem.md * Update 2021-08-22-split-postmortem.md * Update docs/postmortems/2021-08-22-split-postmortem.md Co-authored-by: Sina Mahmoodi <1591639+s1na@users.noreply.github.com> Co-authored-by: Sina Mahmoodi <1591639+s1na@users.noreply.github.com> * internal/debug: remove deprecated flags (#23368) * internal/debug: remove deprecated flags The removed flags are removed in the main portion of geth, this removes it internally too. * internal/debug: remove legacy --debug and legacy --backtrace flag * Update flags.go Co-authored-by: Martin Holst Swende <martin@swende.se> * cmd/geth, cmd/utils: remove legacy rpc flags (#23358) * remove rpc flags * remove legacy rpc flags * remove legacy rpc flags * remove legacy rpc commands * (hopefully) fix most of the build errors * fix build errors https://app.travis-ci.com/github/ethereum/go-ethereum/jobs/530318686 * cmd/utils: fix syntax error * empty commit to unbreak travis ci * fix syntax error * syntax fixes * syntax fixes * fix fixes "cmd/geth/usage.go:234:7: expected '(', found init (typecheck)" * fix * various fixes in usage.go * various fixes in flags.go * adds extra space reverts the spacing to how it was before I resolved the merge conflict * more fixes in usage.go * fix fix for cmd/geth/usage.go:243:17: expected operand, found ':=' (typecheck) in travis * Update cmd/utils/flags.go Co-authored-by: Martin Holst Swende <martin@swende.se> * fix error fixes these errors: cmd/utils/flags_legacy.go:21:2: "strings" imported but not used (typecheck) "strings" ^ cmd/utils/flags_legacy.go:24:2: "github.com/ethereum/go-ethereum/node" imported but not used (typecheck) "github.com/ethereum/go-ethereum/node" ^ * goimports Co-authored-by: Martin Holst Swende <martin@swende.se> * core/rawdb: freezer batch write (#23462) This change is a rewrite of the freezer code. When writing ancient chain data to the freezer, the previous version first encoded each individual item to a temporary buffer, then wrote the buffer. For small item sizes (for example, in the block hash freezer table), this strategy causes a lot of system calls for writing tiny chunks of data. It also allocated a lot of temporary []byte buffers. In the new version, we instead encode multiple items into a re-useable batch buffer, which is then written to the file all at once. This avoids performing a system call for every inserted item. To make the internal batching work, the ancient database API had to be changed. While integrating this new API in BlockChain.InsertReceiptChain, additional optimizations were also added there. Co-authored-by: Felix Lange <fjl@twurst.com> * p2p/enode: use unix timestamp as base ENR sequence number (#19903) This PR ensures that wiping all data associated with a node (apart from its nodekey) will not generate already used sequence number for the ENRs, since all remote nodes would reject them until they out-number the previously published largest one. The big complication with this scheme is that every local update to the ENR can potentially bump the sequence number by one. In order to ensure that local updates do not outrun the clock, the sequence number is a millisecond-precision timestamp, and updates are throttled to occur at most once per millisecond. Co-authored-by: Felix Lange <fjl@twurst.com> * core: make txPricedList.stales the first field for 64bit alignment (#23542) This fixes crashes on 32bit builds. * core: 64bit alignment of testBlockChain.gasLimit (#23543) This fixes crashes in txpool tests on 32bit platforms. * appveyor.yml: add linux/amd64 build job (#23548) * les: duplicate downloader and fetcher to allow progressive refactoring * README: add londonBlock to example genesis config (#23565) Updated example genesis.json configuration section, added londonBlock within config. * cmd/evm: transaction validation tool (#23494) * cmd/evm: transaction validation tool * cmd/evm: add hash to t9n tool * cmd/evm: lint nits * cmd/evm: nitpicks * core, rpc: disable memory output by default in traces (#23558) * core: cmd: invert disableMemory * core: fix missed inversion * cmd/evm: preserve Flags but change default value * Apply suggestions from code review Co-authored-by: Martin Holst Swende <martin@swende.se> Co-authored-by: Martin Holst Swende <martin@swende.se> * cmd/devp2p/internal/ethtest: only use eth66 if eth66 is negotiated (#23568) * cmd/devp2p/internal/ethtest: only use eth66 if eth66 is negotiated * cmd/devp2p/internal/ethtest: switch on concrete type not pointer * cmd/devp2p/internal/ethtest: switch on concrete type not pointer * eth/tracers: abort evm execution when trace is aborted (#23580) * core,eth: call frame tracing (#23087) This change introduces 2 new optional methods; `enter()` and `exit()` for js tracers, and makes `step()` optiona. The two new methods are invoked when entering and exiting a call frame (but not invoked for the outermost scope, which has it's own methods). Currently these are the data fields passed to each of them: enter: type (opcode), from, to, input, gas, value exit: output, gasUsed, error The PR also comes with a re-write of the callTracer. As a backup we keep the previous tracing script under the name `callTracerLegacy`. Behaviour of both tracers are equivalent for the most part, although there are some small differences (improvements), where the new tracer is more correct / has more information. * ethclient, accounts/keystore: fix flaky tests (#23599) * ethclient/gethclient: fix flaky test (due to map key ordering) * accounts/keystore: fix test failing due to rand collision due to low time resolution on windows * docs: fix spelling on 2021-08-22 postmortem (#23595) Spelling update * internal: support optional filter expression for debug.stacks (#23605) * internal: support optional filter expression for debug.stacks * internal/debug: fix string regexp * internal/debug: support searching for line numbers too * internal/debug: make gosimple linter happy * go.mod: fix module file to prevent go from updating it during build * console: add note about typing exit to exit (#23602) * add explicit note about typing exit in console * Add note about typing exit as alternative * consensus/clique: prevent 0 len extradata from panicing (#23538) Closes #23522 Co-authored-by: Martin Holst Swende <martin@swende.se> * rpc: set scheme for ws and ipc conns to the server (#23615) * rpc: set scheme for ws and ipc conns to the server * rpc: review fixes * rpc: bugfix * rpc: empty default scheme * accounts/abi: fix resolving single struct argument (#23573) * rpc: set pong read deadline (#23556) This PR adds a 30s timeout for the remote part to answer a ping message, thus detecting (silent) disconnnects * cmd/puppeth: remove shh from Dockerfile (#23634) * eth/tracers: re-write of 4byte tracer using enter/exit (#23622) * eth/tracers: add re-write of 4byte tracer using enter/exit * eth/tracers: fix 4byte indent * core/state: move state account to core/types + abstracted "write account to trie" (#23567) * core/state: abstracted "write account to trie" method * fix appveyor build * Apply suggestions from code review Co-authored-by: Martin Holst Swende <martin@swende.se> * review feedback * core/state/accounts: move Account to core/types * core/types: rename Account -> StateAccount * core/state: restore EncodeRLP for stateObject * core/types: add the missing file * more review feedback * more review feedback Co-authored-by: Martin Holst Swende <martin@swende.se> Co-authored-by: Felix Lange <fjl@twurst.com> * eth/tracers: implement debug.intermediateRoots (#23594) This PR implements a new debug method, which I've talked briefly about to some other client developers. It allows the caller to obtain the intermediate state roots for a block (which might be either a canon block or a 'bad' block). * core/rawdb: avoid unnecessary receipt processing for log filtering (#23147) * core/types: rm extranous check in test * core/rawdb: add lightweight types for block logs * core/rawdb,eth: use lightweight accessor for log filtering * core/rawdb: add bench for decoding into rlpLogs * accounts/abi/bind: check event signature before parsing (#23230) * accounts/abi/bind: check event signature before parsing * remove redundant break line * eth/tracers: avoid unsyncronized mutations on trie database (#23632) This PR fixes an issue in traceChain, where the statedb Commit operation was performed asynchronously with dereference-operations agains the underlying trie.Database instance. Due to how the reference counting works within the trie database (where parent count is recursively updated when new parents are added), doing dereferencing in the middle of Commit can cause the refcount to become wrong, leading to an inconsistent state. This was fixed by doing Commit/Deref from the same routine. * eth/protocols/eth: simplify peer known block/txs caches (#23649) * Simplify peer known block/txns cache * Address minor changes * Add more minor comments * Minor changes from review * graphql: add storage slots to access list (#23650) Fixes #23640 * eth/protocols/snap, trie: better error-handling (#23657) * params: release go-ethereum v1.10.9 stable * params: begin v1.10.10 release cycle * core: fix typo in comment (#23658) * internal/ethapi: support retrieving header RLPs too * eth/tracers: fix callTracer fault handling (#23667) * eth/tracers: fix calltracer fault handling * eth/tracers: fix calltracer indentation * internal/ethapi: make header/block rlp retrieval canonical * core/state: fix typo in comment (#23665) * eth/filters: fix TestPendingLogsSubscription (#23619) The test did not synchronize with per-case goroutines, and thus didn't notice that some tests were just hanging. This change adds missing synchronization and fixes the broken tests. * eth/protocols/eth: replace array with counter in txn broadcaster (#23656) * eth/api: add rpc method to obtain which states are accessible (#23646) This PR adds a method to the debug namespace, to iterate over the blocks and check where we have the roots on disk. * go.mod: upgrade github.com/karalable/usb (#23684) This update includes fixes for the *BSD build and go module vendoring. * core/types: copy tx recipient address (#23376) This resolves a long-standing TODO. The point of copying the address is to ensure that all data referenced by types.Transaction is independent of the data passed into the constructor. Co-authored-by: Felix Lange <fjl@twurst.com> * core: improve shutdown synchronization in BlockChain (#22853) This change removes misuses of sync.WaitGroup in BlockChain. Before this change, block insertion modified the WaitGroup counter in order to ensure that Stop would wait for pending operations to complete. This was racy and could even lead to crashes if Stop was called at an unfortunate time. The issue is resolved by adding a specialized 'closable' mutex, which prevents chain modifications after stopping while also synchronizing writers with each other. Co-authored-by: Felix Lange <fjl@twurst.com> * internal/ethapi: use correct signer when serving old blocks (#23683) Fixes #23681 After the fix I get the address 0x6d6d02e83c4ced98204e20126acf27e9d87b8af2 for the tx mentioned in the ticket, which agrees with etherscan. * cmd/geth: fix typo in error message (#23697) * build: upgrade -dlgo version to 1.17.2 (#23698) Go 1.17.2 fixes some miscompilation issues on amd64 and a runtime issue with timers. While the upgrade is not strictly necessary for go-ethereum right now, it is still good to be up-to-date. * eth: close miner on exit (instead of just stopping) (#21992) This ensures that all miner goroutines have exited before stopping the blockchain. Co-authored-by: Felix Lange <fjl@twurst.com> * miner: fix data race during shutdown (#23435) This fixes a data race on worker.current by moving the call to StopPrefetcher into the main loop. The commit also contains fixes for two other races in unit tests of unrelated packages. * miner/stress: initialize account backends explicitly (#23699) node.Node no longer registers any account manager backends by default, they need to be registered explicitly. For ethash-based tests, we actually don't need any accounts in the miner keystore. Just set the etherbase instead to make mining work. For clique, the signer account must be in the keystore. The change also adds interrupt handling in stress tests. * internal/jsre: handle null and undefined to prevent crash (#23701) This prevents the console from crashing when auto-completing on a variable or property that is null or undefined. Fixes #23693 * core/state: fix typos in comments (#23702) * eth/gasprice: avoid modifying TestChainConfig (#23204) Co-authored-by: Felix Lange <fjl@twurst.com> * cmd/puppeth: add txpool to explorer Dockerfile (#23652) * cmd/evm: stricter transaction validation (#23694) * cmd/evm: t9n: validate transaction intrinsic gas * cmd/evm: t9n: stricter tx validation * build: increase C thread stack size on linux (#23676) * build: increase thread stack size when running alpine linux * review feedback: force a stack size of 8M on all linux distribs * fix missing extldflags * params: changed CatalystBlock to TerminalTotalDifficulty (#23700) * params: changed CatalystBlock to TerminalTotalDifficulty * eth/catalyst: comment out unused code * les/vflux/server: fix metrics (#22946) * les/vflux/server: fix metrics * les/vflux/server: fix metrics * core: tests for forked blocks retrievable by hash (#23695) * Update tests to showcase that forked blocks can still be looked up by their hash * ci: enable race tests as cron job on travis (#23480) * consensus/clique, core: API cleanup (#23100) This removes some code: - The clique engine calculated the snapshot twice when verifying headers/blocks. - The method GetBlockHashesFromHash in Header/Block/Lightchain was only used by tests. It is now removed from the API. - The method GetTdByHash internally looked up the number before calling GetTd(hash, num). In many cases, callers already had the number, and used this method just because it has a shorter name. I have removed the method to make the API surface smaller. * fixed broken web3 methods link in README.md (#23703) * eth,rpc: allow for flag configured timeouts for eth_call (#23645) * eth,rpc: allow for flag configured timeouts for eth_call * lint: account for package-local import order * cr: rename `rpc.calltimeout` to `rpc.evmtimeout` * go.mod: upgrade goja (#23721) This update adds support for some more ES6 functionality, notably arrow functions. * core/types: add MarshalBinary, UnmarshalBinary for Receipt (#22806) * all: fix some go-critic linter warnings (#23709) This doesn't fix all go-critic warnings, just the most serious ones. Co-authored-by: Felix Lange <fjl@twurst.com> Co-authored-by: Martin Holst Swende <martin@swende.se> * accounts/abi/bind: refactor transact method (#23719) This fixes a bug where gas-related fields of the TransactOpts passed to transaction methods would be modified, skipping gas estimation for subsequent transactions. Co-authored-by: Yondon Fu <yondon.fu@gmail.com> Co-authored-by: Felix Lange <fjl@twurst.com> * core: remove unused error from TxPool.Pending (#23720) * accounts/abi: add basic support for error types (#23161) This is the initial step for support of Solidity errors in contract bindings. As of this change, errors can be decoded, but are not supported in bindings yet. Closes #23157 * core/state/snapshot: fix data race in layer flattening (#23628) * core/state/snapshot: fix data race in layer flattening * core/state/snapshot: fix typo * params: release go-ethereum v1.10.10 stable * Apply best practices to Dockerfile * Vendor protobuf and go extension issue PR (maticnetwork#223) * Vendor protobuf and go extension issue PR * Finalized the script * Quick fix * Final touches to Dockerfiles * Build the new CLI * Bump Go * Revert "Build the new CLI" This reverts commit e58bdfa. * Add chain set head command (maticnetwork#226) * Added Prometheus flag on bor-cli * Release multi-platform with goreleaser Packages, docker images CI automated * Added Prometheus to New CLI: fixes * minor Clean * Minor Clean-up * minor cleanup * Added Prometheus Flag and Default * added opentelemetry config, flags, and setup (maticnetwork#235) * added opentelemetry config, flags, and setup * modifications in opencollector flag and config * bug fix * modified error log * Adapt Dockerfile for development (maticnetwork#237) * Adapt Dockerfile for development The Dockerfile for release using Alpine is in the included Dockerfile.release and this one was not used for release so doesn't make sense to have it using multistage nor Alpine. * added service name in config and flags (maticnetwork#238) * fix: bor receipt #1 * Write bor receipts in ancient * fix: bor receipt rlp * fix: testcases * Arpit/reorg fix 2 (maticnetwork#210) * testing * author check * if else fix * Small tweeks to Dockerfiles (maticnetwork#247) Standardize Dockerfile between projects (Heimdall) and remove not necessary tini package. * Fix ancient receipts * Fix ancestor bor receipts (maticnetwork#249) * bumped version to 0.2.11 * Changed syncmode from fast to full * Genesis change fix (maticnetwork#252) * read from genesis file * add: set code in finalize and assemble * new: storing data in bor config * chg: remove unwanted code * chg: refactor * minor change * add error states * Fix small things * Add test * Add more coverage in genesis finalize test * Ensure balance is not changed * Add decode safe check * Change bor config block alloc field name * Remove block alloc values in blocks * Add genesis alloc code change info logging Co-authored-by: Ferran Borreguero <ferranbt@protonmail.com> * add block alloc * change block alloc * remove byte array * mainnet upgrade Co-authored-by: Paweł Bylica <chfast@gmail.com> Co-authored-by: Fredrik Svantes <fredrik@ethereum.org> Co-authored-by: Ikko Ashimine <eltociear@gmail.com> Co-authored-by: Alexander Yastrebov <yastrebov.alex@gmail.com> Co-authored-by: Marius van der Wijden <m.vanderwijden@live.de> Co-authored-by: Martin Holst Swende <martin@swende.se> Co-authored-by: aaronbuchwald <aaron.buchwald56@gmail.com> Co-authored-by: Péter Szilágyi <peterke@gmail.com> Co-authored-by: Sina Mahmoodi <1591639+s1na@users.noreply.github.com> Co-authored-by: Zachinquarantine <zachinquarantine@yahoo.com> Co-authored-by: Felix Lange <fjl@twurst.com> Co-authored-by: Jonathan Verhees <jonathan@verhe.es> Co-authored-by: Pete <90942436+peteyburgers@users.noreply.github.com> Co-authored-by: Thad Guidry <thadguidry@gmail.com> Co-authored-by: gary rong <garyrong0905@gmail.com> Co-authored-by: Jordan Krage <jmank88@gmail.com> Co-authored-by: Zachinquarantine <Zachinquarantine@protonmail.com> Co-authored-by: Guillaume Ballet <3272758+gballet@users.noreply.github.com> Co-authored-by: Yihau Chen <a122092487@gmail.com> Co-authored-by: Ferran Borreguero <ferranbt@protonmail.com> Co-authored-by: hsyodyssey <47173566+hsyodyssey@users.noreply.github.com> Co-authored-by: Miro <mirokuratczyk@users.noreply.github.com> Co-authored-by: Sean <darcys22@gmail.com> Co-authored-by: Aditya Arora <arora.aditya520@gmail.com> Co-authored-by: z89 <30657227+z89@users.noreply.github.com> Co-authored-by: noam-alchemy <76969113+noam-alchemy@users.noreply.github.com> Co-authored-by: Ian Norden <iannordenn@gmail.com> Co-authored-by: Iskander (Alex) Sharipov <i.sharipov@corp.vk.com> Co-authored-by: Yondon Fu <yondon.fu@gmail.com> Co-authored-by: jwasinger <j-wasinger@hotmail.com> Co-authored-by: Victor Castell <victor@victorcastell.com> Co-authored-by: Rajat Saxena <42701222+rajatlko13@users.noreply.github.com> Co-authored-by: Victor Castell <victor@polygon.technology> Co-authored-by: Shivam Sharma <shivam691999@gmail.com> Co-authored-by: Manav Darji <manavdarji.india@gmail.com> Co-authored-by: Sandeep Sreenath <sandeep.sreenath@gmail.com> Co-authored-by: Jaynti Kanani <jdkanani@gmail.com> Co-authored-by: Arpit Temani <temaniarpit27@gmail.com> Co-authored-by: Sandeep Sreenath <ssandeep@users.noreply.github.com>
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
core/vm: rework jumpdest analysis benchmarks (#23499)
core/vm: rework jumpdest analysis benchmarks
For BenchmarkJumpdestOpAnalysis use fixed code size of ~1.2MB
and classic benchmark loop.
core/vm: clear bitvec in jumpdest analysis benchmark
docs: add links to more audits in SECURITY.md (#23482)
core: fix typo in iterator.go (#23502)
strorage -> storage
common: fixes format verb (#23495)
core: fix race conditions in txpool (#23474)
core: fix race conditions in txpool
core: fixed races in the txpool
core: rebased on master
core: move reheap mutex
core: renamed mutex
core: revert Reheap changes
cmd/evm: add tests for evm t8n (#23507)
trie: add missing copyright header (#23530)
Add missing copyright header
Update stacktrie_test.go
Co-authored-by: Péter Szilágyi peterke@gmail.com
docs: add post-mortem (#23518)
docs: add post-mortem
Update docs/postmortems/2021-08-22-split-postmortem.md
Co-authored-by: Sina Mahmoodi 1591639+s1na@users.noreply.github.com
Co-authored-by: Sina Mahmoodi 1591639+s1na@users.noreply.github.com
Co-authored-by: Sina Mahmoodi 1591639+s1na@users.noreply.github.com
Update docs/postmortems/2021-08-22-split-postmortem.md
Update 2021-08-22-split-postmortem.md
Update docs/postmortems/2021-08-22-split-postmortem.md
Co-authored-by: Sina Mahmoodi 1591639+s1na@users.noreply.github.com
Co-authored-by: Sina Mahmoodi 1591639+s1na@users.noreply.github.com
internal/debug: remove deprecated flags (#23368)
internal/debug: remove deprecated flags
The removed flags are removed in the main portion of geth, this removes it internally too.
internal/debug: remove legacy --debug and legacy --backtrace flag
Update flags.go
Co-authored-by: Martin Holst Swende martin@swende.se
cmd/geth, cmd/utils: remove legacy rpc flags (#23358)
remove rpc flags
remove legacy rpc flags
remove legacy rpc flags
remove legacy rpc commands
(hopefully) fix most of the build errors
fix build errors
https://app.travis-ci.com/github/ethereum/go-ethereum/jobs/530318686
cmd/utils: fix syntax error
empty commit to unbreak travis ci
fix syntax error
syntax fixes
syntax fixes
fix
fixes "cmd/geth/usage.go:234:7: expected '(', found init (typecheck)"
fix
various fixes in usage.go
various fixes in flags.go
adds extra space
reverts the spacing to how it was before I resolved the merge conflict
more fixes in usage.go
fix
fix for cmd/geth/usage.go:243:17: expected operand, found ':=' (typecheck) in travis
Co-authored-by: Martin Holst Swende martin@swende.se
fixes these errors:
cmd/utils/flags_legacy.go:21:2: "strings" imported but not used (typecheck)
cmd/utils/flags_legacy.go:24:2: "github.com/ethereum/go-ethereum/node" imported but not used (typecheck)
Co-authored-by: Martin Holst Swende martin@swende.se
This change is a rewrite of the freezer code.
When writing ancient chain data to the freezer, the previous version first encoded each
individual item to a temporary buffer, then wrote the buffer. For small item sizes (for
example, in the block hash freezer table), this strategy causes a lot of system calls for
writing tiny chunks of data. It also allocated a lot of temporary []byte buffers.
In the new version, we instead encode multiple items into a re-useable batch buffer, which
is then written to the file all at once. This avoids performing a system call for every
inserted item.
To make the internal batching work, the ancient database API had to be changed. While
integrating this new API in BlockChain.InsertReceiptChain, additional optimizations were
also added there.
Co-authored-by: Felix Lange fjl@twurst.com
This PR ensures that wiping all data associated with a node (apart from its nodekey)
will not generate already used sequence number for the ENRs, since all remote nodes
would reject them until they out-number the previously published largest one.
The big complication with this scheme is that every local update to the ENR can
potentially bump the sequence number by one. In order to ensure that local updates
do not outrun the clock, the sequence number is a millisecond-precision timestamp,
and updates are throttled to occur at most once per millisecond.
Co-authored-by: Felix Lange fjl@twurst.com
This fixes crashes on 32bit builds.
This fixes crashes in txpool tests on 32bit platforms.
appveyor.yml: add linux/amd64 build job (#23548)
les: duplicate downloader and fetcher to allow progressive refactoring
README: add londonBlock to example genesis config (#23565)
Updated example genesis.json configuration section, added londonBlock within config.
cmd/evm: transaction validation tool (#23494)
cmd/evm: transaction validation tool
cmd/evm: add hash to t9n tool
cmd/evm: lint nits
cmd/evm: nitpicks
core, rpc: disable memory output by default in traces (#23558)
core: cmd: invert disableMemory
core: fix missed inversion
cmd/evm: preserve Flags but change default value
Apply suggestions from code review
Co-authored-by: Martin Holst Swende martin@swende.se
Co-authored-by: Martin Holst Swende martin@swende.se
cmd/devp2p/internal/ethtest: only use eth66 if eth66 is negotiated (#23568)
cmd/devp2p/internal/ethtest: only use eth66 if eth66 is negotiated
cmd/devp2p/internal/ethtest: switch on concrete type not pointer
cmd/devp2p/internal/ethtest: switch on concrete type not pointer
eth/tracers: abort evm execution when trace is aborted (#23580)
core,eth: call frame tracing (#23087)
This change introduces 2 new optional methods;
enter()
andexit()
for js tracers, and makesstep()
optiona. The two new methods are invoked when entering and exiting a call frame (but not invoked for the outermost scope, which has it's own methods). Currently these are the data fields passed to each of them:The PR also comes with a re-write of the callTracer. As a backup we keep the previous tracing script under the name
callTracerLegacy
. Behaviour of both tracers are equivalent for the most part, although there are some small differences (improvements), where the new tracer is more correct / has more information.ethclient, accounts/keystore: fix flaky tests (#23599)
ethclient/gethclient: fix flaky test (due to map key ordering)
accounts/keystore: fix test failing due to rand collision due to low time resolution on windows
docs: fix spelling on 2021-08-22 postmortem (#23595)
Spelling update
internal: support optional filter expression for debug.stacks (#23605)
internal: support optional filter expression for debug.stacks
internal/debug: fix string regexp
internal/debug: support searching for line numbers too
internal/debug: make gosimple linter happy
go.mod: fix module file to prevent go from updating it during build
console: add note about typing exit to exit (#23602)
add explicit note about typing exit in console
Add note about typing exit as alternative
consensus/clique: prevent 0 len extradata from panicing (#23538)
Closes #23522
Co-authored-by: Martin Holst Swende martin@swende.se
rpc: set scheme for ws and ipc conns to the server (#23615)
rpc: set scheme for ws and ipc conns to the server
rpc: review fixes
rpc: bugfix
rpc: empty default scheme
accounts/abi: fix resolving single struct argument (#23573)
rpc: set pong read deadline (#23556)
This PR adds a 30s timeout for the remote part to answer a ping message, thus detecting (silent) disconnnects
cmd/puppeth: remove shh from Dockerfile (#23634)
eth/tracers: re-write of 4byte tracer using enter/exit (#23622)
eth/tracers: add re-write of 4byte tracer using enter/exit
eth/tracers: fix 4byte indent
core/state: move state account to core/types + abstracted "write account to trie" (#23567)
core/state: abstracted "write account to trie" method
fix appveyor build
Apply suggestions from code review
Co-authored-by: Martin Holst Swende martin@swende.se
review feedback
core/state/accounts: move Account to core/types
core/types: rename Account -> StateAccount
core/state: restore EncodeRLP for stateObject
core/types: add the missing file
more review feedback
more review feedback
Co-authored-by: Martin Holst Swende martin@swende.se
Co-authored-by: Felix Lange fjl@twurst.com
This PR implements a new debug method, which I've talked briefly about to some other client developers. It allows the caller to obtain the intermediate state roots for a block (which might be either a canon block or a 'bad' block).
core/rawdb: avoid unnecessary receipt processing for log filtering (#23147)
core/types: rm extranous check in test
core/rawdb: add lightweight types for block logs
core/rawdb,eth: use lightweight accessor for log filtering
core/rawdb: add bench for decoding into rlpLogs
accounts/abi/bind: check event signature before parsing (#23230)
accounts/abi/bind: check event signature before parsing
remove redundant break line
eth/tracers: avoid unsyncronized mutations on trie database (#23632)
This PR fixes an issue in traceChain, where the statedb Commit operation was performed asynchronously with dereference-operations agains the underlying trie.Database instance. Due to how the reference counting works within the trie database (where parent count is recursively updated when new parents are added), doing dereferencing in the middle of Commit can cause the refcount to become wrong, leading to an inconsistent state.
This was fixed by doing Commit/Deref from the same routine.
eth/protocols/eth: simplify peer known block/txs caches (#23649)
Simplify peer known block/txns cache
Address minor changes
Add more minor comments
Minor changes from review
graphql: add storage slots to access list (#23650)
Fixes #23640
eth/protocols/snap, trie: better error-handling (#23657)
params: release go-ethereum v1.10.9 stable
params: begin v1.10.10 release cycle
core: fix typo in comment (#23658)
internal/ethapi: support retrieving header RLPs too
eth/tracers: fix callTracer fault handling (#23667)
eth/tracers: fix calltracer fault handling
eth/tracers: fix calltracer indentation
internal/ethapi: make header/block rlp retrieval canonical
core/state: fix typo in comment (#23665)
eth/filters: fix TestPendingLogsSubscription (#23619)
The test did not synchronize with per-case goroutines, and thus didn't notice
that some tests were just hanging. This change adds missing synchronization
and fixes the broken tests.
eth/protocols/eth: replace array with counter in txn broadcaster (#23656)
eth/api: add rpc method to obtain which states are accessible (#23646)
This PR adds a method to the debug namespace, to iterate over the blocks and check where we have the roots on disk.
This update includes fixes for the *BSD build and go module vendoring.
This resolves a long-standing TODO. The point of copying the address is
to ensure that all data referenced by types.Transaction is independent of the
data passed into the constructor.
Co-authored-by: Felix Lange fjl@twurst.com
This change removes misuses of sync.WaitGroup in BlockChain. Before this change,
block insertion modified the WaitGroup counter in order to ensure that Stop would wait
for pending operations to complete. This was racy and could even lead to crashes
if Stop was called at an unfortunate time. The issue is resolved by adding a specialized
'closable' mutex, which prevents chain modifications after stopping while also
synchronizing writers with each other.
Co-authored-by: Felix Lange fjl@twurst.com
Fixes #23681
After the fix I get the address 0x6d6d02e83c4ced98204e20126acf27e9d87b8af2 for the
tx mentioned in the ticket, which agrees with etherscan.
cmd/geth: fix typo in error message (#23697)
build: upgrade -dlgo version to 1.17.2 (#23698)
Go 1.17.2 fixes some miscompilation issues on amd64 and a runtime issue with timers.
While the upgrade is not strictly necessary for go-ethereum right now, it is still good
to be up-to-date.
This ensures that all miner goroutines have exited before stopping the blockchain.
Co-authored-by: Felix Lange fjl@twurst.com
This fixes a data race on worker.current by moving the call to StopPrefetcher
into the main loop.
The commit also contains fixes for two other races in unit tests of unrelated packages.
node.Node no longer registers any account manager backends by default,
they need to be registered explicitly.
For ethash-based tests, we actually don't need any accounts in the miner
keystore. Just set the etherbase instead to make mining work. For
clique, the signer account must be in the keystore.
The change also adds interrupt handling in stress tests.
This prevents the console from crashing when auto-completing on
a variable or property that is null or undefined.
Fixes #23693
core/state: fix typos in comments (#23702)
eth/gasprice: avoid modifying TestChainConfig (#23204)
Co-authored-by: Felix Lange fjl@twurst.com
cmd/puppeth: add txpool to explorer Dockerfile (#23652)
cmd/evm: stricter transaction validation (#23694)
cmd/evm: t9n: validate transaction intrinsic gas
cmd/evm: t9n: stricter tx validation
build: increase C thread stack size on linux (#23676)
build: increase thread stack size when running alpine linux
review feedback: force a stack size of 8M on all linux distribs
fix missing extldflags
params: changed CatalystBlock to TerminalTotalDifficulty (#23700)
params: changed CatalystBlock to TerminalTotalDifficulty
eth/catalyst: comment out unused code
les/vflux/server: fix metrics (#22946)
les/vflux/server: fix metrics
les/vflux/server: fix metrics
core: tests for forked blocks retrievable by hash (#23695)
Update tests to showcase that forked blocks can still be looked up by their hash
ci: enable race tests as cron job on travis (#23480)
consensus/clique, core: API cleanup (#23100)
This removes some code:
The clique engine calculated the snapshot twice when verifying headers/blocks.
The method GetBlockHashesFromHash in Header/Block/Lightchain was only used by tests. It
is now removed from the API.
The method GetTdByHash internally looked up the number before calling GetTd(hash, num).
In many cases, callers already had the number, and used this method just because it has a
shorter name. I have removed the method to make the API surface smaller.
fixed broken web3 methods link in README.md (#23703)
eth,rpc: allow for flag configured timeouts for eth_call (#23645)
eth,rpc: allow for flag configured timeouts for eth_call
lint: account for package-local import order
cr: rename
rpc.calltimeout
torpc.evmtimeout
go.mod: upgrade goja (#23721)
This update adds support for some more ES6 functionality, notably
arrow functions.
core/types: add MarshalBinary, UnmarshalBinary for Receipt (#22806)
all: fix some go-critic linter warnings (#23709)
This doesn't fix all go-critic warnings, just the most serious ones.
Co-authored-by: Felix Lange fjl@twurst.com
Co-authored-by: Martin Holst Swende martin@swende.se
This fixes a bug where gas-related fields of the TransactOpts passed
to transaction methods would be modified, skipping gas estimation for
subsequent transactions.
Co-authored-by: Yondon Fu yondon.fu@gmail.com
Co-authored-by: Felix Lange fjl@twurst.com
core: remove unused error from TxPool.Pending (#23720)
accounts/abi: add basic support for error types (#23161)
This is the initial step for support of Solidity errors in contract bindings.
As of this change, errors can be decoded, but are not supported in
bindings yet.
Closes #23157
core/state/snapshot: fix data race in layer flattening (#23628)
core/state/snapshot: fix data race in layer flattening
core/state/snapshot: fix typo
params: release go-ethereum v1.10.10 stable
Apply best practices to Dockerfile
Vendor protobuf and go extension issue PR (Vendor protobuf and go extension issue PR maticnetwork/bor#223)
Vendor protobuf and go extension issue PR
Finalized the script
Quick fix
Final touches to Dockerfiles
Build the new CLI
Bump Go
Revert "Build the new CLI"
This reverts commit e58bdfa.
Add chain set head command (Add chain set head command maticnetwork/bor#226)
Added Prometheus flag on bor-cli
Release multi-platform with goreleaser
Packages, docker images CI automated
Added Prometheus to New CLI: fixes
minor Clean
Minor Clean-up
minor cleanup
Added Prometheus Flag and Default
added opentelemetry config, flags, and setup (added opentelemetry config, flags, and setup maticnetwork/bor#235)
added opentelemetry config, flags, and setup
modifications in opencollector flag and config
bug fix
modified error log
Adapt Dockerfile for development (Adapt Dockerfile for development maticnetwork/bor#237)
Adapt Dockerfile for development
The Dockerfile for release using Alpine is in the included Dockerfile.release and this one was not used for release so doesn't make sense to have it using multistage nor Alpine.
added service name in config and flags (added service name in config and flags maticnetwork/bor#238)
fix: bor receipt Add Replacement to Drop Feed + Expand Payload #1
Write bor receipts in ancient
fix: bor receipt rlp
fix: testcases
Arpit/reorg fix 2 (Arpit/reorg fix 2 maticnetwork/bor#210)
testing
author check
if else fix
Small tweeks to Dockerfiles (Small tweeks to Dockerfiles maticnetwork/bor#247)
Standardize Dockerfile between projects (Heimdall) and remove not necessary tini package.
Fix ancient receipts
Fix ancestor bor receipts (Fix ancestor bor receipts maticnetwork/bor#249)
bumped version to 0.2.11
Changed syncmode from fast to full
Genesis change fix (Genesis change fix maticnetwork/bor#252)
read from genesis file
add: set code in finalize and assemble
new: storing data in bor config
chg: remove unwanted code
chg: refactor
minor change
add error states
Fix small things
Add test
Add more coverage in genesis finalize test
Ensure balance is not changed
Add decode safe check
Change bor config block alloc field name
Remove block alloc values in blocks
Add genesis alloc code change info logging
Co-authored-by: Ferran Borreguero ferranbt@protonmail.com
add block alloc
change block alloc
remove byte array
mainnet upgrade
Co-authored-by: Paweł Bylica chfast@gmail.com
Co-authored-by: Fredrik Svantes fredrik@ethereum.org
Co-authored-by: Ikko Ashimine eltociear@gmail.com
Co-authored-by: Alexander Yastrebov yastrebov.alex@gmail.com
Co-authored-by: Marius van der Wijden m.vanderwijden@live.de
Co-authored-by: Martin Holst Swende martin@swende.se
Co-authored-by: aaronbuchwald aaron.buchwald56@gmail.com
Co-authored-by: Péter Szilágyi peterke@gmail.com
Co-authored-by: Sina Mahmoodi 1591639+s1na@users.noreply.github.com
Co-authored-by: Zachinquarantine zachinquarantine@yahoo.com
Co-authored-by: Felix Lange fjl@twurst.com
Co-authored-by: Jonathan Verhees jonathan@verhe.es
Co-authored-by: Pete 90942436+peteyburgers@users.noreply.github.com
Co-authored-by: Thad Guidry thadguidry@gmail.com
Co-authored-by: gary rong garyrong0905@gmail.com
Co-authored-by: Jordan Krage jmank88@gmail.com
Co-authored-by: Zachinquarantine Zachinquarantine@protonmail.com
Co-authored-by: Guillaume Ballet 3272758+gballet@users.noreply.github.com
Co-authored-by: Yihau Chen a122092487@gmail.com
Co-authored-by: Ferran Borreguero ferranbt@protonmail.com
Co-authored-by: hsyodyssey 47173566+hsyodyssey@users.noreply.github.com
Co-authored-by: Miro mirokuratczyk@users.noreply.github.com
Co-authored-by: Sean darcys22@gmail.com
Co-authored-by: Aditya Arora arora.aditya520@gmail.com
Co-authored-by: z89 30657227+z89@users.noreply.github.com
Co-authored-by: noam-alchemy 76969113+noam-alchemy@users.noreply.github.com
Co-authored-by: Ian Norden iannordenn@gmail.com
Co-authored-by: Iskander (Alex) Sharipov i.sharipov@corp.vk.com
Co-authored-by: Yondon Fu yondon.fu@gmail.com
Co-authored-by: jwasinger j-wasinger@hotmail.com
Co-authored-by: Victor Castell victor@victorcastell.com
Co-authored-by: Rajat Saxena 42701222+rajatlko13@users.noreply.github.com
Co-authored-by: Victor Castell victor@polygon.technology
Co-authored-by: Shivam Sharma shivam691999@gmail.com
Co-authored-by: Manav Darji manavdarji.india@gmail.com
Co-authored-by: Sandeep Sreenath sandeep.sreenath@gmail.com
Co-authored-by: Jaynti Kanani jdkanani@gmail.com
Co-authored-by: Arpit Temani temaniarpit27@gmail.com
Co-authored-by: Sandeep Sreenath ssandeep@users.noreply.github.com