Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(64)

Side by Side Diff: net/quic/port_suggester.h

Issue 107803002: Consistently suggest ephemeral port for QUIC client (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Move a paren... save a 64 bit add Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef NET_QUIC_PORT_SUGGESTER_H_
6 #define NET_QUIC_PORT_SUGGESTER_H_
7
8 #include "base/basictypes.h"
9 #include "base/memory/ref_counted.h"
10 #include "base/sha1.h"
11 #include "net/base/net_export.h"
12
13 namespace net {
14
15 class HostPortPair;
16
17 // We provide a pseudo-random number generator that is always seeded the same
18 // way for a given destination host-port pair. The generator is used to
19 // consistently suggest (for that host-port pair) an ephemeral source port,
20 // and hence increase the likelihood that a server's load balancer will direct
21 // a repeated connection to the same server (with QUIC, further increasing the
22 // chance of connection establishment with 0-RTT).
23 class NET_EXPORT PortSuggester
Ryan Hamilton 2013/12/07 23:21:55 Should this be NET_EXPORT or NET_EXPORT_PRIVATE?
jar (doing other things) 2013/12/08 01:38:36 Done.
24 : public base::RefCounted<PortSuggester> {
Ryan Hamilton 2013/12/07 23:21:55 nit: I think this can all fit on a single line. (
jar (doing other things) 2013/12/08 01:38:36 Made private... doesn't fit.
25 public:
26 // |per_profile_randomness| is used to seed the generator.
27 PortSuggester(const HostPortPair& server, uint64 per_profile_randomness);
28
29 // Generate a pseudo-random int in the inclusive range from |min| to |max|.
30 // Will (probably) return different numbers when called repeatedly.
31 int SuggestPort(int min, int max);
32
33 uint32 call_count() const { return call_count_; }
34 int previous_suggestion() const { return previous_suggestion_; }
Ryan Hamilton 2013/12/07 23:21:55 if you decide to keep this method, should it DCHEC
jar (doing other things) 2013/12/08 01:38:36 I can add that. I gave it a init value of -1, so
35
36 private:
37 friend class base::RefCounted<PortSuggester>;
38
39 virtual ~PortSuggester() {}
40
41 // We maintain the first 8 bytes of a hash as our seed_ state.
42 uint64 seed_;
Ryan Hamilton 2013/12/07 23:21:55 nit: extra space before seed_;
jar (doing other things) 2013/12/08 01:38:36 Done.
43 uint32 call_count_; // Number of suggestions made.
44 int previous_suggestion_;
45
46 DISALLOW_COPY_AND_ASSIGN(PortSuggester);
47 };
48
49 } // namespace net
50
51 #endif // NET_QUIC_PORT_SUGGESTER_H_
OLDNEW
« no previous file with comments | « net/net.gyp ('k') | net/quic/port_suggester.cc » ('j') | net/quic/port_suggester.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698