blob: 14f2c2c52ad95878aebfe1609113c1d4a2ad5151 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_QUIC_QUIC_CONNECTION_STATS_H_
#define NET_QUIC_QUIC_CONNECTION_STATS_H_
#include <ostream>
#include "base/basictypes.h"
#include "net/base/net_export.h"
#include "net/quic/quic_bandwidth.h"
#include "net/quic/quic_protocol.h"
#include "net/quic/quic_time.h"
namespace net {
// Structure to hold stats for a QuicConnection.
struct NET_EXPORT_PRIVATE QuicConnectionStats {
QuicConnectionStats();
~QuicConnectionStats();
NET_EXPORT_PRIVATE friend std::ostream& operator<<(
std::ostream& os, const QuicConnectionStats& s);
QuicByteCount bytes_sent; // Includes retransmissions, fec.
QuicPacketCount packets_sent;
// Non-retransmitted bytes sent in a stream frame.
QuicByteCount stream_bytes_sent;
// Packets serialized and discarded before sending.
QuicPacketCount packets_discarded;
// These include version negotiation and public reset packets, which do not
// have packet numbers or frame data.
QuicByteCount bytes_received; // Includes duplicate data for a stream, fec.
// Includes packets which were not processable.
QuicPacketCount packets_received;
// Excludes packets which were not processable.
QuicPacketCount packets_processed;
QuicByteCount stream_bytes_received; // Bytes received in a stream frame.
QuicByteCount bytes_retransmitted;
QuicPacketCount packets_retransmitted;
QuicByteCount bytes_spuriously_retransmitted;
QuicPacketCount packets_spuriously_retransmitted;
// Number of packets abandoned as lost by the loss detection algorithm.
QuicPacketCount packets_lost;
// Number of packets sent in slow start.
QuicPacketCount slowstart_packets_sent;
// Number of packets lost exiting slow start.
QuicPacketCount slowstart_packets_lost;
QuicPacketCount packets_revived;
QuicPacketCount packets_dropped; // Duplicate or less than least unacked.
size_t crypto_retransmit_count;
// Count of times the loss detection alarm fired. At least one packet should
// be lost when the alarm fires.
size_t loss_timeout_count;
size_t tlp_count;
size_t rto_count; // Count of times the rto timer fired.
int64 min_rtt_us; // Minimum RTT in microseconds.
int64 srtt_us; // Smoothed RTT in microseconds.
QuicByteCount max_packet_size;
QuicByteCount max_received_packet_size;
QuicBandwidth estimated_bandwidth;
// Reordering stats for received packets.
// Number of packets received out of packet number order.
QuicPacketCount packets_reordered;
// Maximum reordering observed in packet number space.
QuicPacketNumber max_sequence_reordering;
// Maximum reordering observed in microseconds
int64 max_time_reordering_us;
// The following stats are used only in TcpCubicSender.
// The number of loss events from TCP's perspective. Each loss event includes
// one or more lost packets.
uint32 tcp_loss_events;
// Creation time, as reported by the QuicClock.
QuicTime connection_creation_time;
};
} // namespace net
#endif // NET_QUIC_QUIC_CONNECTION_STATS_H_
|