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

Make the packet number encryption sampling clearer #1389

Merged
merged 5 commits into from
May 29, 2018
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
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
20 changes: 16 additions & 4 deletions draft-ietf-quic-tls.md
Original file line number Diff line number Diff line change
Expand Up @@ -942,16 +942,28 @@ Packet number protection is applied after packet protection is applied (see
encryption algorithm.

In sampling the packet ciphertext, the packet number length is assumed to be the
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't "packet number length" be "sample_offset"?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, but I see how this text is confusing, I'll rephrase and we can try again.

smaller of the maximum possible packet number encoding (4 octets), or the size
of the protected packet minus the minimum expansion for the AEAD. For example,
the sampled ciphertext for a packet with a short header can be determined by:
smaller of the maximum possible packet number encoding (4 octets), or the
remaining space in the packet when the minimum expansion for the AEAD is
subtracted. For example, the sampled ciphertext for a packet with a short
header can be determined by:

~~~
sample_offset = min(1 + connection_id_length + 4,
sample_offset = min(1 + len(connection_id) + 4,
packet_length - aead_expansion)
sample = packet[sample_offset..sample_offset+sample_length]
~~~

A packet with a long header is sampled in the same way, noting that multiple
QUIC packets might be included in the same UDP datagram and that each one is
handled separately.

~~~
sample_offset = min(2 + len(destination_connection_id) +
Copy link
Member

@kazuho kazuho May 25, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't 2 be 6? There are the type octet, version (4 octets), CILs (1 octet).

len(source_connection_id) +
len(payload_length) + 4,
packet_length - aead_expansion)
Copy link
Member

@nibanks nibanks May 25, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I assume packet_length refers to the QUIC packet length and not the UDP payload length, right?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ahh, I see the problem. You don't know where the payload length starts. It seems like we need to make the payload length cover the packet number length. More changes inbound.

~~~

To ensure that this process does not sample the packet number, packet number
protection algorithms MUST NOT sample more ciphertext than the minimum
expansion of the corresponding AEAD.
Expand Down
21 changes: 12 additions & 9 deletions draft-ietf-quic-transport.md
Original file line number Diff line number Diff line change
Expand Up @@ -280,7 +280,7 @@ keys are established.
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Source Connection ID (0/32..144) ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Payload Length (i) ...
| Length (i) ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Packet Number (8/16/32) |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Expand Down Expand Up @@ -337,10 +337,11 @@ Source Connection ID:
either 0 octets in length or between 4 and 18 octets. {{connection-id}}
describes the use of this field in more detail.

Payload Length:
Length:

: The length of the Payload field in octets, encoded as a variable-length
integer ({{integer-encoding}}).
: The length of the remainder of the packet (that is, the Packet Number and
Payload fields) in octets, encoded as a variable-length integer
({{integer-encoding}}).

Packet Number:

Expand Down Expand Up @@ -373,10 +374,13 @@ The interpretation of the fields and the payload are specific to a version and
packet type. Type-specific semantics for this version are described in the
following sections.

The end of the Payload field (which is also the end of the long header
packet) is determined by the value of the Payload Length field.
Senders can sometimes coalesce multiple packets into one UDP datagram.
See {{packet-coalesce}} for more details.
The end of the packet is determined by the Length field. The Length field
covers the both the Packet Number and Payload fields, both of which are
confidentiality protected and initially of unknown length. The size of the
Payload field is learned once the packet number protection is removed.

Senders can sometimes coalesce multiple packets into one UDP datagram. See
{{packet-coalesce}} for more details.


## Short Header
Expand Down Expand Up @@ -4568,4 +4572,3 @@ Hamilton, Jana Iyengar, Fedor Kouranov, Charles Krasic, Jo Kulik, Adam Langley,
Jim Roskind, Robbie Shade, Satyam Shekhar, Cherie Shi, Ian Swett, Raman Tenneti,
Victor Vasiliev, Antonio Vicente, Patrik Westin, Alyssa Wilk, Dale Worley, Fan
Yang, Dan Zhang, Daniel Ziegler.