Index: net/quic/quic_stream_factory.cc |
diff --git a/net/quic/quic_stream_factory.cc b/net/quic/quic_stream_factory.cc |
index 40f294821850e0a6fbffa5c9dc5a1d0fbb58d13c..839b01be82edd0e16cc2ccf696f7668effe61b8c 100644 |
--- a/net/quic/quic_stream_factory.cc |
+++ b/net/quic/quic_stream_factory.cc |
@@ -9,6 +9,7 @@ |
#include "base/logging.h" |
#include "base/message_loop/message_loop.h" |
#include "base/message_loop/message_loop_proxy.h" |
+#include "base/metrics/histogram.h" |
#include "base/rand_util.h" |
#include "base/stl_util.h" |
#include "base/strings/string_util.h" |
@@ -21,6 +22,7 @@ |
#include "net/quic/congestion_control/tcp_receiver.h" |
#include "net/quic/crypto/proof_verifier_chromium.h" |
#include "net/quic/crypto/quic_random.h" |
+#include "net/quic/port_suggester.h" |
#include "net/quic/quic_client_session.h" |
#include "net/quic/quic_clock.h" |
#include "net/quic/quic_connection.h" |
@@ -256,7 +258,8 @@ QuicStreamFactory::QuicStreamFactory( |
random_generator_(random_generator), |
clock_(clock), |
max_packet_length_(max_packet_length), |
- weak_factory_(this) { |
+ weak_factory_(this), |
+ port_entropy_(random_generator_->RandUint64()) { |
config_.SetDefaults(); |
config_.set_idle_connection_state_lifetime( |
QuicTime::Delta::FromSeconds(30), |
@@ -447,12 +450,21 @@ QuicClientSession* QuicStreamFactory::CreateSession( |
const BoundNetLog& net_log) { |
QuicGuid guid = random_generator_->RandUint64(); |
IPEndPoint addr = *address_list.begin(); |
+ scoped_refptr<PortSuggester> port_suggester = |
+ new PortSuggester(host_port_proxy_pair.first, port_entropy_); |
scoped_ptr<DatagramClientSocket> socket( |
client_socket_factory_->CreateDatagramClientSocket( |
- DatagramSocket::DEFAULT_BIND, base::Bind(&base::RandInt), |
+ DatagramSocket::RANDOM_BIND, |
+ base::Bind(&PortSuggester::SuggestPort, port_suggester), |
net_log.net_log(), net_log.source())); |
socket->Connect(addr); |
+ IPEndPoint address; |
+ DCHECK(ERR_SOCKET_NOT_CONNECTED != socket->GetLocalAddress(&address) || |
+ address.port() == port_suggester->previous_suggestion()); |
Ryan Hamilton
2013/12/07 23:21:55
I don't think that this DCHECK is guaranteed to su
jar (doing other things)
2013/12/08 01:38:36
I thought the chance of exhausting the 10 attempts
Ryan Hamilton
2013/12/08 04:00:29
Hm. I'm totally down with a DCHECK to make sure t
jar (doing other things)
2013/12/08 04:57:43
Please take a look at the DCHECK that was in the m
Ryan Hamilton
2013/12/08 05:24:08
I totally believe the DCHECK is passing on the bot
Ryan Hamilton
2013/12/08 06:06:23
Something that might make the DCHECK a bit more cl
|
+ UMA_HISTOGRAM_COUNTS("Net.QuicEphemeralPortsSuggested", |
+ port_suggester->call_count()); |
+ |
// We should adaptively set this buffer size, but for now, we'll use a size |
// that is more than large enough for a full receive window, and yet |
// does not consume "too much" memory. If we see bursty packet loss, we may |