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

Unified Diff: net/quic/quic_stream_sequencer.cc

Issue 1764913002: Deprecate --gfe2_reloadable_flag_quic_use_stream_sequencer_buffer. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@115690862
Patch Set: update dependency Created 4 years, 10 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/quic/quic_stream_sequencer.h ('k') | net/quic/quic_stream_sequencer_test.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/quic/quic_stream_sequencer.cc
diff --git a/net/quic/quic_stream_sequencer.cc b/net/quic/quic_stream_sequencer.cc
index 18f40a39565a25756a5283b810d16872fdf9f94b..113f4ff64e0c2b23bdf9c832bd8f32b48122186b 100644
--- a/net/quic/quic_stream_sequencer.cc
+++ b/net/quic/quic_stream_sequencer.cc
@@ -12,7 +12,6 @@
#include "net/quic/quic_bug_tracker.h"
#include "net/quic/quic_clock.h"
#include "net/quic/quic_flags.h"
-#include "net/quic/quic_frame_list.h"
#include "net/quic/quic_protocol.h"
#include "net/quic/reliable_quic_stream.h"
#include "net/quic/stream_sequencer_buffer.h"
@@ -26,20 +25,14 @@ namespace net {
QuicStreamSequencer::QuicStreamSequencer(ReliableQuicStream* quic_stream,
const QuicClock* clock)
: stream_(quic_stream),
+ buffered_frames_(kStreamReceiveWindowLimit),
close_offset_(numeric_limits<QuicStreamOffset>::max()),
blocked_(false),
num_frames_received_(0),
num_duplicate_frames_received_(0),
num_early_frames_received_(0),
clock_(clock),
- ignore_read_data_(false) {
- if (FLAGS_quic_use_stream_sequencer_buffer) {
- buffered_frames_.reset(
- new StreamSequencerBuffer(kStreamReceiveWindowLimit));
- } else {
- buffered_frames_.reset(new QuicFrameList());
- }
-}
+ ignore_read_data_(false) {}
QuicStreamSequencer::~QuicStreamSequencer() {}
@@ -63,7 +56,7 @@ void QuicStreamSequencer::OnStreamFrame(const QuicStreamFrame& frame) {
}
}
size_t bytes_written;
- QuicErrorCode result = buffered_frames_->OnStreamData(
+ QuicErrorCode result = buffered_frames_.OnStreamData(
byte_offset, StringPiece(frame.frame_buffer, frame.frame_length),
clock_->ApproximateNow(), &bytes_written);
@@ -80,7 +73,7 @@ void QuicStreamSequencer::OnStreamFrame(const QuicStreamFrame& frame) {
return;
}
- if (byte_offset > buffered_frames_->BytesConsumed()) {
+ if (byte_offset > buffered_frames_.BytesConsumed()) {
++num_early_frames_received_;
}
@@ -88,7 +81,7 @@ void QuicStreamSequencer::OnStreamFrame(const QuicStreamFrame& frame) {
return;
}
- if (byte_offset == buffered_frames_->BytesConsumed()) {
+ if (byte_offset == buffered_frames_.BytesConsumed()) {
if (ignore_read_data_) {
FlushBufferedFrames();
} else {
@@ -117,7 +110,7 @@ bool QuicStreamSequencer::MaybeCloseStream() {
}
DVLOG(1) << "Passing up termination, as we've processed "
- << buffered_frames_->BytesConsumed() << " of " << close_offset_
+ << buffered_frames_.BytesConsumed() << " of " << close_offset_
<< " bytes.";
// This will cause the stream to consume the FIN.
// Technically it's an error if |num_bytes_consumed| isn't exactly
@@ -129,39 +122,39 @@ bool QuicStreamSequencer::MaybeCloseStream() {
} else {
stream_->OnDataAvailable();
}
- buffered_frames_->Clear();
+ buffered_frames_.Clear();
return true;
}
int QuicStreamSequencer::GetReadableRegions(iovec* iov, size_t iov_len) const {
DCHECK(!blocked_);
- return buffered_frames_->GetReadableRegions(iov, iov_len);
+ return buffered_frames_.GetReadableRegions(iov, iov_len);
}
bool QuicStreamSequencer::GetReadableRegion(iovec* iov,
QuicTime* timestamp) const {
DCHECK(!blocked_);
- return buffered_frames_->GetReadableRegion(iov, timestamp);
+ return buffered_frames_.GetReadableRegion(iov, timestamp);
}
int QuicStreamSequencer::Readv(const struct iovec* iov, size_t iov_len) {
DCHECK(!blocked_);
- size_t bytes_read = buffered_frames_->Readv(iov, iov_len);
+ size_t bytes_read = buffered_frames_.Readv(iov, iov_len);
stream_->AddBytesConsumed(bytes_read);
return static_cast<int>(bytes_read);
}
bool QuicStreamSequencer::HasBytesToRead() const {
- return buffered_frames_->HasBytesToRead();
+ return buffered_frames_.HasBytesToRead();
}
bool QuicStreamSequencer::IsClosed() const {
- return buffered_frames_->BytesConsumed() >= close_offset_;
+ return buffered_frames_.BytesConsumed() >= close_offset_;
}
void QuicStreamSequencer::MarkConsumed(size_t num_bytes_consumed) {
DCHECK(!blocked_);
- bool result = buffered_frames_->MarkConsumed(num_bytes_consumed);
+ bool result = buffered_frames_.MarkConsumed(num_bytes_consumed);
if (!result) {
QUIC_BUG << "Invalid argument to MarkConsumed."
<< " expect to consume: " << num_bytes_consumed
@@ -193,20 +186,20 @@ void QuicStreamSequencer::StopReading() {
void QuicStreamSequencer::FlushBufferedFrames() {
DCHECK(ignore_read_data_);
- size_t bytes_flushed = buffered_frames_->FlushBufferedFrames();
+ size_t bytes_flushed = buffered_frames_.FlushBufferedFrames();
DVLOG(1) << "Flushing buffered data at offset "
- << buffered_frames_->BytesConsumed() << " length " << bytes_flushed
+ << buffered_frames_.BytesConsumed() << " length " << bytes_flushed
<< " for stream " << stream_->id();
stream_->AddBytesConsumed(bytes_flushed);
MaybeCloseStream();
}
size_t QuicStreamSequencer::NumBytesBuffered() const {
- return buffered_frames_->BytesBuffered();
+ return buffered_frames_.BytesBuffered();
}
QuicStreamOffset QuicStreamSequencer::NumBytesConsumed() const {
- return buffered_frames_->BytesConsumed();
+ return buffered_frames_.BytesConsumed();
}
} // namespace net
« no previous file with comments | « net/quic/quic_stream_sequencer.h ('k') | net/quic/quic_stream_sequencer_test.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698