Skip to content

Commit

Permalink
Add payload threshold to use uTP, and show work
Browse files Browse the repository at this point in the history
  • Loading branch information
carver authored Sep 19, 2024
1 parent 3508500 commit a76f7b7
Showing 1 changed file with 30 additions and 0 deletions.
30 changes: 30 additions & 0 deletions portal-wire-protocol.md
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,36 @@ The transmission of data that is too large to fit a single packet is done using

> The Portal wire protocol currently implements uTP over the `TALKREQ/TALKRESP` messages. Future plans are to move to the [sub-protocol data transmission](https://github.com/ethereum/devp2p/issues/229) in order to use a protocol native mechanism for establishing packet streams between clients.
Currently, the standard is to switch to uTP when the payload exceeds 1165 bytes. This may change over time, because it depends on a number of other variables. See an example calculation in [rust](https://github.com/ethereum/trin/blob/0ff1b8310f70327da61b3e8ac6e2163977cf2511/ethportal-api/src/types/portal_wire.rs#L34-L71):
```rs
/// The maximum size of a Discv5 talk request payload.
///
/// Discv5 talk request overhead:
/// * masking IV length: 16
/// * static header (protocol ID || version || flag || nonce || authdata-size) length: 23
/// * authdata length: 32
/// * HMAC length: 16
/// * (max) talk request ID length: 8
/// * (max assumed) talk request protocol length: 8
/// * RLP byte array overhead: 6
pub(crate) const MAX_DISCV5_TALK_REQ_PAYLOAD_SIZE: usize =
MAX_DISCV5_PACKET_SIZE - 16 - 23 - 32 - 16 - 8 - 8 - 6;

// NOTE: The wire constant below relies on the following SSZ constants:
// * `ssz::BYTES_PER_UNION_SELECTOR`: 1
// * `ssz::BYTES_PER_LENGTH_OFFSET`: 4

/// The maximum size of a portal CONTENT payload. At the time of writing, this payload either
/// corresponds to a `connection_id`, `enrs`, or `content` payload.
///
/// Portal wire overhead:
/// * portal message SSZ union selector
/// * CONTENT SSZ union selector
/// * CONTENT SSZ length offset for List `enrs` or `content`
pub const MAX_PORTAL_CONTENT_PAYLOAD_SIZE: usize = MAX_DISCV5_TALK_REQ_PAYLOAD_SIZE
- (ssz::BYTES_PER_UNION_SELECTOR * 2)
- ssz::BYTES_PER_LENGTH_OFFSET;
```

## Request - Response Messages

Expand Down

0 comments on commit a76f7b7

Please sign in to comment.