Skip to content
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

Svnn ibc proof generation #36

Closed
wants to merge 1,613 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
1613 commits
Select commit Hold shift + click to select a range
66885fe
GH-2057 Correctly handle proposer schedule transition from legacy to …
heifner Mar 18, 2024
91cbeac
Merge remote-tracking branch 'origin/main' into merge-main-03-18-2024
heifner Mar 18, 2024
98c08c3
Fix merge issue
heifner Mar 18, 2024
1e0ca13
Merge remote-tracking branch 'origin/hotstuff_integration' into GH-20…
heifner Mar 18, 2024
23fbe2d
GH-2057 Update asserts for IRREVERSIBLE mode
heifner Mar 18, 2024
55717d1
make head_finality_data() return std::optional<finality_data_t>
linh2931 Mar 18, 2024
03ac11e
Merge pull request #2319 from AntelopeIO/merge-main-03-18-2024
heifner Mar 18, 2024
a3a0a6f
small refactoring in state_history_plugin.cpp
linh2931 Mar 18, 2024
ad09408
GH-2057 Add helper template for extracting header extensions
heifner Mar 18, 2024
fe11657
GH-2057 Cleanup
heifner Mar 18, 2024
ef9d7e3
GH-2057 Stop using legacy forkdb on close when no longer needed
heifner Mar 19, 2024
b73937f
Merge remote-tracking branch 'origin/hotstuff_integration' into GH-20…
heifner Mar 19, 2024
46cefb5
GH-2057 Update deepmind logs
heifner Mar 19, 2024
bc5ba05
GH-2057 Add snapshot support during transition; untested
heifner Mar 19, 2024
5722be9
GH-2057 Fix close logic of forkdb
heifner Mar 19, 2024
b8a772c
GH-2057 Fix race condition on switch_from_legacy. Fix startup in sava…
heifner Mar 19, 2024
f00fd32
GH-2057 Rename result to next_header_state
heifner Mar 19, 2024
beed426
update savanna protocol activation
ericpassmore Mar 19, 2024
0a789b0
GH-2057 Fix indentation
heifner Mar 19, 2024
50fdb40
GH-2057 Set default_safety_information on replay
heifner Mar 19, 2024
3c19387
Merge pull request #2324 from AntelopeIO/update-svna-protocol-activation
ericpassmore Mar 19, 2024
dadd077
Add new Savanna action digest (wip).
greg7mdp Mar 19, 2024
9c70367
merge `origin/hotstuff_integration`
greg7mdp Mar 19, 2024
52eb338
GH-2057 Don't bother including legacy in snapshot if pass transition
heifner Mar 19, 2024
d53d431
Delay on error to give time for node to launch
heifner Mar 19, 2024
0a9f0c1
GH-2057 Simplify code
heifner Mar 19, 2024
84cc1f7
Revert "merge `origin/hotstuff_integration`"
greg7mdp Mar 19, 2024
b624c24
Merge pull request #2325 from AntelopeIO/fix-sync-test
heifner Mar 20, 2024
d19c3f0
Added cleaner log base 2 function + integrity check in bitset constru…
systemzax Mar 20, 2024
5804b24
Added cleaner log base 2 function + integrity check in bitset constru…
systemzax Mar 20, 2024
aada30c
Merge branch 'hotstuff_integration' of https://github.com/antelopeIO/…
systemzax Mar 20, 2024
30a61cc
Merge branch 'hotstuff_integration' into if_ibc_contract
systemzax Mar 20, 2024
3efd4bf
GH-2057 Always return a valid future
heifner Mar 20, 2024
26d82da
GH-2057 Switch away from legacy forkdb in log_irreversible to simplif…
heifner Mar 20, 2024
bbe8735
Introduce get_blocks_request_v1 to support fetch_finality_data parame…
linh2931 Mar 20, 2024
b1b9642
remove leftover debugging statements
linh2931 Mar 20, 2024
35839ed
Merge remote-tracking branch 'origin/hotstuff_integration' into GH-20…
heifner Mar 21, 2024
b4c445d
Support optional computation and storage of two `action_digest` varia…
greg7mdp Mar 21, 2024
528c089
Construct `executed_action_receipt_digests_*` empty by default.
greg7mdp Mar 21, 2024
fbe6455
Merge pull request #2314 from AntelopeIO/if_ibc_contract
systemzax Mar 21, 2024
0c6d290
Add finality_data ABI definition so clients have a standard type defi…
linh2931 Mar 21, 2024
51feb05
GH-2057 Use constexpr instead of overloaded function
heifner Mar 21, 2024
6cfb3fb
Rename functions.
greg7mdp Mar 21, 2024
79142ab
simplify std::visitor uses; cache base_digest; and minor changes for …
linh2931 Mar 21, 2024
2799ca7
Use struct to store two versions of `action_receipt_digests`
greg7mdp Mar 22, 2024
5e895c4
Simplify two namespaces.
greg7mdp Mar 22, 2024
7a22f7e
rename `sad` into `store_which`.
greg7mdp Mar 22, 2024
493b7e1
Merge branch 'hotstuff_integration' of github.com:AntelopeIO/leap int…
greg7mdp Mar 22, 2024
26f72bd
Encapsulate use of `action_digests_t` better.
greg7mdp Mar 22, 2024
1b92f02
Move back `finalize_trace` after the digest computation.
greg7mdp Mar 22, 2024
cc65791
Remove outdated comment.
greg7mdp Mar 22, 2024
78bbc62
GH-2286 Add an irreversible node to test
heifner Mar 22, 2024
b9ac212
GH-2161 Uncomment tests.
heifner Mar 22, 2024
be96431
GH-2161 For LIB to advance need to make bios not a finalizer
heifner Mar 22, 2024
988261e
GH-2161 Add better log statement
heifner Mar 22, 2024
32258f4
GH-2161 Add support for transition to savanna in irreversible mode
heifner Mar 22, 2024
dac12e5
GH-2057 Use any_of instead of find_if
heifner Mar 23, 2024
f576797
GH-2057 Remove todo
heifner Mar 23, 2024
eb2fc59
Merge remote-tracking branch 'origin/hotstuff_integration' into GH-23…
heifner Mar 23, 2024
54e88ed
Fix misspelled function name, and incorrect name `clz_power_2`
greg7mdp Mar 25, 2024
cce8e5c
File reorg to separate `legacy` and `optimized` merkle implementation
greg7mdp Mar 25, 2024
1b0a63b
Merge pull request #2326 from AntelopeIO/gh_2161
greg7mdp Mar 25, 2024
c775d7a
Make `merkle` names consistent and deprecate `canonical`
greg7mdp Mar 25, 2024
f7364c5
Move `merkle` types into their correct headers.
greg7mdp Mar 25, 2024
1b7351d
GH-2286 Add message to assert.
heifner Mar 25, 2024
6f47ddb
GH-2886 Create method to remove duplicate code
heifner Mar 25, 2024
6bb9d36
GH-2334 Change bls_public_key serialization format and optimize
heifner Mar 26, 2024
1056702
GH-2057 minor cleanup
heifner Mar 26, 2024
e421b74
use cached base_digest actually; minor review changes
linh2931 Mar 26, 2024
417615d
Merge branch 'hotstuff_integration' into ship_finality_info_support
linh2931 Mar 26, 2024
86a0b28
Merge remote-tracking branch 'origin/hotstuff_integration' into GH-20…
heifner Mar 26, 2024
3b3fb28
GH-2057 Fix merge conflicts
heifner Mar 26, 2024
1fdd181
Merge remote-tracking branch 'origin/ship_finality_info_support' into…
heifner Mar 26, 2024
35a040d
minor changes responding to review comments
linh2931 Mar 26, 2024
f412147
make cached base_digest as an optional
linh2931 Mar 26, 2024
5c82eec
remove an unnecessary compute_base_digest()
linh2931 Mar 26, 2024
0fd2540
GH-2334 Add bls_aggregate_signature and change serialization of bls_s…
heifner Mar 26, 2024
b280344
GH-2057 update deep mind logs again after merge
heifner Mar 26, 2024
e92e4ad
GH-2286 Misc cleanup
heifner Mar 26, 2024
dc029db
GH-2286 Simplify by adding fork_db_head_or_pending()
heifner Mar 26, 2024
97df979
Merge branch 'GH-2057-transition' into GH-2286-irreversible
heifner Mar 26, 2024
21de5c4
use apply_s for head_finality_data to simplify code
linh2931 Mar 26, 2024
3a65b3f
Merge remote-tracking branch 'origin/ship_finality_info_support' into…
heifner Mar 27, 2024
20520cc
Merge pull request #2316 from AntelopeIO/GH-2057-transition
heifner Mar 27, 2024
4bd9b4d
Merge branch 'hotstuff_integration' into GH-2286-irreversible
heifner Mar 27, 2024
383c6e9
Merge remote-tracking branch 'origin/main' into merge-main-03-27-2024
heifner Mar 27, 2024
f1a1893
Merge branch 'hotstuff_integration' into ship_finality_info_support
linh2931 Mar 27, 2024
39cd75a
Merge pull request #2321 from AntelopeIO/ship_finality_info_support
linh2931 Mar 27, 2024
a2013f7
Merge pull request #2341 from AntelopeIO/merge-main-03-27-2024
heifner Mar 27, 2024
7bab066
Merge branch 'hotstuff_integration' of github.com:AntelopeIO/leap int…
greg7mdp Mar 27, 2024
eb3e2dd
GH-2286 Use const members, clean up construction
heifner Mar 27, 2024
aea1aa1
GH-2286 Remove const as FC_REFLECT does not support const members
heifner Mar 27, 2024
2686c85
GH-2334 Remove duplicate code and update comments
heifner Mar 27, 2024
61afa39
GH-2334 Update comments
heifner Mar 27, 2024
8381b40
GH-2334 Make method public to avoid multiple friend declarations
heifner Mar 27, 2024
86432e9
GH-2310 Use getBlockID so that both block_id and head_id supported de…
heifner Mar 27, 2024
e8d10a3
GH-2313 When a proposed producer schedule will replace an existing on…
heifner Mar 27, 2024
80c3b22
add get_blocks_result_v1 to SHiP
linh2931 Mar 27, 2024
fe71f93
update ship_streamer_test to use get_blocks_result_v1 or get_blocks_r…
linh2931 Mar 28, 2024
81ede3c
set initial active_finalizer_policy_generation in finality_data to 1
linh2931 Mar 28, 2024
e7e9a7c
GH-2334 Serialize as variable length array for easier decoding by ext…
heifner Mar 28, 2024
ba33ba8
GH-2310 Fix error message to say status instead of state
heifner Mar 28, 2024
1cd0b35
Merge pull request #2335 from AntelopeIO/GH-2286-irreversible
heifner Mar 28, 2024
bf04b0a
GH-2313 Fix spelling
heifner Mar 28, 2024
37c3322
simplify send_entryby factoring out result variant processing
linh2931 Mar 28, 2024
57b61b9
use common code to serialize get_blocks_result_v0 and get_blocks_resu…
linh2931 Mar 28, 2024
93905c3
use T&& result for send_update
linh2931 Mar 28, 2024
ae08070
Merge pull request #2343 from AntelopeIO/GH-2310-test
heifner Mar 28, 2024
f0038dc
Merge pull request #2344 from AntelopeIO/GH-2313-proposed_producers_v…
heifner Mar 28, 2024
dd8d988
Merge remote-tracking branch 'origin/hotstuff_integration' into GH-23…
heifner Mar 28, 2024
aaa9284
GH-2334 Simplify sizeof calculation
heifner Mar 28, 2024
86cca8e
GH-2348 Calculate IF Genesis Block finality digest correctly
heifner Mar 28, 2024
f68869a
static_assert the variant index is correct for get_blocks_result_v0 a…
linh2931 Mar 28, 2024
9480cf8
Only use get_blocks_request_v1 and get_blocks_result_v1 for ship_stre…
linh2931 Mar 28, 2024
4a5bc73
Merge branch 'hotstuff_integration' into ship_get_blocks_result_v1
linh2931 Mar 28, 2024
789dfee
remove unnecessary if( fetch_finality_data )
linh2931 Mar 28, 2024
51e9379
Update nodeos_forked_chain_test.py to use get_blocks_result_v1 instea…
linh2931 Mar 28, 2024
acc51cb
GH-2348 Make sure all attributes of block_state are populated in crea…
heifner Mar 28, 2024
9cc6f74
always provide fetch_finality_data field for get_blocks_request_v1
linh2931 Mar 28, 2024
30fd771
Merge pull request #2338 from AntelopeIO/GH-2334-bls-serialization
heifner Mar 28, 2024
f0fcc44
Merge branch 'hotstuff_integration' into GH-2348-genesis-finality-digest
heifner Mar 28, 2024
7bb4e56
Merge pull request #2349 from AntelopeIO/ship_get_blocks_result_v1
linh2931 Mar 28, 2024
fd02885
Initial new merkle tree implementation.
greg7mdp Mar 28, 2024
afd97ca
Add stack depth check.
greg7mdp Mar 28, 2024
bcb2545
Add alternative to `std::popcount` for cdt which does not support C++…
greg7mdp Mar 29, 2024
a09fd7d
Remove destructive version of `calculate_merkle`.
greg7mdp Mar 29, 2024
8ea41a4
Add alternative to `std::bit_floor` for cdt which does not support C+…
greg7mdp Mar 29, 2024
8a7794f
Add extra logging around async write
heifner Mar 29, 2024
809e4ab
Merge branch 'hotstuff_integration' into GH-2348-genesis-finality-digest
heifner Mar 29, 2024
d8e7ee5
Merge branch 'hotstuff_integration' into net-plugin-logging
heifner Mar 29, 2024
e384b43
GH-2057 Ignore proposed producers during transition
heifner Mar 29, 2024
0d809ef
GH-2348 Use correct strong digest
heifner Mar 29, 2024
1eb7bc0
set active_finalizer_policy_generation correctly in finality_data for…
linh2931 Mar 29, 2024
38562ac
Log unknown block
heifner Mar 29, 2024
25b93a9
Merge pull request #2355 from AntelopeIO/net-plugin-logging
heifner Mar 29, 2024
d2f1c92
Add perf tests, fix warning.
greg7mdp Mar 29, 2024
70fb9a9
Merge pull request #2358 from AntelopeIO/correct_finalizer_policy_gen…
linh2931 Mar 29, 2024
1ced859
Verify bls signature of vote while not holding a mutex
heifner Mar 29, 2024
57bf131
Merge pull request #2357 from AntelopeIO/GH-2057-producer-schedule
heifner Mar 29, 2024
12e6a53
Add multithreading to , add test, remove stack size debug code
greg7mdp Mar 29, 2024
da5d431
Merge branch 'hotstuff_integration' of github.com:AntelopeIO/leap int…
greg7mdp Mar 29, 2024
ceec40b
Add has_voted() method
heifner Mar 29, 2024
be4c877
Wait for controller to vote if it should
heifner Mar 29, 2024
2c4cb49
Provide finality_data for Transition blocks
linh2931 Mar 29, 2024
67c4f1d
Verify all have voted
heifner Mar 29, 2024
a241785
Make sure validating node has voted
heifner Mar 29, 2024
209090e
Simplify `canonical` template param from `incremental_merkle_tree_leg…
greg7mdp Mar 29, 2024
46867a9
GH-2348 Fix spelling
heifner Mar 29, 2024
3562c7d
Merge pull request #2359 from AntelopeIO/verify-bls-sig-unlocked
heifner Mar 29, 2024
8ed91d9
Update comments.
greg7mdp Mar 29, 2024
fb6f69e
Merge branch 'hotstuff_integration' of github.com:AntelopeIO/leap int…
greg7mdp Mar 29, 2024
49aca0b
Add test with 20 nodes, seems to be an off by one somewhere that prev…
heifner Mar 29, 2024
5b83d32
Merge pull request #2353 from AntelopeIO/GH-2348-genesis-finality-digest
heifner Mar 29, 2024
264dffe
Merge branch 'hotstuff_integration' of github.com:AntelopeIO/leap int…
greg7mdp Mar 29, 2024
0663a3d
Add `num_digests_appended()` method, not used but pretty cool doc on …
greg7mdp Mar 29, 2024
08c5186
Reduce number of boost test assertions.
greg7mdp Mar 29, 2024
ac2f980
Small cleanup of the test.
greg7mdp Mar 30, 2024
b5f522f
Cleanup messages from performance test.
greg7mdp Mar 30, 2024
c300efe
GH-2364 Verify needed trx processed before continuing
heifner Mar 30, 2024
198e512
Finish removing references to `canonical`.
greg7mdp Mar 30, 2024
89e3d8d
Address PR comments, templatize `calculate_merkle`.
greg7mdp Mar 30, 2024
b86a162
Remove `post_async_task` for the `calculate_merkle` of action/transac…
greg7mdp Mar 30, 2024
f2a3c27
Update `calculate_merkle_pow2` to use 2 threads for sizes from 256 to…
greg7mdp Mar 30, 2024
808d586
Update comment.
greg7mdp Mar 30, 2024
95f06f2
Fix gcc-11 compiler warnings.
greg7mdp Mar 30, 2024
20f5d0e
Merge branch 'hotstuff_integration' into 21-test
heifner Mar 30, 2024
064717e
Fix compilation error with gcc10.
greg7mdp Mar 30, 2024
54e5d70
Fix typo.
greg7mdp Mar 30, 2024
82178a7
Add class comment for `incremental_merkle_tree`.
greg7mdp Mar 30, 2024
f44409b
Merge pull request #2365 from AntelopeIO/GH-2364-retry-test
heifner Apr 2, 2024
d4d052e
Merge branch 'hotstuff_integration' into 21-test
heifner Apr 2, 2024
8c03a62
Merge pull request #2361 from AntelopeIO/gh_2333
greg7mdp Apr 2, 2024
ad64fc7
GH-2102 Use vector of atomic bools to avoid mutex lock for duplicate …
heifner Apr 2, 2024
755da1a
Add get_row_by_id to libtester
linh2931 Apr 2, 2024
f622184
allow more than one BOOST_AUTO_TEST_SUITE() in a file
spoonincode Apr 2, 2024
a19d126
split eosio.system_tests in to two parts
spoonincode Apr 2, 2024
548641d
Merge pull request #2368 from AntelopeIO/get_row_by_id
linh2931 Apr 2, 2024
cf7f527
Merge pull request #2370 from AntelopeIO/split_eosio.system_tests
spoonincode Apr 2, 2024
c40d390
Merge branch 'hotstuff_integration' into 21-test
heifner Apr 2, 2024
3887b2c
GH-2102 Add block to fork db as soon as header is validated so it is …
heifner Apr 2, 2024
753af58
Re-implement getting finality_data for Savanna Transition Blocks
linh2931 Apr 3, 2024
9daa3d2
Merge branch 'hotstuff_integration' into add_finality_data_in_transit…
linh2931 Apr 3, 2024
cc56c51
Merge pull request #2363 from AntelopeIO/21-test
heifner Apr 3, 2024
da5f812
Add a comment explaining why both forkdb root and legacy branch are s…
linh2931 Apr 3, 2024
4b06a17
Merge branch 'hotstuff_integration' into add_finality_data_in_transit…
linh2931 Apr 3, 2024
bd43d61
GH-2102 May already be in forkdb since we are adding as soon as heade…
heifner Apr 3, 2024
c10bcaa
Merge remote-tracking branch 'origin/main' into main_catchup_apr_04
greg7mdp Apr 3, 2024
ccc79c5
Additional changes to support bls12 API change.
greg7mdp Apr 3, 2024
c84bab1
GH-2102 Add logging on app().quit()
heifner Apr 3, 2024
cf50336
GH-2102 Integrate qc and vote when switching forks if first time bloc…
heifner Apr 3, 2024
facbee8
Move merkel benchmarks from `unittest` to `benchmark`.
greg7mdp Apr 3, 2024
5cce3d6
Merge pull request #2374 from AntelopeIO/main_catchup_apr_04
greg7mdp Apr 3, 2024
eb84aa2
Merge branch 'hotstuff_integration' of github.com:AntelopeIO/leap int…
greg7mdp Apr 3, 2024
053fe72
GH-2102 Log irreversible even when head not updated
heifner Apr 3, 2024
68148eb
Cache action_mroot_savanna instead of action_receipt_digests_savanna …
linh2931 Apr 3, 2024
78c6de1
Correct comments
linh2931 Apr 3, 2024
f02fa48
Merge pull request #2375 from AntelopeIO/gh_2371
greg7mdp Apr 3, 2024
a9987a2
Merge branch 'hotstuff_integration' into add_finality_data_in_transit…
linh2931 Apr 4, 2024
773577b
update deep-mind.log
linh2931 Apr 4, 2024
4066109
GH-2102 Check for validated block to avoid extra processing
heifner Apr 4, 2024
486fed3
make it clear action_mroot_savanna constructed as a std::optional
linh2931 Apr 4, 2024
9411c05
GH-2102 Init processed on reflection
heifner Apr 4, 2024
3465884
Make action_receipt_digests_savanna as const& to parameter to block_s…
linh2931 Apr 4, 2024
0c82e7a
GH-2102 Handle corner case of trx locally applied but not in a block yet
heifner Apr 4, 2024
b9deb58
GH-2102 Only report fork switch on actual fork switch. maybe_switch_f…
heifner Apr 4, 2024
8a7b973
GH-2102 Check for terminate_at_block during apply of fork db blocks
heifner Apr 4, 2024
274e44a
GH-2102 If forked out again then could still be in local state
heifner Apr 4, 2024
93163ec
store action_mroot only for the last block in the process of construc…
linh2931 Apr 4, 2024
2e49794
GH-2102 Allow ctrl-c shutdown during sync of a large number of blocks…
heifner Apr 4, 2024
4c3535f
GH-2102 Fix sync issue with receiving a current block while syncing
heifner Apr 4, 2024
08d0c96
Merge pull request #2362 from AntelopeIO/add_finality_data_in_transit…
linh2931 Apr 4, 2024
112bb69
GH-2102 On startup pending_head forkdb blocks are processed. If asked…
heifner Apr 4, 2024
84098e5
switch variant index of new get_blocks_request_v1
spoonincode Apr 4, 2024
66c7c62
Merge pull request #2381 from AntelopeIO/ship_gbrv1_variant
spoonincode Apr 5, 2024
914f218
GH-2102 Fix comparison in waitForBlock
heifner Apr 5, 2024
5e9af0c
GH-2102 Better error reporting and a bit more tolerance for trxs in b…
heifner Apr 5, 2024
2449830
GH-2102 Add additional logging for applied blocks
heifner Apr 5, 2024
e464aee
Revert "GH-2102 Fix comparison in waitForBlock"
heifner Apr 5, 2024
a74450c
GH-2102 Improve logging during sync
heifner Apr 5, 2024
cafd0b6
GH-2102 Add a large_atomic wrapper around mutex
heifner Apr 5, 2024
302b957
GH-2102 Use large_atomic for if_irreversible_block_id
heifner Apr 5, 2024
be77ca6
GH-2102 No need to recalculate finality digest
heifner Apr 5, 2024
23945ff
GH-2102 Move valid_qc into pending_qc and make thread safe
heifner Apr 5, 2024
ba5006e
GH-2102 Improve test conditions
heifner Apr 5, 2024
9de11ff
GH-2102 Move produced/received block logging into controller so it lo…
heifner Apr 6, 2024
8e98c18
GH-2102 Fix log_applied to not be called during replay
heifner Apr 6, 2024
a9058a1
GH-2102 Add a copyable atomic type
heifner Apr 8, 2024
6d64c27
GH-2102 Integrate qc and vote if possible off the main thread.
heifner Apr 8, 2024
6bd8128
Merge remote-tracking branch 'origin/hotstuff_integration' into GH-21…
heifner Apr 8, 2024
c54fe32
Increment `finalizer_policy`'s `generation`.
greg7mdp Apr 8, 2024
232e95b
Merge pull request #2388 from AntelopeIO/gh_2345
greg7mdp Apr 9, 2024
33210c0
GH-2102 Small cleanup from PR review
heifner Apr 9, 2024
5cc1b87
GH-2102 Move Produced block log into controller_impl commit_block
heifner Apr 9, 2024
f9786e1
Merge pull request #2385 from AntelopeIO/GH-2102-vote-processing
heifner Apr 10, 2024
aace335
Disable ship streamer tests until ship is fixed.
heifner Apr 10, 2024
1918009
Send handshake to peer to let it know it is not syncing from us.
heifner Apr 10, 2024
5a3e043
Merge branch 'spring/main' into merge-main-04-10-2024
heifner Apr 10, 2024
8cc9420
Merge pull request #21 from AntelopeIO/disable-ship-tests
heifner Apr 11, 2024
4c5e909
Merge branch 'savanna' into merge-main-04-10-2024
heifner Apr 11, 2024
76a79ab
Merge branch 'savanna' into net-sync-peer-fix
heifner Apr 11, 2024
f5967c0
Merge pull request #22 from AntelopeIO/net-sync-peer-fix
heifner Apr 11, 2024
623af37
Merge branch 'savanna' into merge-main-04-10-2024
heifner Apr 11, 2024
16744a0
Merge pull request #23 from AntelopeIO/merge-main-04-10-2024
heifner Apr 11, 2024
f13dae7
Merge branch 'spring/main' into main-04-11-2024
heifner Apr 11, 2024
8ae27a1
Merge pull request #25 from AntelopeIO/main-04-11-2024
heifner Apr 11, 2024
06e6109
Delay sending handshakes on becoming in_sync until controller state i…
heifner Apr 12, 2024
bfbdcca
Merge pull request #27 from AntelopeIO/net-plugin-syncing-with-peer
heifner Apr 15, 2024
b0ee741
Fix empty action_mroot in Transition blocks
linh2931 Apr 15, 2024
359aa89
Merge branch 'savanna' into fix_empty_action_mroot
linh2931 Apr 15, 2024
5900424
added unit test for svnn_ibc proof generation + verification
systemzax Apr 16, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .cicd/defaults.json
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
{
"cdt":{
"target":"4",
"target":"hotstuff_integration",
"prerelease":false
},
"referencecontracts":{
"ref":"main"
"ref":"instant-finality"
}
}
2 changes: 1 addition & 1 deletion .github/workflows/build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ jobs:
error-log-paths: '["build/etc", "build/var", "build/leap-ignition-wd", "build/TestLogs"]'
log-tarball-prefix: ${{matrix.cfg.name}}
tests-label: long_running_tests
test-timeout: 1800
test-timeout: 2700
- name: Export core dumps
run: docker run --mount type=bind,source=/var/lib/systemd/coredump,target=/cores alpine sh -c 'tar -C /cores/ -c .' | tar x
if: failure()
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -92,3 +92,4 @@ node_modules
package-lock.json

snapshots
!unittests/snapshots
1 change: 1 addition & 0 deletions CMakeModules/EosioTesterBuild.cmake.in
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@ target_include_directories(EosioChain INTERFACE
@CMAKE_BINARY_DIR@/libraries/chain/include
@CMAKE_SOURCE_DIR@/libraries/libfc/include
@CMAKE_SOURCE_DIR@/libraries/libfc/libraries/boringssl/boringssl/src/include
@CMAKE_SOURCE_DIR@/libraries/libfc/libraries/bls12-381/include
@CMAKE_SOURCE_DIR@/libraries/softfloat/source/include
@CMAKE_SOURCE_DIR@/libraries/appbase/include
@CMAKE_SOURCE_DIR@/libraries/chainbase/include
Expand Down
15 changes: 11 additions & 4 deletions benchmark/benchmark.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@ std::map<std::string, std::function<void()>> features {
{ "key", key_benchmarking },
{ "hash", hash_benchmarking },
{ "blake2", blake2_benchmarking },
{ "bls", bls_benchmarking }
{ "bls", bls_benchmarking },
{ "merkle", merkle_benchmarking }
};

// values to control cout format
Expand All @@ -34,6 +35,10 @@ void set_num_runs(uint32_t runs) {
num_runs = runs;
}

uint32_t get_num_runs() {
return num_runs;
}

void print_header() {
std::cout << std::left << std::setw(name_width) << "function"
<< std::setw(runs_width) << "runs"
Expand Down Expand Up @@ -63,12 +68,14 @@ bytes to_bytes(const std::string& source) {
return output;
};

void benchmarking(const std::string& name, const std::function<void()>& func) {
void benchmarking(const std::string& name, const std::function<void()>& func,
std::optional<size_t> opt_num_runs /* = {} */) {
uint64_t total{0};
uint64_t min{std::numeric_limits<uint64_t>::max()};
uint64_t max{0};
uint32_t runs = opt_num_runs ? *opt_num_runs : num_runs;

for (auto i = 0U; i < num_runs; ++i) {
for (auto i = 0U; i < runs; ++i) {
auto start_time = std::chrono::high_resolution_clock::now();
func();
auto end_time = std::chrono::high_resolution_clock::now();
Expand All @@ -79,7 +86,7 @@ void benchmarking(const std::string& name, const std::function<void()>& func) {
max = std::max(max, duration);
}

print_results(name, num_runs, total, min, max);
print_results(name, runs, total, min, max);
}

} // benchmark
5 changes: 4 additions & 1 deletion benchmark/benchmark.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,15 @@
#include <map>
#include <vector>
#include <limits>
#include <optional>

#include <fc/crypto/hex.hpp>

namespace eosio::benchmark {
using bytes = std::vector<char>;

void set_num_runs(uint32_t runs);
uint32_t get_num_runs();
std::map<std::string, std::function<void()>> get_features();
void print_header();
bytes to_bytes(const std::string& source);
Expand All @@ -21,7 +23,8 @@ void key_benchmarking();
void hash_benchmarking();
void blake2_benchmarking();
void bls_benchmarking();
void merkle_benchmarking();

void benchmarking(const std::string& name, const std::function<void()>& func);
void benchmarking(const std::string& name, const std::function<void()>& func, std::optional<size_t> num_runs = {});

} // benchmark
3 changes: 2 additions & 1 deletion benchmark/bls.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,8 @@ struct interface_in_benchmark {
// build transaction context from the packed transaction
timer = std::make_unique<platform_timer>();
trx_timer = std::make_unique<transaction_checktime_timer>(*timer);
trx_ctx = std::make_unique<transaction_context>(*chain->control.get(), *ptrx, ptrx->id(), std::move(*trx_timer));
trx_ctx = std::make_unique<transaction_context>(*chain->control.get(), *ptrx, ptrx->id(), std::move(*trx_timer),
action_digests_t::store_which_t::legacy);
trx_ctx->max_transaction_time_subjective = fc::microseconds::maximum();
trx_ctx->init_for_input_trx( ptrx->get_unprunable_size(), ptrx->get_prunable_size() );
trx_ctx->exec(); // this is required to generate action traces to be used by apply_context constructor
Expand Down
69 changes: 69 additions & 0 deletions benchmark/merkle.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
#include <benchmark.hpp>
#include <eosio/chain/incremental_merkle.hpp>
#include <eosio/chain/incremental_merkle_legacy.hpp>
#include <random>

namespace eosio::benchmark {

using namespace eosio::chain;

std::vector<digest_type> create_test_digests(size_t n) {
std::vector<digest_type> v;
v.reserve(n);
for (size_t i=0; i<n; ++i)
v.push_back(fc::sha256::hash(std::string{"Node"} + std::to_string(i)));
return v;
}

void benchmark_calc_merkle(uint32_t size_boost) {
using namespace std::string_literals;
const size_t num_digests = size_boost * 1000ull; // don't use exact powers of 2 as it is a special case

const std::vector<digest_type> digests = create_test_digests(num_digests);
const deque<digest_type> deq { digests.begin(), digests.end() };

auto num_str = std::to_string(size_boost);
while(num_str.size() < 4)
num_str.insert(0, 1, ' ');
auto msg_header = "Calc, "s + num_str + ",000 digests, "s;
uint32_t num_runs = std::min(get_num_runs(), std::max(1u, get_num_runs() / size_boost));
benchmarking(msg_header + "legacy: ", [&]() { calculate_merkle_legacy(deq); }, num_runs);
benchmarking(msg_header + "savanna:", [&]() { calculate_merkle(digests.begin(), digests.end()); }, num_runs);
}

void benchmark_incr_merkle(uint32_t size_boost) {
using namespace std::string_literals;
const size_t num_digests = size_boost * 1000ull; // don't use exact powers of 2 as it is a special case

const std::vector<digest_type> digests = create_test_digests(num_digests);

auto num_str = std::to_string(size_boost);
while(num_str.size() < 4)
num_str.insert(0, 1, ' ');
auto msg_header = "Incr, "s + num_str + ",000 digests, "s;
uint32_t num_runs = std::min(get_num_runs(), std::max(1u, get_num_runs() / size_boost));

auto incr = [&](const auto& incr_tree) {
auto work_tree = incr_tree;
for (const auto& d : digests)
work_tree.append(d);
return work_tree.get_root();
};

benchmarking(msg_header + "legacy: ", [&]() { incr(incremental_merkle_tree_legacy()); }, num_runs);
benchmarking(msg_header + "savanna:", [&]() { incr(incremental_merkle_tree()); }, num_runs);
}

// register benchmarking functions
void merkle_benchmarking() {
benchmark_calc_merkle(1000); // calculate_merkle of very large sequence (1,000,000 digests)
benchmark_calc_merkle(50); // calculate_merkle of large sequence (50,000 digests)
benchmark_calc_merkle(1); // calculate_merkle of small sequence (1000 digests)
std::cout << "\n";

benchmark_incr_merkle(100); // incremental_merkle of very large sequence (100,000 digests)
benchmark_incr_merkle(25); // incremental_merkle of large sequence (25,000 digests)
benchmark_incr_merkle(1); // incremental_merkle of small sequence (1000 digests)
}

}
27 changes: 27 additions & 0 deletions docs/block_production/lifecycle.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
The following diagram describes Leap block production, as implemented in `libraries/chain/controller.cpp`:

```mermaid
flowchart TD
pp[producer_plugin] --> D
A("replay()"):::fun --> B("replay_push_block()"):::fun
B --> E("maybe_switch_forks()"):::fun
C("init()"):::fun ---> E
C --> A
D("push_block()"):::fun ---> E
subgraph G["apply_block()"]
direction TB
start -- "stage = &Oslash;" --> sb
sb("start_block()"):::fun -- "stage = building_block" --> et
et["execute transactions" ] -- "stage = building_block" --> fb("finish_block()"):::fun
fb -- "stage = assembled block" --> cb["add transaction metadata and create completed block"]
cb -- "stage = completed block" --> commit("commit_block() (where we [maybe] add to fork_db and mark valid)"):::fun

end
B ----> start
E --> G
D --> F("log_irreversible()"):::fun
commit -- "stage = &Oslash;" --> F
F -- "if in irreversible mode" --> G

classDef fun fill:#f96
```
14 changes: 13 additions & 1 deletion libraries/chain/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ configure_file(${CMAKE_CURRENT_SOURCE_DIR}/genesis_state_root_key.cpp.in ${CMAKE

file(GLOB HEADERS "include/eosio/chain/*.hpp"
"include/eosio/chain/webassembly/*.hpp"
"include/eosio/chain/hotstuff/*.hpp"
"${CMAKE_CURRENT_BINARY_DIR}/include/eosio/chain/core_symbol.hpp" )

if((APPLE AND UNIX) OR (${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD"))
Expand Down Expand Up @@ -78,18 +79,26 @@ set(CHAIN_WEBASSEMBLY_SOURCES
webassembly/transaction.cpp
)

set(CHAIN_HOTSTUFF_SOURCES
hotstuff/finalizer.cpp
hotstuff/instant_finality_extension.cpp
hotstuff/hotstuff.cpp
)

add_library(eosio_rapidjson INTERFACE)
target_include_directories(eosio_rapidjson INTERFACE ../rapidjson/include)

## SORT .cpp by most likely to change / break compile
add_library( eosio_chain
merkle.cpp
name.cpp
transaction.cpp
block.cpp
block_header.cpp
block_header_state.cpp
block_state.cpp
block_header_state_legacy.cpp
block_state_legacy.cpp
finality_core.cpp
fork_database.cpp
controller.cpp
authorization_manager.cpp
Expand Down Expand Up @@ -119,6 +128,7 @@ add_library( eosio_chain
${CHAIN_EOSVMOC_SOURCES}
${CHAIN_EOSVM_SOURCES}
${CHAIN_WEBASSEMBLY_SOURCES}
${CHAIN_HOTSTUFF_SOURCES}

authority.cpp
trace.cpp
Expand Down Expand Up @@ -171,6 +181,8 @@ if(EOSVMOC_ENABLE_DEVELOPER_OPTIONS)
target_compile_definitions(eosio_chain PUBLIC EOSIO_EOS_VM_OC_DEVELOPER)
endif()

add_subdirectory(hotstuff/test)

install( TARGETS eosio_chain
RUNTIME DESTINATION ${CMAKE_INSTALL_FULL_BINDIR} COMPONENT dev EXCLUDE_FROM_ALL
LIBRARY DESTINATION ${CMAKE_INSTALL_FULL_LIBDIR} COMPONENT dev EXCLUDE_FROM_ALL
Expand Down
9 changes: 9 additions & 0 deletions libraries/chain/abi_serializer.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
#include <eosio/chain/abi_serializer.hpp>
#include <eosio/chain/asset.hpp>
#include <eosio/chain/exceptions.hpp>
#include <eosio/chain/hotstuff/instant_finality_extension.hpp>
#include <fc/io/raw.hpp>
#include <boost/algorithm/string/predicate.hpp>
#include <fc/io/varint.hpp>
Expand Down Expand Up @@ -633,6 +634,14 @@ namespace eosio { namespace chain {
_variant_to_binary(type, var, ds, ctx);
}

void impl::abi_to_variant::add_block_header_instant_finality_extension( mutable_variant_object& mvo, const header_extension_multimap& header_exts ) {
if (header_exts.count(instant_finality_extension::extension_id())) {
const auto& if_extension =
std::get<instant_finality_extension>(header_exts.lower_bound(instant_finality_extension::extension_id())->second);
mvo("instant_finality_extension", if_extension);
}
}

type_name abi_serializer::get_action_type(name action)const {
auto itr = actions.find(action);
if( itr != actions.end() ) return itr->second;
Expand Down
20 changes: 10 additions & 10 deletions libraries/chain/apply_context.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@

using boost::container::flat_set;

namespace eosio { namespace chain {
namespace eosio::chain {

static inline void print_debug(account_name receiver, const action_trace& ar) {
if (!ar.console.empty()) {
Expand Down Expand Up @@ -184,7 +184,7 @@ void apply_context::exec_one()
r.auth_sequence[auth.actor] = next_auth_sequence( auth.actor );
}

trx_context.executed_action_receipt_digests.emplace_back( r.digest() );
trx_context.executed_action_receipts.compute_and_append_digests_from(trace);

finalize_trace( trace, start );

Expand Down Expand Up @@ -218,17 +218,17 @@ void apply_context::exec()
exec_one();
}

if( _cfa_inline_actions.size() > 0 || _inline_actions.size() > 0 ) {
if( !_cfa_inline_actions.empty() || !_inline_actions.empty() ) {
EOS_ASSERT( recurse_depth < control.get_global_properties().configuration.max_inline_action_depth,
transaction_exception, "max inline action depth per transaction reached" );
}

for( uint32_t ordinal : _cfa_inline_actions ) {
trx_context.execute_action( ordinal, recurse_depth + 1 );
}
for( uint32_t ordinal : _cfa_inline_actions ) {
trx_context.execute_action( ordinal, recurse_depth + 1 );
}

for( uint32_t ordinal : _inline_actions ) {
trx_context.execute_action( ordinal, recurse_depth + 1 );
for( uint32_t ordinal : _inline_actions ) {
trx_context.execute_action( ordinal, recurse_depth + 1 );
}
}

} /// exec()
Expand Down Expand Up @@ -1105,4 +1105,4 @@ bool apply_context::should_use_eos_vm_oc()const {
}


} } /// eosio::chain
} /// eosio::chain
5 changes: 5 additions & 0 deletions libraries/chain/block.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,11 @@ namespace eosio { namespace chain {
}
}

void quorum_certificate_extension::reflector_init() {
static_assert( fc::raw::has_feature_reflector_init_on_unpacked_reflected_types, "quorum_certificate_extension expects FC to support reflector_init" );
static_assert( extension_id() == 3, "extension id for quorum_certificate_extension must be 3" );
}

flat_multimap<uint16_t, block_extension> signed_block::validate_and_extract_extensions()const {
using decompose_t = block_extension_types::decompose_t;

Expand Down
Loading
Loading