| Index: net/quic/crypto/aead_base_encrypter_openssl.cc
|
| diff --git a/net/quic/crypto/aead_base_encrypter_openssl.cc b/net/quic/crypto/aead_base_encrypter_openssl.cc
|
| index ed475d8d7822664a66044ea25ac265265b018c13..699c60ad934b0d787c0bdc2465ffa3d5bc80e00f 100644
|
| --- a/net/quic/crypto/aead_base_encrypter_openssl.cc
|
| +++ b/net/quic/crypto/aead_base_encrypter_openssl.cc
|
| @@ -10,6 +10,7 @@
|
|
|
| #include "base/memory/scoped_ptr.h"
|
| #include "net/quic/quic_flags.h"
|
| +#include "net/quic/quic_utils.h"
|
|
|
| using base::StringPiece;
|
|
|
| @@ -120,15 +121,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 {
|
|
|