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 { |