#messages #threshold #channel #queue #pallet #factor #fee

no-std cumulus-pallet-xcmp-queue

Pallet to queue outbound and inbound XCMP messages

18 breaking releases

new 0.19.0 Jan 21, 2025
0.17.0 Sep 26, 2024
0.16.0 Jul 18, 2024
0.10.0 Mar 18, 2024
0.0.0 Nov 21, 2022

#987 in Magic Beans

Download history 1215/week @ 2024-10-01 1339/week @ 2024-10-08 1739/week @ 2024-10-15 1808/week @ 2024-10-22 1693/week @ 2024-10-29 2011/week @ 2024-11-05 25595/week @ 2024-11-12 26869/week @ 2024-11-19 26625/week @ 2024-11-26 26026/week @ 2024-12-03 25691/week @ 2024-12-10 21952/week @ 2024-12-17 7267/week @ 2024-12-24 14094/week @ 2024-12-31 23365/week @ 2025-01-07 30097/week @ 2025-01-14

76,895 downloads per month
Used in 38 crates (25 directly)

Apache-2.0 and GPL-3.0-only

125KB
2.5K SLoC

Release

Polkadot SDK Stable 2412


lib.rs:

A pallet which uses the XCMP transport layer to handle both incoming and outgoing XCM message sending and dispatch, queuing, signalling and backpressure. To do so, it implements:

  • XcmpMessageHandler
  • XcmpMessageSource

Also provides an implementation of SendXcm which can be placed in a router tuple for relaying XCM over XCMP if the destination is Parent/Parachain. It requires an implementation of XcmExecutor for dispatching incoming XCM messages.

To prevent out of memory errors on the OutboundXcmpMessages queue, an exponential fee factor (DeliveryFeeFactor) is set, much like the one used in DMP. The fee factor increases whenever the total size of messages in a particular channel passes a threshold. This threshold is defined as a percentage of the maximum total size the channel can have. More concretely, the threshold is max_total_size / THRESHOLD_FACTOR, where:

  • max_total_size is the maximum size, in bytes, of the channel, not number of messages. It is defined in the channel configuration.
  • THRESHOLD_FACTOR just declares which percentage of the max size is the actual threshold. If it's 2, then the threshold is half of the max size, if it's 4, it's a quarter, and so on.

Dependencies

~29–44MB
~750K SLoC