Skip to content
This repository has been archived by the owner on Jan 22, 2025. It is now read-only.

Add new execution code-path for unified scheduler #31239

Closed
wants to merge 56 commits into from
Closed
Show file tree
Hide file tree
Changes from 39 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
3597dfb
Add new execution code-path for unified scheduler
ryoqun Apr 18, 2023
a8d66fa
Adjust to use the installed prefix consistently
ryoqun Apr 20, 2023
16a1e9c
Reword comment for simplicity
ryoqun Apr 22, 2023
3a7810c
Make replay_stats locking more granular
ryoqun Apr 22, 2023
8fc00c7
Clean up the local cluster test a bit
ryoqun Apr 23, 2023
3ba582b
Remove extra blank line
ryoqun Apr 23, 2023
9769288
Assert there's no active scheduler before freezing
ryoqun Apr 23, 2023
eed7db0
Move to ClusterConfig
ryoqun Apr 23, 2023
26607d1
Rename replace_{scheduler,scheduling}_context()
ryoqun Apr 27, 2023
b74f316
Add mermaid charts for InstalledScheduler
ryoqun Apr 27, 2023
546596a
Apply recent rename...
ryoqun Apr 27, 2023
43bbe42
Fix ci...
ryoqun Apr 27, 2023
090610f
Fix Arc<Bank> in chart...
ryoqun Apr 27, 2023
21b7250
Rename: strip redundant prefix from trait methods
ryoqun Apr 28, 2023
305e75b
Add some traits for bench
ryoqun May 8, 2023
4c2df8d
Add benches for scheduler
ryoqun May 8, 2023
12b3cb5
Make scheulder more generic over tx type shape
ryoqun May 12, 2023
8bbfaf8
Avoid transaction.clone() by Cow pass-thru
ryoqun May 12, 2023
6a4101c
Add sanity-checks for ledger-tool verify
ryoqun May 12, 2023
f2051db
Run benches in the scheduler-pool crate
ryoqun May 12, 2023
f863c71
Simplify IntoCow helper trait a bit
ryoqun May 13, 2023
b44475b
Move out of too-croweded bank.rs to proper file
ryoqun May 13, 2023
81075ac
Move scheduler out of Bank
ryoqun May 22, 2023
b3db6a0
ci...
ryoqun May 22, 2023
3f3dbde
Fix test...
ryoqun May 22, 2023
5c2d4fe
Fix build failure due to feature unification...
ryoqun May 22, 2023
ab1ed84
Use register_unique_tick() as possible
ryoqun May 24, 2023
c4f44cc
Add benches to show bad frequent synchronization
ryoqun May 24, 2023
ac8193e
Simplify is_done
ryoqun Jun 8, 2023
3d7c60f
Define register_tick to remove with_scheduler_lock
ryoqun Jun 8, 2023
56fc5f5
Add messages to assert!
ryoqun Jun 8, 2023
51d8783
Fix typo
ryoqun Jun 8, 2023
00088ed
Remove needless explicit drop()
ryoqun Jun 8, 2023
b2aa017
Use vec![elm; len]
ryoqun Jun 8, 2023
74b9439
Remove .bank{,_cloned}() fully relying on Deref
ryoqun Jun 8, 2023
ed59ea6
Remove into_bank() as well
ryoqun Jun 9, 2023
9a209d8
Small fixes
ryoqun Jun 15, 2023
1c89b9a
Add race condition test of recent_blockhashes
ryoqun Jun 15, 2023
5158a2d
Fix ci....
ryoqun Jun 16, 2023
2e614f6
Simplify BankWithScheduler::new() arguments
ryoqun Jun 27, 2023
b16d201
Move const to its sole use-site
ryoqun Jun 27, 2023
9f32fac
Release lock more early
ryoqun Jun 27, 2023
df692d7
Simplify ScheduledTransactionHandler::handle args
ryoqun Jun 27, 2023
e2d3d7c
add comment
ryoqun Jun 28, 2023
3843793
Properly document BankWithScheduler
ryoqun Jun 29, 2023
a241a8b
Add comment for weak_self
ryoqun Jun 29, 2023
7549b41
Give up maintaining rather meaningless comments
ryoqun Jun 29, 2023
f9df200
Fix comment
ryoqun Jun 29, 2023
1dc0c2c
Don't mix inlined and non-inlined
ryoqun Jun 29, 2023
1415748
Remove actually used SEA from PhantomData
ryoqun Jun 29, 2023
f2e6442
Name actual types which are causing dyn trait
ryoqun Jun 29, 2023
9f82921
Remove explicit spelling of droped type
ryoqun Jun 29, 2023
7958435
Disable cargo-audit for now
ryoqun Jun 29, 2023
60edf6b
Disable downstream for now
ryoqun Jun 29, 2023
b39e2c9
Add doc comment to SchedulingContext
ryoqun Jun 29, 2023
465205e
Remove needless variable assignment
ryoqun Jun 30, 2023
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
106 changes: 106 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 7 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,8 @@ members = [
"rpc-test",
"runtime",
"runtime/store-tool",
"scheduler",
"scheduler-pool",
"sdk",
"sdk/cargo-build-bpf",
"sdk/cargo-build-sbf",
Expand Down Expand Up @@ -121,6 +123,7 @@ license = "Apache-2.0"
edition = "2021"

[workspace.dependencies]
aquamarine = "0.3.1"
aes-gcm-siv = "0.10.3"
ahash = "0.8.3"
anyhow = "1.0.70"
Expand Down Expand Up @@ -231,8 +234,10 @@ memmap2 = "0.5.10"
memoffset = "0.8"
merlin = "3"
min-max-heap = "1.3.0"
mockall = "0.11.4"
modular-bitfield = "0.11.2"
nix = "0.25.1"
nohash-hasher = "0.2.0"
num-bigint = "0.4.3"
num_cpus = "1.13.1"
num_enum = "0.5.7"
Expand Down Expand Up @@ -340,6 +345,8 @@ solana-rpc-client = { path = "rpc-client", version = "=1.16.0", default-features
solana-rpc-client-api = { path = "rpc-client-api", version = "=1.16.0" }
solana-rpc-client-nonce-utils = { path = "rpc-client-nonce-utils", version = "=1.16.0" }
solana-runtime = { path = "runtime", version = "=1.16.0" }
solana-scheduler = { path = "scheduler", version = "=1.16.0" }
solana-scheduler-pool = { path = "scheduler-pool", version = "=1.16.0" }
solana-sdk = { path = "sdk", version = "=1.16.0" }
solana-sdk-macro = { path = "sdk/macro", version = "=1.16.0" }
solana-send-transaction-service = { path = "send-transaction-service", version = "=1.16.0" }
Expand Down
2 changes: 1 addition & 1 deletion banking-bench/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ solana-ledger = { workspace = true }
solana-logger = { workspace = true }
solana-measure = { workspace = true }
solana-perf = { workspace = true }
solana-poh = { workspace = true }
solana-poh = { workspace = true, features = ["test-in-workspace"] }
solana-runtime = { workspace = true }
solana-sdk = { workspace = true }
solana-streamer = { workspace = true }
Expand Down
2 changes: 1 addition & 1 deletion banking-bench/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -538,7 +538,7 @@ fn main() {
);

assert!(poh_recorder.read().unwrap().bank().is_none());
poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
assert!(poh_recorder.read().unwrap().bank().is_some());
debug!(
"new_bank_time: {}us insert_time: {}us poh_time: {}us",
Expand Down
3 changes: 2 additions & 1 deletion ci/run-sanity.sh
Original file line number Diff line number Diff line change
Expand Up @@ -39,4 +39,5 @@ $solana_ledger_tool create-snapshot --ledger config/ledger "$snapshot_slot" conf
cp config/ledger/genesis.tar.bz2 config/snapshot-ledger
$solana_ledger_tool copy --ledger config/ledger \
--target-db config/snapshot-ledger --starting-slot "$snapshot_slot" --ending-slot "$latest_slot"
$solana_ledger_tool verify --ledger config/snapshot-ledger
$solana_ledger_tool verify --ledger config/snapshot-ledger --block-verification-method blockstore-processor
$solana_ledger_tool verify --ledger config/snapshot-ledger --block-verification-method unified-scheduler
4 changes: 4 additions & 0 deletions ci/test-bench.sh
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,10 @@ _ $cargoNightly bench --manifest-path gossip/Cargo.toml ${V:+--verbose} \
_ $cargoNightly bench --manifest-path poh/Cargo.toml ${V:+--verbose} \
-- -Z unstable-options --format=json | tee -a "$BENCH_FILE"

# Run scheduler-pool benches
_ $cargoNightly bench --manifest-path scheduler-pool/Cargo.toml ${V:+--verbose} \
-- -Z unstable-options --format=json | tee -a "$BENCH_FILE"

# Run core benches
_ $cargoNightly bench --manifest-path core/Cargo.toml ${V:+--verbose} \
-- -Z unstable-options --format=json | tee -a "$BENCH_FILE"
Expand Down
3 changes: 3 additions & 0 deletions core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ solana-rayon-threadlimit = { workspace = true }
solana-rpc = { workspace = true }
solana-rpc-client-api = { workspace = true }
solana-runtime = { workspace = true }
solana-scheduler-pool = { workspace = true }
solana-sdk = { workspace = true }
solana-send-transaction-service = { workspace = true }
solana-streamer = { workspace = true }
Expand All @@ -76,7 +77,9 @@ raptorq = { workspace = true }
serde_json = { workspace = true }
serial_test = { workspace = true }
solana-logger = { workspace = true }
solana-poh = { workspace = true, features = ["test-in-workspace"] }
solana-program-runtime = { workspace = true }
solana-runtime = { workspace = true, features = ["test-in-workspace"] }
solana-stake-program = { workspace = true }
static_assertions = { workspace = true }
systemstat = { workspace = true }
Expand Down
4 changes: 3 additions & 1 deletion core/benches/banking_stage.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@ use {
solana_perf::{packet::to_packet_batches, test_tx::test_tx},
solana_poh::poh_recorder::{create_test_recorder, WorkingBankEntry},
solana_runtime::{
bank::Bank, bank_forks::BankForks, prioritization_fee_cache::PrioritizationFeeCache,
bank::Bank, bank_forks::BankForks, installed_scheduler_pool::BankWithScheduler,
prioritization_fee_cache::PrioritizationFeeCache,
},
solana_sdk::{
genesis_config::GenesisConfig,
Expand Down Expand Up @@ -385,6 +386,7 @@ fn simulate_process_entries(
num_accounts: usize,
) {
let bank = Arc::new(Bank::new_for_benches(genesis_config));
let bank = BankWithScheduler::new_without_scheduler(bank);

for i in 0..(num_accounts / 2) {
bank.transfer(initial_lamports, mint_keypair, &keypairs[i * 2].pubkey())
Expand Down
2 changes: 1 addition & 1 deletion core/src/banking_stage.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1018,7 +1018,7 @@ mod tests {

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
let pubkey = solana_sdk::pubkey::new_rand();
let keypair2 = Keypair::new();
let pubkey2 = solana_sdk::pubkey::new_rand();
Expand Down
20 changes: 10 additions & 10 deletions core/src/banking_stage/consumer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -747,7 +747,7 @@ mod tests {
let recorder = poh_recorder.new_recorder();
let poh_recorder = Arc::new(RwLock::new(poh_recorder));

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

Expand Down Expand Up @@ -894,7 +894,7 @@ mod tests {

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
let (replay_vote_sender, _replay_vote_receiver) = unbounded();
let committer = Committer::new(
None,
Expand Down Expand Up @@ -1021,7 +1021,7 @@ mod tests {

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
let (replay_vote_sender, _replay_vote_receiver) = unbounded();
let committer = Committer::new(
None,
Expand Down Expand Up @@ -1093,7 +1093,7 @@ mod tests {

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
let (replay_vote_sender, _replay_vote_receiver) = unbounded();
let committer = Committer::new(
None,
Expand Down Expand Up @@ -1212,7 +1212,7 @@ mod tests {
let recorder = poh_recorder.new_recorder();
let poh_recorder = Arc::new(RwLock::new(poh_recorder));

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

Expand Down Expand Up @@ -1512,7 +1512,7 @@ mod tests {

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);

let shreds = entries_to_test_shreds(
&entries,
Expand Down Expand Up @@ -1650,7 +1650,7 @@ mod tests {

let poh_simulator = simulate_poh(record_receiver, &poh_recorder);

poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);

let shreds = entries_to_test_shreds(
&entries,
Expand Down Expand Up @@ -1751,7 +1751,7 @@ mod tests {
assert_eq!(buffered_packet_batches.len(), num_conflicting_transactions);
// When the working bank in poh_recorder is Some, all packets should be processed.
// Multi-Iterator will process them 1-by-1 if all txs are conflicting.
poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
let bank_start = poh_recorder.read().unwrap().bank_start().unwrap();
let banking_stage_stats = BankingStageStats::default();
consumer.consume_buffered_packets(
Expand Down Expand Up @@ -1831,7 +1831,7 @@ mod tests {
assert_eq!(buffered_packet_batches.len(), num_conflicting_transactions);
// When the working bank in poh_recorder is Some, all packets should be processed.
// Multi-Iterator will process them 1-by-1 if all txs are conflicting.
poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
let bank_start = poh_recorder.read().unwrap().bank_start().unwrap();
consumer.consume_buffered_packets(
&bank_start,
Expand Down Expand Up @@ -1886,7 +1886,7 @@ mod tests {
// When the working bank in poh_recorder is Some, all packets should be processed
// except except for retryable errors. Manually take the lock of a transaction to
// simulate another thread processing a transaction with that lock.
poh_recorder.write().unwrap().set_bank(&bank, false);
poh_recorder.write().unwrap().set_bank_for_test(&bank);
let bank_start = poh_recorder.read().unwrap().bank_start().unwrap();

let lock_account = transactions[0].message.account_keys[1];
Expand Down
Loading