Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

XCM v3: Context & ID hash #4756

Merged
merged 81 commits into from
Mar 8, 2022
Merged
Show file tree
Hide file tree
Changes from 44 commits
Commits
Show all changes
81 commits
Select commit Hold shift + click to select a range
fd5f8c2
send_xcm returns message hash
gavofyork Jan 20, 2022
1f5fdf4
cargo fmt
KiChjang Jan 21, 2022
1f2d3dc
Create topic register and instructions
KiChjang Jan 21, 2022
0194c91
Fix weights
KiChjang Jan 21, 2022
260025c
Use tabs
KiChjang Jan 21, 2022
e5ceb4c
Sketch out XcmContext
KiChjang Jan 21, 2022
870ac09
Merge branch 'gav-xcm-v3' into gav-xcm-v3-provide-hash
KiChjang Jan 24, 2022
0a19ace
Fix doc test
KiChjang Jan 25, 2022
25c55eb
Add the XCM context as a parameter to executor trait fns
KiChjang Jan 25, 2022
73af5b2
Fixes
KiChjang Jan 26, 2022
7973233
Add XcmContext parameter
KiChjang Jan 27, 2022
bc9cdca
Revert adding context as an arg to SendXcm trait methods
KiChjang Jan 29, 2022
ce34e1a
Revert adding context argument to ConvertOrigin trait methods
KiChjang Jan 29, 2022
9624125
cargo fmt
KiChjang Jan 29, 2022
10f1978
Do not change the API of XcmExecutor::execute
KiChjang Jan 29, 2022
fa0d0d0
Fixes
KiChjang Jan 29, 2022
b4661ea
Fixes
KiChjang Jan 29, 2022
eee33ac
Fixes
KiChjang Feb 2, 2022
46f598c
Merge branch 'gav-xcm-v3' into gav-xcm-v3-provide-hash
KiChjang Feb 2, 2022
149735b
Fixes
KiChjang Feb 2, 2022
e4be71e
Remove convenience method
KiChjang Feb 3, 2022
5b523b0
Fixes
KiChjang Feb 4, 2022
2a1f0e2
Fixes
KiChjang Feb 4, 2022
f431c55
cargo fmt
KiChjang Feb 4, 2022
d6fedf9
Fixes
KiChjang Feb 4, 2022
b044e79
Add benchmarks for XCM topic instructions
KiChjang Feb 5, 2022
163a456
cargo run --quiet --profile=production --features=runtime-benchmarks…
Feb 5, 2022
d897f92
Merge remote-tracking branch 'origin/gav-xcm-v3' into gav-xcm-v3-prov…
KiChjang Feb 19, 2022
62f4193
Remove context argument on FilterAssetLocation
KiChjang Feb 19, 2022
820232c
Merge branch 'gav-xcm-v3' into gav-xcm-v3-provide-hash
KiChjang Feb 19, 2022
166cac1
Fixes
KiChjang Feb 22, 2022
95a5855
Remove unused import
KiChjang Feb 22, 2022
c9b1ca7
Fixes
KiChjang Feb 22, 2022
8f41fbe
Fixes
KiChjang Feb 22, 2022
fd28e0e
Fixes
KiChjang Feb 22, 2022
5356680
Merge remote-tracking branch 'origin/gav-xcm-v3' into gav-xcm-v3-prov…
KiChjang Feb 22, 2022
d5819b3
Accept XCM hash parameter in ExecuteXcm trait methods
KiChjang Feb 22, 2022
03720b5
cargo fmt
KiChjang Feb 22, 2022
487e4e2
Properly enable sp-io/std
KiChjang Feb 22, 2022
85a151b
Fixes
KiChjang Feb 22, 2022
e83175a
default-features = false
KiChjang Feb 22, 2022
be3b4ff
Fixes
KiChjang Feb 22, 2022
3ba62db
Fixes
KiChjang Feb 22, 2022
33a4308
Fixes
KiChjang Feb 22, 2022
0de1a00
Make XcmContext optional in withdraw_asset
KiChjang Feb 23, 2022
f4751e2
Fixes
KiChjang Feb 23, 2022
f4cd038
Fixes
KiChjang Feb 23, 2022
8bf4f6a
Fixes
KiChjang Feb 23, 2022
4b62f97
Modify tests to check for the correct XCM hash
KiChjang Feb 24, 2022
8702ebc
Small refactor
KiChjang Feb 24, 2022
0cde431
cargo fmt
KiChjang Feb 24, 2022
2ca0117
Check for expected hash in xcm-builder unit tests
KiChjang Feb 24, 2022
3df1279
Add doc comment for the optionality of the XCM context in withdraw_asset
KiChjang Mar 1, 2022
3f36459
Merge branch 'gav-xcm-v3' into gav-xcm-v3-provide-hash
KiChjang Mar 2, 2022
a549286
Update xcm/src/v3/traits.rs
gavofyork Mar 5, 2022
18bb864
Update xcm/src/v3/traits.rs
gavofyork Mar 5, 2022
3c1117f
Store XcmContext and avoid rebuilding
gavofyork Mar 5, 2022
c554b97
Use ref for XcmContext
gavofyork Mar 5, 2022
292f8d4
Formatting
gavofyork Mar 5, 2022
4612154
Fix incorrect hash CC @KiChjang
gavofyork Mar 7, 2022
053c510
Refactor and make clear fake hashes
gavofyork Mar 7, 2022
9e463e1
Fixes
gavofyork Mar 7, 2022
63f7b60
Fixes
gavofyork Mar 7, 2022
e1933fa
Fixes
gavofyork Mar 7, 2022
c9d0e32
Fix broken hashing
gavofyork Mar 7, 2022
c3d1ddf
Docs
gavofyork Mar 7, 2022
a4e3656
Fixes
gavofyork Mar 7, 2022
788004d
Fixes
gavofyork Mar 7, 2022
c247f63
Fixes
gavofyork Mar 7, 2022
28899e4
Formatting
gavofyork Mar 7, 2022
8eab788
Merge branch 'gav-xcm-v3' into gav-xcm-v3-provide-hash
gavofyork Mar 7, 2022
f50e5d6
Fixes
gavofyork Mar 7, 2022
cd8b8dd
Fixes
gavofyork Mar 7, 2022
43f9ced
Fixes
gavofyork Mar 7, 2022
426370c
Remove unknowable hash
gavofyork Mar 7, 2022
84b3f98
Formatting
gavofyork Mar 7, 2022
145a876
Merge remote-tracking branch 'origin/gav-xcm-v3' into gav-xcm-v3-prov…
gavofyork Mar 8, 2022
46bda63
Use message hash for greater identifiability
gavofyork Mar 8, 2022
d1876fb
Formatting
gavofyork Mar 8, 2022
c7143c9
Fixes
gavofyork Mar 8, 2022
a2b1686
Formatting
gavofyork Mar 8, 2022
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
1 change: 1 addition & 0 deletions Cargo.lock

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

4 changes: 3 additions & 1 deletion runtime/common/src/xcm_sender.rs
Original file line number Diff line number Diff line change
Expand Up @@ -59,8 +59,10 @@ impl<T: configuration::Config + dmp::Config, W: xcm::WrapVersion> SendXcm

fn deliver(
(config, para, blob): (HostConfiguration<T::BlockNumber>, ParaId, Vec<u8>),
) -> Result<(), SendError> {
) -> Result<XcmHash, SendError> {
let hash = sp_io::hashing::blake2_256(&blob[..]);
<dmp::Pallet<T>>::queue_downward_message(&config, para, blob)
.map(|()| hash)
.map_err(|_| SendError::Transport(&"Error placing into DMP queue"))
}
}
2 changes: 1 addition & 1 deletion runtime/parachains/src/ump.rs
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ impl<XcmExecutor: xcm::latest::ExecuteXcm<C::Call>, C: Config> UmpSink for XcmSi
},
Ok(Ok(xcm_message)) => {
let xcm_junction = Junction::Parachain(origin.into());
let outcome = XcmExecutor::execute_xcm(xcm_junction, xcm_message, max_weight);
let outcome = XcmExecutor::execute_xcm(xcm_junction, xcm_message, id, max_weight);
match outcome {
Outcome::Error(XcmError::WeightLimitReached(required)) => Err((id, required)),
outcome => {
Expand Down
12 changes: 8 additions & 4 deletions runtime/test-runtime/src/xcm_config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,20 +45,24 @@ impl SendXcm for DoNothingRouter {
fn validate(_dest: &mut Option<MultiLocation>, _msg: &mut Option<Xcm<()>>) -> SendResult<()> {
Ok(((), MultiAssets::new()))
}
fn deliver(_: ()) -> Result<(), SendError> {
Ok(())
fn deliver(_: ()) -> Result<XcmHash, SendError> {
Ok([0; 32])
}
}

pub type Barrier = AllowUnpaidExecutionFrom<Everything>;

pub struct DummyAssetTransactor;
impl TransactAsset for DummyAssetTransactor {
fn deposit_asset(_what: &MultiAsset, _who: &MultiLocation) -> XcmResult {
fn deposit_asset(_what: &MultiAsset, _who: &MultiLocation, _context: XcmContext) -> XcmResult {
Ok(())
}

fn withdraw_asset(_what: &MultiAsset, _who: &MultiLocation) -> Result<Assets, XcmError> {
fn withdraw_asset(
_what: &MultiAsset,
_who: &MultiLocation,
_context: XcmContext,
) -> Result<Assets, XcmError> {
let asset: MultiAsset = (Parent, 100_000).into();
Ok(asset.into())
}
Expand Down
6 changes: 6 additions & 0 deletions runtime/westend/src/weights/xcm/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -238,4 +238,10 @@ impl<Call> XcmWeightInfo<Call> for WestendXcmWeight<Call> {
fn set_fees_mode(_: &bool) -> Weight {
Weight::MAX // todo fix
}
fn set_topic(_topic: &[u8; 32]) -> Weight {
XcmGeneric::<Runtime>::set_topic()
}
fn clear_topic() -> Weight {
XcmGeneric::<Runtime>::clear_topic()
}
}
60 changes: 33 additions & 27 deletions runtime/westend/src/weights/xcm/pallet_xcm_benchmarks_generic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,11 @@
//! Autogenerated weights for `pallet_xcm_benchmarks::generic`
//!
//! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 4.0.0-dev
//! DATE: 2021-12-20, STEPS: `50`, REPEAT: 20, LOW RANGE: `[]`, HIGH RANGE: `[]`
//! EXECUTION: Some(Wasm), WASM-EXECUTION: Compiled, CHAIN: Some("westend-dev"), DB CACHE: 128
//! DATE: 2022-02-05, STEPS: `50`, REPEAT: 20, LOW RANGE: `[]`, HIGH RANGE: `[]`
//! EXECUTION: Some(Wasm), WASM-EXECUTION: Compiled, CHAIN: Some("westend-dev"), DB CACHE: 1024

// Executed Command:
// target/release/polkadot
// target/production/polkadot
// benchmark
// --chain=westend-dev
// --steps=50
Expand Down Expand Up @@ -51,57 +51,57 @@ impl<T: frame_system::Config> WeightInfo<T> {
// Storage: Dmp DownwardMessageQueueHeads (r:1 w:1)
// Storage: Dmp DownwardMessageQueues (r:1 w:1)
pub(crate) fn report_holding() -> Weight {
(35_446_000 as Weight)
(24_000_000 as Weight)
.saturating_add(T::DbWeight::get().reads(5 as Weight))
.saturating_add(T::DbWeight::get().writes(3 as Weight))
}
pub(crate) fn buy_execution() -> Weight {
(5_228_000 as Weight)
(3_377_000 as Weight)
}
// Storage: XcmPallet Queries (r:1 w:0)
pub(crate) fn query_response() -> Weight {
(18_708_000 as Weight)
(12_418_000 as Weight)
.saturating_add(T::DbWeight::get().reads(1 as Weight))
}
pub(crate) fn transact() -> Weight {
(20_401_000 as Weight)
(12_795_000 as Weight)
}
pub(crate) fn refund_surplus() -> Weight {
(5_238_000 as Weight)
(3_485_000 as Weight)
}
pub(crate) fn set_error_handler() -> Weight {
(5_104_000 as Weight)
(3_314_000 as Weight)
}
pub(crate) fn set_appendix() -> Weight {
(5_095_000 as Weight)
(3_334_000 as Weight)
gavofyork marked this conversation as resolved.
Show resolved Hide resolved
}
pub(crate) fn clear_error() -> Weight {
(5_010_000 as Weight)
(3_240_000 as Weight)
}
pub(crate) fn descend_origin() -> Weight {
(6_368_000 as Weight)
(4_339_000 as Weight)
}
pub(crate) fn clear_origin() -> Weight {
(5_011_000 as Weight)
(3_338_000 as Weight)
}
// Storage: XcmPallet SupportedVersion (r:1 w:0)
// Storage: XcmPallet VersionDiscoveryQueue (r:1 w:1)
// Storage: XcmPallet SafeXcmVersion (r:1 w:0)
// Storage: Dmp DownwardMessageQueueHeads (r:1 w:1)
// Storage: Dmp DownwardMessageQueues (r:1 w:1)
pub(crate) fn report_error() -> Weight {
(27_823_000 as Weight)
(20_469_000 as Weight)
.saturating_add(T::DbWeight::get().reads(5 as Weight))
.saturating_add(T::DbWeight::get().writes(3 as Weight))
}
// Storage: XcmPallet AssetTraps (r:1 w:1)
pub(crate) fn claim_asset() -> Weight {
(12_402_000 as Weight)
(7_749_000 as Weight)
.saturating_add(T::DbWeight::get().reads(1 as Weight))
.saturating_add(T::DbWeight::get().writes(1 as Weight))
}
pub(crate) fn trap() -> Weight {
(5_022_000 as Weight)
(3_271_000 as Weight)
}
// Storage: XcmPallet VersionNotifyTargets (r:1 w:1)
// Storage: XcmPallet SupportedVersion (r:1 w:0)
Expand All @@ -110,13 +110,13 @@ impl<T: frame_system::Config> WeightInfo<T> {
// Storage: Dmp DownwardMessageQueueHeads (r:1 w:1)
// Storage: Dmp DownwardMessageQueues (r:1 w:1)
pub(crate) fn subscribe_version() -> Weight {
(32_492_000 as Weight)
(22_263_000 as Weight)
.saturating_add(T::DbWeight::get().reads(6 as Weight))
.saturating_add(T::DbWeight::get().writes(4 as Weight))
}
// Storage: XcmPallet VersionNotifyTargets (r:0 w:1)
pub(crate) fn unsubscribe_version() -> Weight {
(7_777_000 as Weight)
(5_366_000 as Weight)
.saturating_add(T::DbWeight::get().writes(1 as Weight))
}
// Storage: XcmPallet SupportedVersion (r:1 w:0)
Expand All @@ -125,46 +125,52 @@ impl<T: frame_system::Config> WeightInfo<T> {
// Storage: Dmp DownwardMessageQueueHeads (r:1 w:1)
// Storage: Dmp DownwardMessageQueues (r:1 w:1)
pub(crate) fn initiate_reserve_withdraw() -> Weight {
(37_066_000 as Weight)
(23_659_000 as Weight)
.saturating_add(T::DbWeight::get().reads(5 as Weight))
.saturating_add(T::DbWeight::get().writes(3 as Weight))
}
pub(crate) fn burn_asset() -> Weight {
(7_935_000 as Weight)
(4_910_000 as Weight)
}
pub(crate) fn expect_asset() -> Weight {
(5_237_000 as Weight)
(3_488_000 as Weight)
}
pub(crate) fn expect_origin() -> Weight {
(5_245_000 as Weight)
(3_400_000 as Weight)
}
pub(crate) fn expect_error() -> Weight {
(5_062_000 as Weight)
(3_358_000 as Weight)
}
// Storage: XcmPallet SupportedVersion (r:1 w:0)
// Storage: XcmPallet VersionDiscoveryQueue (r:1 w:1)
// Storage: XcmPallet SafeXcmVersion (r:1 w:0)
// Storage: Dmp DownwardMessageQueueHeads (r:1 w:1)
// Storage: Dmp DownwardMessageQueues (r:1 w:1)
pub(crate) fn query_pallet() -> Weight {
(28_876_000 as Weight)
(21_841_000 as Weight)
.saturating_add(T::DbWeight::get().reads(5 as Weight))
.saturating_add(T::DbWeight::get().writes(3 as Weight))
}
pub(crate) fn expect_pallet() -> Weight {
(5_526_000 as Weight)
(3_716_000 as Weight)
}
// Storage: XcmPallet SupportedVersion (r:1 w:0)
// Storage: XcmPallet VersionDiscoveryQueue (r:1 w:1)
// Storage: XcmPallet SafeXcmVersion (r:1 w:0)
// Storage: Dmp DownwardMessageQueueHeads (r:1 w:1)
// Storage: Dmp DownwardMessageQueues (r:1 w:1)
pub(crate) fn report_transact_status() -> Weight {
(27_889_000 as Weight)
(20_503_000 as Weight)
.saturating_add(T::DbWeight::get().reads(5 as Weight))
.saturating_add(T::DbWeight::get().writes(3 as Weight))
}
pub(crate) fn clear_transact_status() -> Weight {
(5_100_000 as Weight)
(3_270_000 as Weight)
}
pub(crate) fn set_topic() -> Weight {
(3_269_000 as Weight)
}
pub(crate) fn clear_topic() -> Weight {
(3_268_000 as Weight)
}
}
2 changes: 2 additions & 0 deletions xcm/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ edition = "2018"
impl-trait-for-tuples = "0.2.2"
parity-scale-codec = { version = "2.3.1", default-features = false, features = [ "derive", "max-encoded-len" ] }
scale-info = { version = "1.0", default-features = false, features = ["derive"] }
sp-io = { git = "https://github.com/paritytech/substrate", branch = "master", default-features = false }
derivative = {version = "2.2.0", default-features = false, features = [ "use_core" ] }
log = { version = "0.4.14", default-features = false }
xcm-procedural = { path = "procedural" }
Expand All @@ -20,4 +21,5 @@ runtime-benchmarks = []
std = [
"parity-scale-codec/std",
"scale-info/std",
"sp-io/std"
]
5 changes: 3 additions & 2 deletions xcm/pallet-xcm-benchmarks/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@ log = "0.4.0"
pallet-balances = { branch = "master", git = "https://github.com/paritytech/substrate" }
pallet-assets = { branch = "master", git = "https://github.com/paritytech/substrate" }
sp-core = { branch = "master", git = "https://github.com/paritytech/substrate" }
sp-io = { branch = "master", git = "https://github.com/paritytech/substrate" }
sp-tracing = { branch = "master", git = "https://github.com/paritytech/substrate" }
xcm-builder = { path = "../xcm-builder" }
xcm = { path = ".." }
Expand All @@ -41,6 +40,8 @@ std = [
"frame-benchmarking/std",
"frame-support/std",
"frame-system/std",
"sp-io/std",
"sp-runtime/std",
"sp-std/std"
"sp-std/std",
"xcm-executor/std"
]
30 changes: 27 additions & 3 deletions xcm/pallet-xcm-benchmarks/src/fungible/benchmarking.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,15 @@ benchmarks_instance_pallet! {
let worst_case_holding = T::worst_case_holding(0);
let asset = T::get_multi_asset();

<AssetTransactorOf<T>>::deposit_asset(&asset, &sender_location).unwrap();
<AssetTransactorOf<T>>::deposit_asset(
&asset,
&sender_location,
XcmContext {
origin: Some(sender_location.clone()),
message_hash: [0; 32],
topic: None,
},
).unwrap();
// check the assets of origin.
assert!(!T::TransactAsset::balance(&sender_account).is_zero());

Expand All @@ -69,7 +77,15 @@ benchmarks_instance_pallet! {
let dest_location = T::valid_destination()?;
let dest_account = T::AccountIdConverter::convert(dest_location.clone()).unwrap();

<AssetTransactorOf<T>>::deposit_asset(&asset, &sender_location).unwrap();
<AssetTransactorOf<T>>::deposit_asset(
&asset,
&sender_location,
XcmContext {
origin: Some(sender_location.clone()),
message_hash: [0; 32],
topic: None,
},
).unwrap();
assert!(T::TransactAsset::balance(&dest_account).is_zero());

let mut executor = new_executor::<T>(sender_location);
Expand All @@ -88,7 +104,15 @@ benchmarks_instance_pallet! {
let dest_account = T::AccountIdConverter::convert(dest_location.clone()).unwrap();

let asset = T::get_multi_asset();
<AssetTransactorOf<T>>::deposit_asset(&asset, &sender_location).unwrap();
<AssetTransactorOf<T>>::deposit_asset(
&asset,
&sender_location,
XcmContext {
origin: Some(sender_location.clone()),
message_hash: [0; 32],
topic: None,
},
).unwrap();
let assets: MultiAssets = vec![ asset ].into();
assert!(T::TransactAsset::balance(&dest_account).is_zero());

Expand Down
35 changes: 34 additions & 1 deletion xcm/pallet-xcm-benchmarks/src/generic/benchmarking.rs
Original file line number Diff line number Diff line change
Expand Up @@ -235,6 +235,11 @@ benchmarks! {
<T::XcmConfig as xcm_executor::Config>::AssetTrap::drop_assets(
&origin,
assets.clone().into(),
XcmContext {
origin: Some(origin.clone()),
message_hash: [0; 32],
topic: None,
},
);

// Assets should be in the trap now.
Expand Down Expand Up @@ -286,7 +291,12 @@ benchmarks! {
<T::XcmConfig as xcm_executor::Config>::SubscriptionService::start(
&origin,
query_id,
max_response_weight
max_response_weight,
XcmContext {
origin: Some(origin.clone()),
message_hash: [0; 32],
topic: None,
},
).map_err(|_| "Could not start subscription")?;
assert!(<T::XcmConfig as xcm_executor::Config>::SubscriptionService::is_subscribed(&origin));

Expand Down Expand Up @@ -442,6 +452,29 @@ benchmarks! {
assert_eq!(executor.transact_status(), &MaybeErrorCode::Success);
}

set_topic {
let mut executor = new_executor::<T>(Default::default());

let instruction = Instruction::SetTopic([1; 32]);
let xcm = Xcm(vec![instruction]);
}: {
executor.execute(xcm)?;
} verify {
assert_eq!(executor.topic(), &Some([1; 32]));
}

clear_topic {
let mut executor = new_executor::<T>(Default::default());
executor.set_topic(Some([2; 32]));

let instruction = Instruction::ClearTopic;
let xcm = Xcm(vec![instruction]);
}: {
executor.execute(xcm)?;
} verify {
assert_eq!(executor.topic(), &None);
}

impl_benchmark_test_suite!(
Pallet,
crate::generic::mock::new_test_ext(),
Expand Down
8 changes: 6 additions & 2 deletions xcm/pallet-xcm-benchmarks/src/generic/mock.rs
Original file line number Diff line number Diff line change
Expand Up @@ -84,11 +84,15 @@ impl frame_system::Config for Test {
/// The benchmarks in this pallet should never need an asset transactor to begin with.
pub struct NoAssetTransactor;
impl xcm_executor::traits::TransactAsset for NoAssetTransactor {
fn deposit_asset(_: &MultiAsset, _: &MultiLocation) -> Result<(), XcmError> {
fn deposit_asset(_: &MultiAsset, _: &MultiLocation, _: XcmContext) -> Result<(), XcmError> {
unreachable!();
}

fn withdraw_asset(_: &MultiAsset, _: &MultiLocation) -> Result<Assets, XcmError> {
fn withdraw_asset(
_: &MultiAsset,
_: &MultiLocation,
_: XcmContext,
) -> Result<Assets, XcmError> {
unreachable!();
}
}
Expand Down
Loading