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

Side by Side Diff: net/quic/chromium/quic_chromium_client_session.h

Issue 2319343004: Makes migration on write error asynchronous to avoid reentrancy issues (Closed)
Patch Set: Cleaning up. Created 4 years, 3 months 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
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 // 4 //
5 // A client specific QuicSession subclass. This class owns the underlying 5 // A client specific QuicSession subclass. This class owns the underlying
6 // QuicConnection and QuicConnectionHelper objects. The connection stores 6 // QuicConnection and QuicConnectionHelper objects. The connection stores
7 // a non-owning pointer to the helper so this session needs to ensure that 7 // a non-owning pointer to the helper so this session needs to ensure that
8 // the helper outlives the connection. 8 // the helper outlives the connection.
9 9
10 #ifndef NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_ 10 #ifndef NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_
(...skipping 235 matching lines...) Expand 10 before | Expand all | Expand 10 after
246 246
247 // Returns true if |hostname| may be pooled onto this session. If this 247 // Returns true if |hostname| may be pooled onto this session. If this
248 // is a secure QUIC session, then |hostname| must match the certificate 248 // is a secure QUIC session, then |hostname| must match the certificate
249 // presented during the handshake. 249 // presented during the handshake.
250 bool CanPool(const std::string& hostname, PrivacyMode privacy_mode) const; 250 bool CanPool(const std::string& hostname, PrivacyMode privacy_mode) const;
251 251
252 const QuicServerId& server_id() const { return server_id_; } 252 const QuicServerId& server_id() const { return server_id_; }
253 253
254 QuicDisabledReason disabled_reason() const { return disabled_reason_; } 254 QuicDisabledReason disabled_reason() const { return disabled_reason_; }
255 255
256 // Attempts to migrate session when a write error is encountered.
257 void MigrateSessionOnWriteError();
258
259 // Helper method that writes a packet on the new socket after
260 // migration completes. If not null, |packet| is written, else
261 // a PING packet is written.
262 void WriteToNewSocket(scoped_refptr<StringIOBuffer> packet);
263
256 // Migrates session onto new socket, i.e., starts reading from 264 // Migrates session onto new socket, i.e., starts reading from
257 // |socket| in addition to any previous sockets, and sets |writer| 265 // |socket| in addition to any previous sockets, and sets |writer|
258 // to be the new default writer. Returns true if socket was 266 // to be the new default writer. Returns true if socket was
259 // successfully added to the session and the session was 267 // successfully added to the session and the session was
260 // successfully migrated to using the new socket. If not null, 268 // successfully migrated to using the new socket. Returns true on
261 // |packet| is sent on the new network, else a PING frame is 269 // successful migration, or false if number of migrations exceeds
262 // sent. Returns true on successful migration, or false if number of 270 // kMaxReadersPerQuicSession. Takes ownership of |socket|, |reader|,
263 // migrations exceeds kMaxReadersPerQuicSession. Takes ownership of 271 // and |writer|.
264 // |socket|, |reader|, and |writer|.
265 bool MigrateToSocket(std::unique_ptr<DatagramClientSocket> socket, 272 bool MigrateToSocket(std::unique_ptr<DatagramClientSocket> socket,
266 std::unique_ptr<QuicChromiumPacketReader> reader, 273 std::unique_ptr<QuicChromiumPacketReader> reader,
267 std::unique_ptr<QuicChromiumPacketWriter> writer, 274 std::unique_ptr<QuicChromiumPacketWriter> writer);
268 scoped_refptr<StringIOBuffer> packet);
269 275
270 // Populates network error details for this session. 276 // Populates network error details for this session.
271 void PopulateNetErrorDetails(NetErrorDetails* details); 277 void PopulateNetErrorDetails(NetErrorDetails* details);
272 278
273 // Returns current default socket. This is the socket over which all 279 // Returns current default socket. This is the socket over which all
274 // QUIC packets are sent. This default socket can change, so do not store the 280 // QUIC packets are sent. This default socket can change, so do not store the
275 // returned socket. 281 // returned socket.
276 const DatagramClientSocket* GetDefaultSocket() const; 282 const DatagramClientSocket* GetDefaultSocket() const;
277 283
278 bool IsAuthorized(const std::string& hostname) override; 284 bool IsAuthorized(const std::string& hostname) override;
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after
358 // True when the session is going away, and streams may no longer be created 364 // True when the session is going away, and streams may no longer be created
359 // on this session. Existing stream will continue to be processed. 365 // on this session. Existing stream will continue to be processed.
360 bool going_away_; 366 bool going_away_;
361 // True when the session receives a go away from server due to port migration. 367 // True when the session receives a go away from server due to port migration.
362 bool port_migration_detected_; 368 bool port_migration_detected_;
363 QuicDisabledReason disabled_reason_; 369 QuicDisabledReason disabled_reason_;
364 TokenBindingSignatureMap token_binding_signatures_; 370 TokenBindingSignatureMap token_binding_signatures_;
365 // UMA histogram counters for streams pushed to this session. 371 // UMA histogram counters for streams pushed to this session.
366 int streams_pushed_count_; 372 int streams_pushed_count_;
367 int streams_pushed_and_claimed_count_; 373 int streams_pushed_and_claimed_count_;
368 // Return value from packet rewrite packet on new socket. Used 374 // Stores packet for rewrite after migration due to socket write error.
369 // during connection migration on socket write error. 375 scoped_refptr<StringIOBuffer> packet_;
370 int error_code_from_rewrite_;
371 bool use_error_code_from_rewrite_;
372 base::WeakPtrFactory<QuicChromiumClientSession> weak_factory_; 376 base::WeakPtrFactory<QuicChromiumClientSession> weak_factory_;
373 377
374 DISALLOW_COPY_AND_ASSIGN(QuicChromiumClientSession); 378 DISALLOW_COPY_AND_ASSIGN(QuicChromiumClientSession);
375 }; 379 };
376 380
377 } // namespace net 381 } // namespace net
378 382
379 #endif // NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_ 383 #endif // NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698