blob: b1060acd36f34dbffe2e967a73e662d9d3a986bf [file] [log] [blame]
[email protected]691f45a982013-11-19 10:52:041// Copyright (c) 2013 The Chromium Authors. All rights reserved.
[email protected]ec86d5462013-11-17 16:04:492// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4//
5// A send algorithm which adds pacing on top of an another send algorithm.
6// It uses the underlying sender's bandwidth estimate to determine the
7// pacing rate to be used. It also takes into consideration the expected
8// resolution of the underlying alarm mechanism to ensure that alarms are
9// not set too aggressively, and to smooth out variations.
10
11#ifndef NET_QUIC_CONGESTION_CONTROL_PACING_SENDER_H_
12#define NET_QUIC_CONGESTION_CONTROL_PACING_SENDER_H_
13
14#include <map>
15
16#include "base/basictypes.h"
17#include "base/memory/scoped_ptr.h"
18#include "net/quic/congestion_control/send_algorithm_interface.h"
19#include "net/quic/quic_bandwidth.h"
[email protected]ec86d5462013-11-17 16:04:4920#include "net/quic/quic_config.h"
21#include "net/quic/quic_protocol.h"
22#include "net/quic/quic_time.h"
23
24namespace net {
25
26class NET_EXPORT_PRIVATE PacingSender : public SendAlgorithmInterface {
27 public:
28 PacingSender(SendAlgorithmInterface* sender,
29 QuicTime::Delta alarm_granularity);
30 virtual ~PacingSender();
31
32 // SendAlgorithmInterface methods.
33 virtual void SetFromConfig(const QuicConfig& config, bool is_server) OVERRIDE;
[email protected]ec86d5462013-11-17 16:04:4934 virtual void OnIncomingQuicCongestionFeedbackFrame(
35 const QuicCongestionFeedbackFrame& feedback,
[email protected]cb23a922014-02-20 17:42:3836 QuicTime feedback_receive_time) OVERRIDE;
[email protected]77b5d50b2014-05-07 22:48:4837 virtual void OnCongestionEvent(bool rtt_updated,
38 QuicByteCount bytes_in_flight,
39 const CongestionMap& acked_packets,
40 const CongestionMap& lost_packets) OVERRIDE;
[email protected]ec86d5462013-11-17 16:04:4941 virtual bool OnPacketSent(QuicTime sent_time,
[email protected]ef0da582014-05-09 07:16:3042 QuicByteCount bytes_in_flight,
[email protected]ec86d5462013-11-17 16:04:4943 QuicPacketSequenceNumber sequence_number,
44 QuicByteCount bytes,
[email protected]ec86d5462013-11-17 16:04:4945 HasRetransmittableData is_retransmittable) OVERRIDE;
[email protected]7ad98f42014-01-08 07:11:3046 virtual void OnRetransmissionTimeout(bool packets_retransmitted) OVERRIDE;
[email protected]ec86d5462013-11-17 16:04:4947 virtual QuicTime::Delta TimeUntilSend(
48 QuicTime now,
[email protected]77b5d50b2014-05-07 22:48:4849 QuicByteCount bytes_in_flight,
[email protected]9bb57c72014-03-31 20:36:0450 HasRetransmittableData has_retransmittable_data) OVERRIDE;
[email protected]691f45a982013-11-19 10:52:0451 virtual QuicBandwidth BandwidthEstimate() const OVERRIDE;
[email protected]691f45a982013-11-19 10:52:0452 virtual QuicTime::Delta RetransmissionDelay() const OVERRIDE;
[email protected]ec86d5462013-11-17 16:04:4953 virtual QuicByteCount GetCongestionWindow() const OVERRIDE;
[email protected]ec86d5462013-11-17 16:04:4954
55 private:
[email protected]ec86d5462013-11-17 16:04:4956 scoped_ptr<SendAlgorithmInterface> sender_; // Underlying sender.
57 QuicTime::Delta alarm_granularity_;
58 QuicTime next_packet_send_time_; // When can the next packet be sent.
59 bool was_last_send_delayed_; // True when the last send was delayed.
[email protected]77b5d50b2014-05-07 22:48:4860 bool has_valid_rtt_; // True if we have at least one RTT update.
[email protected]ec86d5462013-11-17 16:04:4961
62 DISALLOW_COPY_AND_ASSIGN(PacingSender);
63};
64
65} // namespace net
66
67#endif // NET_QUIC_CONGESTION_CONTROL_PACING_SENDER_H_