| Index: net/quic/crypto/aead_base_encrypter_nss.cc
|
| diff --git a/net/quic/crypto/aead_base_encrypter_nss.cc b/net/quic/crypto/aead_base_encrypter_nss.cc
|
| index 80731ed5b8ac07e3a9e1bb8fab962730857f44e9..c7841e1dacc8e0e89be0a78d993418983c8f502c 100644
|
| --- a/net/quic/crypto/aead_base_encrypter_nss.cc
|
| +++ b/net/quic/crypto/aead_base_encrypter_nss.cc
|
| @@ -9,6 +9,7 @@
|
| #include "base/memory/scoped_ptr.h"
|
| #include "crypto/scoped_nss_types.h"
|
| #include "net/quic/quic_flags.h"
|
| +#include "net/quic/quic_utils.h"
|
|
|
| using base::StringPiece;
|
|
|
| @@ -135,15 +136,8 @@ bool AeadBaseEncrypter::EncryptPacket(QuicPathId path_id,
|
| ALIGNAS(4) char nonce_buffer[kMaxNonceSize];
|
| memcpy(nonce_buffer, nonce_prefix_, nonce_prefix_size_);
|
| if (FLAGS_quic_include_path_id_in_iv) {
|
| - // Setting the nonce below relies on QuicPathId and QuicPacketNumber being
|
| - // specific sizes.
|
| - static_assert(sizeof(path_id) == 1, "Size of QuicPathId changed.");
|
| - static_assert(sizeof(packet_number) == 8,
|
| - "Size of QuicPacketNumber changed.");
|
| - // Use path_id and lower 7 bytes of packet_number as lower 8 bytes of nonce.
|
| uint64_t path_id_packet_number =
|
| - (static_cast<uint64_t>(path_id) << 56) | packet_number;
|
| - DCHECK(path_id != kDefaultPathId || path_id_packet_number == packet_number);
|
| + QuicUtils::PackPathIdAndPacketNumber(path_id, packet_number);
|
| memcpy(nonce_buffer + nonce_prefix_size_, &path_id_packet_number,
|
| sizeof(path_id_packet_number));
|
| } else {
|
|
|