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

Sassafras Consensus Pallet #1577

Merged
merged 132 commits into from
Dec 1, 2023
Merged
Show file tree
Hide file tree
Changes from 76 commits
Commits
Show all changes
132 commits
Select commit Hold shift + click to select a range
3b1f85f
Sassafras pallet draft
davxy Aug 31, 2023
d8e5bb6
Remove copyright year
davxy Aug 31, 2023
a216de6
Address some of the open points
davxy Sep 12, 2023
31334fd
Remove code for epoch change management via external session-pallet
davxy Sep 12, 2023
ddc9d7d
Begin Sassafras benchmarking
davxy Sep 12, 2023
201c853
Test using pre-built tickets
davxy Sep 12, 2023
d30f701
Max tickets is bounded to slots per epoch
davxy Sep 13, 2023
d5bdb91
Benchmarking experiments
davxy Sep 13, 2023
c5a1cdb
Benchmarking support in the node template
davxy Sep 13, 2023
893c25e
Merge branch 'master' into sassafras-pallet
davxy Sep 13, 2023
7b37a1b
Fix after master merge
davxy Sep 13, 2023
418bf4d
Remove not required timestamp pallet
davxy Sep 13, 2023
c459601
Temporary patch ring-proof deps (broken no-std compat)
davxy Sep 14, 2023
b6b4630
Benchmarks and first weights results
davxy Sep 14, 2023
76f08ff
Some more benches
davxy Sep 14, 2023
bf36518
Clean open TODOs
davxy Sep 14, 2023
c667ddf
cleanup
davxy Sep 14, 2023
dc25a95
Cleanup
davxy Sep 14, 2023
4e74f89
Add license to weights file
davxy Sep 14, 2023
adf34b0
Prepare code for verifier persistence
davxy Sep 15, 2023
cec9eb5
No need to store the whole SlotClaim
davxy Sep 15, 2023
b84a342
Use next epoch authorities for ring verifier
davxy Sep 15, 2023
27ed420
Merge branch 'master' into davxy-sassafras-pallet
davxy Sep 19, 2023
da4e1ae
Patch only ring-proof and fflonk
davxy Sep 19, 2023
ccb7bea
Remove versions from pallets referenced by path
davxy Sep 19, 2023
c0ca577
Use experimental bandersnatch_vrfs with host functions
davxy Sep 27, 2023
0196d75
Merge branch 'master' into davxy-sassafras-pallet
davxy Sep 27, 2023
303bfbb
Introduce ark host functions
davxy Sep 27, 2023
b96b6fa
Workaround while waiting for serializable Verifier
davxy Oct 5, 2023
48a2dc5
Use patched bandersnatch_vrfs
davxy Oct 7, 2023
dafaab5
Make clippy happy
davxy Oct 7, 2023
5fbee17
Merge branch 'master' into davxy-sassafras-pallet
davxy Oct 7, 2023
0d0c181
Zepter fix
davxy Oct 7, 2023
8c95324
More Zepter hints
davxy Oct 7, 2023
ba35931
Zepter 😁
davxy Oct 7, 2023
db33af0
Merge branch 'master' into davxy-sassafras-pallet
davxy Oct 16, 2023
89a398a
Fix after master merge
davxy Oct 16, 2023
06505bb
Make clippy happy
davxy Oct 16, 2023
6116b31
remove unused clone
davxy Oct 17, 2023
1a13de3
Boost ring context construction perfs by:
davxy Oct 19, 2023
eea2516
Fix benchmark results
davxy Oct 19, 2023
200ba5f
Fix clippy
davxy Oct 19, 2023
84e7321
Update readme
davxy Oct 19, 2023
b64d530
Merge branch 'master' into davxy-sassafras-pallet
davxy Oct 19, 2023
3649d47
Remove hardcoded value
davxy Oct 19, 2023
3ddc578
Docs cleanup
davxy Oct 20, 2023
ed54065
Outstanding unsorted segments have all the same size
davxy Oct 20, 2023
bb60ae9
Update weights
davxy Oct 20, 2023
f2aceea
Cleanup
davxy Oct 23, 2023
3647da9
Restore upstream fflonk crate
davxy Oct 23, 2023
83d3492
Add license to weights file
davxy Oct 23, 2023
288e443
Merge branch 'master' into davxy-sassafras-pallet
davxy Oct 31, 2023
c02702b
Bump bandersnatch_vrfs rev
davxy Oct 31, 2023
df1139c
Use new host functions
davxy Oct 31, 2023
90e7c8a
Merge branch 'master' into davxy-sassafras-pallet
davxy Nov 1, 2023
3a2749c
Patch bandersnatch
davxy Nov 1, 2023
6c5dd08
Update fflonk
davxy Nov 1, 2023
ec8eb0a
Benchmark notes update
davxy Nov 1, 2023
de21bf8
Merge branch 'master' into davxy-sassafras-pallet
davxy Nov 1, 2023
209037e
Merge branch 'master' into davxy-sassafras-pallet
davxy Nov 2, 2023
b45ce50
Integration of pallet-sassafras in kitchensink node for the sake of b…
davxy Nov 3, 2023
6a07572
Independence from periodic time
davxy Nov 3, 2023
ceab697
Cleanup some TODOs
davxy Nov 3, 2023
7f7255c
Move the benchmarking to kitchensink
davxy Nov 3, 2023
a8b4f6b
Restore master template
davxy Nov 3, 2023
59feb26
Remove some allocations
davxy Nov 3, 2023
518dee7
Tests/Benches refactory and bigger ring size
davxy Nov 3, 2023
ea370dd
Update weights
davxy Nov 3, 2023
72288ed
Fix some dependencies required by some auxiliary stuff
davxy Nov 4, 2023
99d9cae
Fix new serde gated stuff in bandersnatch
davxy Nov 4, 2023
2d4d32f
Revert to node-template
davxy Nov 4, 2023
ba8000f
Expand ring vrf domain size to 2048
davxy Nov 4, 2023
a057593
Update benchmark-results.md
davxy Nov 4, 2023
f7774b8
Update benchmark-results.md
davxy Nov 4, 2023
ea5c966
Update benchmark-results.md
davxy Nov 4, 2023
a7bd12d
Small fix and better docs
davxy Nov 6, 2023
de873c4
Merge branch 'master' into davxy-sassafras-pallet
davxy Nov 6, 2023
6ea2b14
Merge branch 'master' into davxy-sassafras-pallet
davxy Nov 8, 2023
bb16327
Use #2190 fix
davxy Nov 8, 2023
b1c468f
Trivial tweaks
davxy Nov 11, 2023
02cdcba
Structs fields order inline with Sassafras RFC
davxy Nov 11, 2023
5c345b3
Apply suggestions from code review
davxy Nov 13, 2023
a66f9d8
Use separate bounded vector for sorted candidates
davxy Nov 13, 2023
ced5b81
Merge branch 'davxy-sassafras-pallet' of github.com:paritytech/polkad…
davxy Nov 13, 2023
edb0e39
on_initialize weight
davxy Nov 13, 2023
d9607b6
Proper on_initialize weight
davxy Nov 13, 2023
2c63652
Fix test
davxy Nov 13, 2023
4ddc48d
Fix markdown
davxy Nov 13, 2023
294265b
Apply suggestions from code review
davxy Nov 14, 2023
67c565b
Apply suggestions
davxy Nov 14, 2023
ffefc22
Duplicate tickets must be discarded
davxy Nov 14, 2023
649f245
Apply code suggestions
davxy Nov 14, 2023
a304802
Apply suggestions from code review
davxy Nov 14, 2023
0b21a57
Add some corner cases for outside in sortition
davxy Nov 14, 2023
64406b6
Apply suggestions from code review
davxy Nov 14, 2023
c1cc3ef
Rename 'todo' variable
davxy Nov 14, 2023
e4ac081
Apply suggestions from code review
davxy Nov 14, 2023
42371d6
Add reference to the w3f layman overview
davxy Nov 14, 2023
2e88209
Apply suggestions from code review
davxy Nov 14, 2023
f45ef2f
Skip 3 epochs in the test
davxy Nov 14, 2023
0471c6b
Docs adjustments
davxy Nov 15, 2023
ac074bb
Utility accessors
davxy Nov 15, 2023
1af7fef
Remove cruft
davxy Nov 15, 2023
5a19e0c
Check for submission epoch related constraint in extrinsic
davxy Nov 15, 2023
35e742d
Ticket sorting graph
davxy Nov 15, 2023
b52f339
Amend pic
davxy Nov 15, 2023
115934c
Trigger worst case when computing 'enact_epoch_change' weight
davxy Nov 16, 2023
1b659c8
Improve ticket_id_threshold docs
davxy Nov 16, 2023
ea94758
Optimize segments sorting
davxy Nov 16, 2023
4d42558
Recompute weights
davxy Nov 16, 2023
2c70a7b
Zepter fix
davxy Nov 16, 2023
41a34ff
Epoch length type set to u32
davxy Nov 16, 2023
a889c2c
Fix a codepath where metadata was not written back in storage
davxy Nov 16, 2023
431d18c
Update weights
davxy Nov 16, 2023
1841896
Make clippy happy
davxy Nov 16, 2023
b0bfcff
Fix doc
davxy Nov 20, 2023
4ca8eb0
Post genesis pallet initialization
davxy Nov 23, 2023
30d9c7c
Fix tests after new randomness initialization policy
davxy Nov 23, 2023
6188189
Include both genesis hash and base slot number in post-genesis random…
davxy Nov 23, 2023
6ebfaa6
Apply suggestions from code review
davxy Nov 29, 2023
d68d992
Include missing traits
davxy Nov 30, 2023
c1750ed
Use derive_impl to construct frame_system Config
davxy Nov 30, 2023
2af09df
Merge branch 'master' into davxy-sassafras-pallet
davxy Nov 30, 2023
4420b00
Apply suggestions from code review
davxy Nov 30, 2023
1ccba97
Temporary patch ring-proof
davxy Nov 30, 2023
67712a7
Remove leftover
davxy Nov 30, 2023
255f90e
Restore working tests
davxy Nov 30, 2023
8aca3b6
Apply suggestions from code review
davxy Nov 30, 2023
41139dc
Merge branch 'master' into davxy-sassafras-pallet
davxy Nov 30, 2023
4fd7f7a
Revert node-template
davxy Dec 1, 2023
3b29570
Merge branch 'master' into davxy-sassafras-pallet
davxy Dec 1, 2023
f110a14
Fix lock
davxy Dec 1, 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
27 changes: 25 additions & 2 deletions Cargo.lock

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

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -338,6 +338,7 @@ members = [
"substrate/frame/root-testing",
"substrate/frame/safe-mode",
"substrate/frame/salary",
"substrate/frame/sassafras",
"substrate/frame/scheduler",
"substrate/frame/scored-pool",
"substrate/frame/session",
Expand Down
35 changes: 35 additions & 0 deletions benchmark.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
#!/bin/bash
davxy marked this conversation as resolved.
Show resolved Hide resolved

binary="./target/release/node-template"

steps=10
repeat=3

export RUST_LOG="sassafras=debug"

pallet='pallet_sassafras'

bench=$1

if [[ $bench == "" ]]; then
list=$($binary benchmark pallet --list | grep $pallet | cut -d ',' -f 2)

echo "Usage: $0 <benchmark>"
echo ""
echo "Available benchmarks:"
for bench in $list; do
echo "- $bench"
done
exit
fi

extrinsic=$bench

$binary benchmark pallet \
--chain dev \
--pallet $pallet \
--extrinsic "$extrinsic" \
--steps $steps \
--repeat $repeat \
--output weights.rs \
--template substrate/.maintain/frame-weight-template.hbs
3 changes: 3 additions & 0 deletions substrate/bin/node-template/node/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,9 @@ sp-keyring = { path = "../../../primitives/keyring" }
frame-system = { path = "../../../frame/system" }
pallet-transaction-payment = { path = "../../../frame/transaction-payment", default-features = false}

sp-consensus-sassafras = { path = "../../../primitives/consensus/sassafras" }
sp-crypto-ec-utils = { path = "../../../primitives/crypto/ec-utils", features = ["bls12-381","ed-on-bls12-381-bandersnatch"] }

davxy marked this conversation as resolved.
Show resolved Hide resolved
# These dependencies are used for the node template's RPCs
jsonrpsee = { version = "0.16.2", features = ["server"] }
sp-api = { path = "../../../primitives/api" }
Expand Down
19 changes: 14 additions & 5 deletions substrate/bin/node-template/node/src/chain_spec.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
use node_template_runtime::{
AccountId, AuraConfig, BalancesConfig, GrandpaConfig, RuntimeGenesisConfig, Signature,
SudoConfig, SystemConfig, WASM_BINARY,
AccountId, AuraConfig, BalancesConfig, GrandpaConfig, RuntimeGenesisConfig, SassafrasConfig,
Signature, SudoConfig, SystemConfig, WASM_BINARY,
};
use sc_service::ChainType;
use sp_consensus_aura::sr25519::AuthorityId as AuraId;
use sp_consensus_grandpa::AuthorityId as GrandpaId;
use sp_consensus_sassafras::AuthorityId as SassafrasId;
use sp_core::{sr25519, Pair, Public};
use sp_runtime::traits::{IdentifyAccount, Verify};

Expand Down Expand Up @@ -32,8 +33,8 @@ where
}

/// Generate an Aura authority key.
pub fn authority_keys_from_seed(s: &str) -> (AuraId, GrandpaId) {
(get_from_seed::<AuraId>(s), get_from_seed::<GrandpaId>(s))
pub fn authority_keys_from_seed(s: &str) -> (AuraId, GrandpaId, SassafrasId) {
(get_from_seed::<AuraId>(s), get_from_seed::<GrandpaId>(s), get_from_seed::<SassafrasId>(s))
}

pub fn development_config() -> Result<ChainSpec, String> {
Expand Down Expand Up @@ -127,7 +128,7 @@ pub fn local_testnet_config() -> Result<ChainSpec, String> {
/// Configure initial storage state for FRAME modules.
fn testnet_genesis(
wasm_binary: &[u8],
initial_authorities: Vec<(AuraId, GrandpaId)>,
initial_authorities: Vec<(AuraId, GrandpaId, SassafrasId)>,
root_key: AccountId,
endowed_accounts: Vec<AccountId>,
_enable_println: bool,
Expand All @@ -154,5 +155,13 @@ fn testnet_genesis(
key: Some(root_key),
},
transaction_payment: Default::default(),
sassafras: SassafrasConfig {
authorities: initial_authorities.iter().map(|x| x.2.clone()).collect(),
epoch_config: sp_consensus_sassafras::EpochConfiguration {
attempts_number: 32,
redundancy_factor: 2,
},
..Default::default()
},
}
}
5 changes: 4 additions & 1 deletion substrate/bin/node-template/node/src/command.rs
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,10 @@ pub fn run() -> sc_cli::Result<()> {
)
}

cmd.run::<Block, ()>(config)
cmd.run::<Block, (
sp_crypto_ec_utils::bls12_381::host_calls::HostFunctions,
sp_crypto_ec_utils::ed_on_bls12_381_bandersnatch::host_calls::HostFunctions,
)>(config)
},
BenchmarkCmd::Block(cmd) => {
let PartialComponents { client, .. } = service::new_partial(&config)?;
Expand Down
21 changes: 15 additions & 6 deletions substrate/bin/node-template/node/src/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,25 @@ use sc_transaction_pool_api::OffchainTransactionPoolFactory;
use sp_consensus_aura::sr25519::AuthorityPair as AuraPair;
use std::{sync::Arc, time::Duration};

/// Only enable the benchmarking host functions when we actually want to benchmark.
#[cfg(feature = "runtime-benchmarks")]
type ExtendHostFunctions = (
sp_crypto_ec_utils::bls12_381::host_calls::HostFunctions,
sp_crypto_ec_utils::ed_on_bls12_381_bandersnatch::host_calls::HostFunctions,
frame_benchmarking::benchmarking::HostFunctions,
);
/// Otherwise we only use the default Substrate host functions.
#[cfg(not(feature = "runtime-benchmarks"))]
type ExtendHostFunctions = (
sp_crypto_ec_utils::bls12_381::host_calls::HostFunctions,
sp_crypto_ec_utils::ed_on_bls12_381_bandersnatch::host_calls::HostFunctions,
);

// Our native executor instance.
pub struct ExecutorDispatch;

impl sc_executor::NativeExecutionDispatch for ExecutorDispatch {
/// Only enable the benchmarking host functions when we actually want to benchmark.
#[cfg(feature = "runtime-benchmarks")]
type ExtendHostFunctions = frame_benchmarking::benchmarking::HostFunctions;
/// Otherwise we only use the default Substrate host functions.
#[cfg(not(feature = "runtime-benchmarks"))]
type ExtendHostFunctions = ();
type ExtendHostFunctions = ExtendHostFunctions;

fn dispatch(method: &str, data: &[u8]) -> Option<Vec<u8>> {
node_template_runtime::api::dispatch(method, data)
Expand Down
7 changes: 7 additions & 0 deletions substrate/bin/node-template/runtime/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,9 @@ sp-transaction-pool = { path = "../../../primitives/transaction-pool", default-f
sp-version = { path = "../../../primitives/version", default-features = false}
sp-genesis-builder = { default-features = false, path = "../../../primitives/genesis-builder" }

pallet-sassafras = { path = "../../../frame/sassafras", default-features = false, features = ["construct-dummy-ring-context"]}
sp-consensus-sassafras = { path = "../../../primitives/consensus/sassafras", default-features = false}

# Used for the node template's RPCs
frame-system-rpc-runtime-api = { path = "../../../frame/system/rpc/runtime-api", default-features = false}
pallet-transaction-payment-rpc-runtime-api = { path = "../../../frame/transaction-payment/rpc/runtime-api", default-features = false}
Expand Down Expand Up @@ -90,6 +93,8 @@ std = [
"sp-transaction-pool/std",
"sp-version/std",
"substrate-wasm-builder",
"pallet-sassafras/std",
"sp-consensus-sassafras/std",
]
runtime-benchmarks = [
"frame-benchmarking/runtime-benchmarks",
Expand All @@ -102,6 +107,7 @@ runtime-benchmarks = [
"pallet-template/runtime-benchmarks",
"pallet-timestamp/runtime-benchmarks",
"sp-runtime/runtime-benchmarks",
"pallet-sassafras/runtime-benchmarks",
]
try-runtime = [
"frame-executive/try-runtime",
Expand All @@ -116,5 +122,6 @@ try-runtime = [
"pallet-timestamp/try-runtime",
"pallet-transaction-payment/try-runtime",
"sp-runtime/try-runtime",
"pallet-sassafras/try-runtime",
]
experimental = [ "pallet-aura/experimental" ]
17 changes: 17 additions & 0 deletions substrate/bin/node-template/runtime/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -280,6 +280,21 @@ impl pallet_template::Config for Runtime {
type WeightInfo = pallet_template::weights::SubstrateWeight<Runtime>;
}

impl pallet_sassafras::Config for Runtime {
type EpochLength = ConstU64<200>;
type MaxAuthorities = ConstU32<100>;
type EpochChangeTrigger = pallet_sassafras::EpochChangeInternalTrigger;
type WeightInfo = pallet_sassafras::weights::SubstrateWeight<Runtime>;
}

impl<C> frame_system::offchain::SendTransactionTypes<C> for Runtime
where
RuntimeCall: From<C>,
{
type Extrinsic = UncheckedExtrinsic;
type OverarchingCall = RuntimeCall;
}

// Create the runtime by composing the FRAME pallets that were previously configured.
construct_runtime!(
pub struct Runtime {
Expand All @@ -292,6 +307,7 @@ construct_runtime!(
Sudo: pallet_sudo,
// Include the custom logic from the pallet-template in the runtime.
TemplateModule: pallet_template,
Sassafras: pallet_sassafras,
}
);

Expand Down Expand Up @@ -340,6 +356,7 @@ mod benches {
[pallet_timestamp, Timestamp]
[pallet_sudo, Sudo]
[pallet_template, TemplateModule]
[pallet_sassafras, Sassafras]
);
}

Expand Down
59 changes: 59 additions & 0 deletions substrate/frame/sassafras/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
[package]
name = "pallet-sassafras"
version = "0.3.5-dev"
authors = ["Parity Technologies <admin@parity.io>"]
edition = "2021"
license = "Apache-2.0"
homepage = "https://substrate.io"
repository = "/~https://github.com/paritytech/substrate/"
description = "Consensus extension module for Sassafras consensus."
readme = "README.md"
publish = false

[package.metadata.docs.rs]
targets = ["x86_64-unknown-linux-gnu"]

[dependencies]
scale-codec = { package = "parity-scale-codec", version = "3.6.1", default-features = false, features = ["derive"] }
scale-info = { version = "2.5.0", default-features = false, features = ["derive"] }
frame-benchmarking = { path = "../benchmarking", default-features = false, optional = true }
frame-support = { path = "../support", default-features = false }
frame-system = { path = "../system", default-features = false }
log = { version = "0.4.17", default-features = false }
sp-consensus-sassafras = { path = "../../primitives/consensus/sassafras", default-features = false, features = ["serde"] }
sp-io = { path = "../../primitives/io", default-features = false }
sp-runtime = { path = "../../primitives/runtime", default-features = false }
sp-std = { path = "../../primitives/std", default-features = false }

[dev-dependencies]
array-bytes = "6.1"
env_logger = "0.10"
sp-core = { path = "../../primitives/core" }

[features]
default = [ "std" ]
std = [
"frame-benchmarking?/std",
"frame-support/std",
"frame-system/std",
"log/std",
"scale-codec/std",
"scale-info/std",
"sp-consensus-sassafras/std",
"sp-io/std",
"sp-runtime/std",
"sp-std/std",
]
runtime-benchmarks = [
"frame-benchmarking/runtime-benchmarks",
"frame-support/runtime-benchmarks",
"frame-system/runtime-benchmarks",
"sp-runtime/runtime-benchmarks",
]
try-runtime = [
"frame-support/try-runtime",
"frame-system/try-runtime",
"sp-runtime/try-runtime",
]
# Construct dummy ring context (useful for development)
construct-dummy-ring-context = []
11 changes: 11 additions & 0 deletions substrate/frame/sassafras/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
Runtime module for SASSAFRAS consensus.

Depends on `sp-core` feature: `bandersnatch-experimental`.
davxy marked this conversation as resolved.
Show resolved Hide resolved

- Tracking issue: /~https://github.com/paritytech/polkadot-sdk/issues/41
- Protocol RFC proposal: /~https://github.com/polkadot-fellows/RFCs/pull/26

# ⚠️ WARNING ⚠️

The crate interfaces and structures are highly experimental and may be subject
to significant changes.
Loading