2016-08-30 14:04:35 -07:00
|
|
|
/*
|
|
|
|
|
* Copyright 2016 The WebRTC Project Authors. All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
|
*/
|
|
|
|
|
|
2017-09-15 06:47:31 +02:00
|
|
|
#include "api/stats/rtcstats_objects.h"
|
2016-08-30 14:04:35 -07:00
|
|
|
|
2018-11-28 16:47:49 +01:00
|
|
|
#include <utility>
|
|
|
|
|
|
2019-03-19 15:38:49 +01:00
|
|
|
#include "api/stats/rtc_stats.h"
|
2018-11-28 16:47:49 +01:00
|
|
|
#include "rtc_base/checks.h"
|
2019-03-19 15:38:49 +01:00
|
|
|
|
2016-08-30 14:04:35 -07:00
|
|
|
namespace webrtc {
|
|
|
|
|
|
2017-08-08 10:48:15 -07:00
|
|
|
const char* const RTCDataChannelState::kConnecting = "connecting";
|
|
|
|
|
const char* const RTCDataChannelState::kOpen = "open";
|
|
|
|
|
const char* const RTCDataChannelState::kClosing = "closing";
|
|
|
|
|
const char* const RTCDataChannelState::kClosed = "closed";
|
2016-10-18 12:48:31 -07:00
|
|
|
|
2017-08-08 10:48:15 -07:00
|
|
|
const char* const RTCStatsIceCandidatePairState::kFrozen = "frozen";
|
|
|
|
|
const char* const RTCStatsIceCandidatePairState::kWaiting = "waiting";
|
|
|
|
|
const char* const RTCStatsIceCandidatePairState::kInProgress = "in-progress";
|
|
|
|
|
const char* const RTCStatsIceCandidatePairState::kFailed = "failed";
|
|
|
|
|
const char* const RTCStatsIceCandidatePairState::kSucceeded = "succeeded";
|
2016-10-11 14:54:49 -07:00
|
|
|
|
|
|
|
|
// Strings defined in https://tools.ietf.org/html/rfc5245.
|
2017-08-08 10:48:15 -07:00
|
|
|
const char* const RTCIceCandidateType::kHost = "host";
|
|
|
|
|
const char* const RTCIceCandidateType::kSrflx = "srflx";
|
|
|
|
|
const char* const RTCIceCandidateType::kPrflx = "prflx";
|
|
|
|
|
const char* const RTCIceCandidateType::kRelay = "relay";
|
|
|
|
|
|
|
|
|
|
const char* const RTCDtlsTransportState::kNew = "new";
|
|
|
|
|
const char* const RTCDtlsTransportState::kConnecting = "connecting";
|
|
|
|
|
const char* const RTCDtlsTransportState::kConnected = "connected";
|
|
|
|
|
const char* const RTCDtlsTransportState::kClosed = "closed";
|
|
|
|
|
const char* const RTCDtlsTransportState::kFailed = "failed";
|
|
|
|
|
|
|
|
|
|
const char* const RTCMediaStreamTrackKind::kAudio = "audio";
|
|
|
|
|
const char* const RTCMediaStreamTrackKind::kVideo = "video";
|
2017-01-17 02:53:23 -08:00
|
|
|
|
2017-11-21 10:49:36 -08:00
|
|
|
// https://w3c.github.io/webrtc-stats/#dom-rtcnetworktype
|
|
|
|
|
const char* const RTCNetworkType::kBluetooth = "bluetooth";
|
|
|
|
|
const char* const RTCNetworkType::kCellular = "cellular";
|
|
|
|
|
const char* const RTCNetworkType::kEthernet = "ethernet";
|
|
|
|
|
const char* const RTCNetworkType::kWifi = "wifi";
|
|
|
|
|
const char* const RTCNetworkType::kWimax = "wimax";
|
|
|
|
|
const char* const RTCNetworkType::kVpn = "vpn";
|
|
|
|
|
const char* const RTCNetworkType::kUnknown = "unknown";
|
|
|
|
|
|
2019-05-28 17:42:38 +02:00
|
|
|
// https://w3c.github.io/webrtc-stats/#dom-rtcqualitylimitationreason
|
|
|
|
|
const char* const RTCQualityLimitationReason::kNone = "none";
|
|
|
|
|
const char* const RTCQualityLimitationReason::kCpu = "cpu";
|
|
|
|
|
const char* const RTCQualityLimitationReason::kBandwidth = "bandwidth";
|
|
|
|
|
const char* const RTCQualityLimitationReason::kOther = "other";
|
|
|
|
|
|
2019-04-09 13:59:31 +02:00
|
|
|
// https://webrtc.org/experiments/rtp-hdrext/video-content-type/
|
|
|
|
|
const char* const RTCContentType::kUnspecified = "unspecified";
|
|
|
|
|
const char* const RTCContentType::kScreenshare = "screenshare";
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-10-24 04:00:05 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCCertificateStats, RTCStats, "certificate",
|
|
|
|
|
&fingerprint,
|
|
|
|
|
&fingerprint_algorithm,
|
|
|
|
|
&base64_certificate,
|
2019-02-20 10:13:16 -05:00
|
|
|
&issuer_certificate_id)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-10-24 04:00:05 -07:00
|
|
|
|
|
|
|
|
RTCCertificateStats::RTCCertificateStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCCertificateStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCCertificateStats::RTCCertificateStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
fingerprint("fingerprint"),
|
|
|
|
|
fingerprint_algorithm("fingerprintAlgorithm"),
|
|
|
|
|
base64_certificate("base64Certificate"),
|
|
|
|
|
issuer_certificate_id("issuerCertificateId") {}
|
|
|
|
|
|
|
|
|
|
RTCCertificateStats::RTCCertificateStats(const RTCCertificateStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
fingerprint(other.fingerprint),
|
|
|
|
|
fingerprint_algorithm(other.fingerprint_algorithm),
|
|
|
|
|
base64_certificate(other.base64_certificate),
|
|
|
|
|
issuer_certificate_id(other.issuer_certificate_id) {}
|
|
|
|
|
|
|
|
|
|
RTCCertificateStats::~RTCCertificateStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-11-23 02:32:06 -08:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCCodecStats, RTCStats, "codec",
|
|
|
|
|
&payload_type,
|
2017-02-28 06:56:04 -08:00
|
|
|
&mime_type,
|
2016-11-23 02:32:06 -08:00
|
|
|
&clock_rate,
|
|
|
|
|
&channels,
|
2019-08-16 13:09:51 +02:00
|
|
|
&sdp_fmtp_line)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-11-23 02:32:06 -08:00
|
|
|
|
|
|
|
|
RTCCodecStats::RTCCodecStats(const std::string& id, int64_t timestamp_us)
|
|
|
|
|
: RTCCodecStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCCodecStats::RTCCodecStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
payload_type("payloadType"),
|
2017-02-28 06:56:04 -08:00
|
|
|
mime_type("mimeType"),
|
2016-11-23 02:32:06 -08:00
|
|
|
clock_rate("clockRate"),
|
|
|
|
|
channels("channels"),
|
2019-08-16 13:09:51 +02:00
|
|
|
sdp_fmtp_line("sdpFmtpLine") {}
|
2016-11-23 02:32:06 -08:00
|
|
|
|
|
|
|
|
RTCCodecStats::RTCCodecStats(const RTCCodecStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
payload_type(other.payload_type),
|
2017-02-28 06:56:04 -08:00
|
|
|
mime_type(other.mime_type),
|
2016-11-23 02:32:06 -08:00
|
|
|
clock_rate(other.clock_rate),
|
|
|
|
|
channels(other.channels),
|
2019-08-16 13:09:51 +02:00
|
|
|
sdp_fmtp_line(other.sdp_fmtp_line) {}
|
2016-11-23 02:32:06 -08:00
|
|
|
|
|
|
|
|
RTCCodecStats::~RTCCodecStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-10-24 04:00:05 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCDataChannelStats, RTCStats, "data-channel",
|
|
|
|
|
&label,
|
|
|
|
|
&protocol,
|
2020-06-05 15:38:51 +02:00
|
|
|
&data_channel_identifier,
|
2016-10-24 04:00:05 -07:00
|
|
|
&state,
|
|
|
|
|
&messages_sent,
|
|
|
|
|
&bytes_sent,
|
|
|
|
|
&messages_received,
|
2019-02-20 10:13:16 -05:00
|
|
|
&bytes_received)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-10-24 04:00:05 -07:00
|
|
|
|
|
|
|
|
RTCDataChannelStats::RTCDataChannelStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCDataChannelStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCDataChannelStats::RTCDataChannelStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
label("label"),
|
|
|
|
|
protocol("protocol"),
|
2020-06-05 15:38:51 +02:00
|
|
|
data_channel_identifier("dataChannelIdentifier"),
|
2016-10-24 04:00:05 -07:00
|
|
|
state("state"),
|
|
|
|
|
messages_sent("messagesSent"),
|
|
|
|
|
bytes_sent("bytesSent"),
|
|
|
|
|
messages_received("messagesReceived"),
|
|
|
|
|
bytes_received("bytesReceived") {}
|
|
|
|
|
|
|
|
|
|
RTCDataChannelStats::RTCDataChannelStats(const RTCDataChannelStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
label(other.label),
|
|
|
|
|
protocol(other.protocol),
|
2020-06-05 15:38:51 +02:00
|
|
|
data_channel_identifier(other.data_channel_identifier),
|
2016-10-24 04:00:05 -07:00
|
|
|
state(other.state),
|
|
|
|
|
messages_sent(other.messages_sent),
|
|
|
|
|
bytes_sent(other.bytes_sent),
|
|
|
|
|
messages_received(other.messages_received),
|
|
|
|
|
bytes_received(other.bytes_received) {}
|
|
|
|
|
|
|
|
|
|
RTCDataChannelStats::~RTCDataChannelStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-10-11 14:54:49 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCIceCandidatePairStats, RTCStats, "candidate-pair",
|
|
|
|
|
&transport_id,
|
|
|
|
|
&local_candidate_id,
|
|
|
|
|
&remote_candidate_id,
|
|
|
|
|
&state,
|
|
|
|
|
&priority,
|
|
|
|
|
&nominated,
|
|
|
|
|
&writable,
|
|
|
|
|
&readable,
|
|
|
|
|
&bytes_sent,
|
|
|
|
|
&bytes_received,
|
2016-12-15 06:17:08 -08:00
|
|
|
&total_round_trip_time,
|
|
|
|
|
¤t_round_trip_time,
|
2016-10-11 14:54:49 -07:00
|
|
|
&available_outgoing_bitrate,
|
|
|
|
|
&available_incoming_bitrate,
|
|
|
|
|
&requests_received,
|
|
|
|
|
&requests_sent,
|
|
|
|
|
&responses_received,
|
|
|
|
|
&responses_sent,
|
|
|
|
|
&retransmissions_received,
|
|
|
|
|
&retransmissions_sent,
|
|
|
|
|
&consent_requests_received,
|
|
|
|
|
&consent_requests_sent,
|
|
|
|
|
&consent_responses_received,
|
2019-02-20 10:13:16 -05:00
|
|
|
&consent_responses_sent)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-10-11 14:54:49 -07:00
|
|
|
|
|
|
|
|
RTCIceCandidatePairStats::RTCIceCandidatePairStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCIceCandidatePairStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCIceCandidatePairStats::RTCIceCandidatePairStats(std::string&& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
transport_id("transportId"),
|
|
|
|
|
local_candidate_id("localCandidateId"),
|
|
|
|
|
remote_candidate_id("remoteCandidateId"),
|
|
|
|
|
state("state"),
|
|
|
|
|
priority("priority"),
|
|
|
|
|
nominated("nominated"),
|
|
|
|
|
writable("writable"),
|
|
|
|
|
readable("readable"),
|
|
|
|
|
bytes_sent("bytesSent"),
|
|
|
|
|
bytes_received("bytesReceived"),
|
2016-12-15 06:17:08 -08:00
|
|
|
total_round_trip_time("totalRoundTripTime"),
|
|
|
|
|
current_round_trip_time("currentRoundTripTime"),
|
2016-10-11 14:54:49 -07:00
|
|
|
available_outgoing_bitrate("availableOutgoingBitrate"),
|
|
|
|
|
available_incoming_bitrate("availableIncomingBitrate"),
|
|
|
|
|
requests_received("requestsReceived"),
|
|
|
|
|
requests_sent("requestsSent"),
|
|
|
|
|
responses_received("responsesReceived"),
|
|
|
|
|
responses_sent("responsesSent"),
|
|
|
|
|
retransmissions_received("retransmissionsReceived"),
|
|
|
|
|
retransmissions_sent("retransmissionsSent"),
|
|
|
|
|
consent_requests_received("consentRequestsReceived"),
|
|
|
|
|
consent_requests_sent("consentRequestsSent"),
|
|
|
|
|
consent_responses_received("consentResponsesReceived"),
|
|
|
|
|
consent_responses_sent("consentResponsesSent") {}
|
|
|
|
|
|
|
|
|
|
RTCIceCandidatePairStats::RTCIceCandidatePairStats(
|
|
|
|
|
const RTCIceCandidatePairStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
transport_id(other.transport_id),
|
|
|
|
|
local_candidate_id(other.local_candidate_id),
|
|
|
|
|
remote_candidate_id(other.remote_candidate_id),
|
|
|
|
|
state(other.state),
|
|
|
|
|
priority(other.priority),
|
|
|
|
|
nominated(other.nominated),
|
|
|
|
|
writable(other.writable),
|
|
|
|
|
readable(other.readable),
|
|
|
|
|
bytes_sent(other.bytes_sent),
|
|
|
|
|
bytes_received(other.bytes_received),
|
2016-12-15 06:17:08 -08:00
|
|
|
total_round_trip_time(other.total_round_trip_time),
|
|
|
|
|
current_round_trip_time(other.current_round_trip_time),
|
2016-10-11 14:54:49 -07:00
|
|
|
available_outgoing_bitrate(other.available_outgoing_bitrate),
|
|
|
|
|
available_incoming_bitrate(other.available_incoming_bitrate),
|
|
|
|
|
requests_received(other.requests_received),
|
|
|
|
|
requests_sent(other.requests_sent),
|
|
|
|
|
responses_received(other.responses_received),
|
|
|
|
|
responses_sent(other.responses_sent),
|
|
|
|
|
retransmissions_received(other.retransmissions_received),
|
|
|
|
|
retransmissions_sent(other.retransmissions_sent),
|
|
|
|
|
consent_requests_received(other.consent_requests_received),
|
|
|
|
|
consent_requests_sent(other.consent_requests_sent),
|
|
|
|
|
consent_responses_received(other.consent_responses_received),
|
|
|
|
|
consent_responses_sent(other.consent_responses_sent) {}
|
|
|
|
|
|
|
|
|
|
RTCIceCandidatePairStats::~RTCIceCandidatePairStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2018-03-20 13:24:20 +01:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCIceCandidateStats, RTCStats, "abstract-ice-candidate",
|
2017-01-02 09:59:31 -08:00
|
|
|
&transport_id,
|
2017-01-02 04:46:15 -08:00
|
|
|
&is_remote,
|
2017-11-21 10:49:36 -08:00
|
|
|
&network_type,
|
2016-10-07 02:18:47 -07:00
|
|
|
&ip,
|
|
|
|
|
&port,
|
|
|
|
|
&protocol,
|
2018-09-27 14:40:08 +02:00
|
|
|
&relay_protocol,
|
2016-10-07 02:18:47 -07:00
|
|
|
&candidate_type,
|
|
|
|
|
&priority,
|
2017-01-02 08:09:59 -08:00
|
|
|
&url,
|
2019-02-20 10:13:16 -05:00
|
|
|
&deleted)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-10-07 02:18:47 -07:00
|
|
|
|
|
|
|
|
RTCIceCandidateStats::RTCIceCandidateStats(const std::string& id,
|
2017-01-02 04:46:15 -08:00
|
|
|
int64_t timestamp_us,
|
|
|
|
|
bool is_remote)
|
|
|
|
|
: RTCIceCandidateStats(std::string(id), timestamp_us, is_remote) {}
|
2016-10-07 02:18:47 -07:00
|
|
|
|
2017-11-21 10:49:36 -08:00
|
|
|
RTCIceCandidateStats::RTCIceCandidateStats(std::string&& id,
|
|
|
|
|
int64_t timestamp_us,
|
|
|
|
|
bool is_remote)
|
2016-10-07 02:18:47 -07:00
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
2017-01-02 09:59:31 -08:00
|
|
|
transport_id("transportId"),
|
2017-01-02 04:46:15 -08:00
|
|
|
is_remote("isRemote", is_remote),
|
2017-11-21 10:49:36 -08:00
|
|
|
network_type("networkType"),
|
2016-10-07 02:18:47 -07:00
|
|
|
ip("ip"),
|
|
|
|
|
port("port"),
|
|
|
|
|
protocol("protocol"),
|
2018-09-27 14:40:08 +02:00
|
|
|
relay_protocol("relayProtocol"),
|
2016-10-07 02:18:47 -07:00
|
|
|
candidate_type("candidateType"),
|
|
|
|
|
priority("priority"),
|
2017-01-02 08:09:59 -08:00
|
|
|
url("url"),
|
2017-11-21 10:49:36 -08:00
|
|
|
deleted("deleted", false) {}
|
2016-10-07 02:18:47 -07:00
|
|
|
|
|
|
|
|
RTCIceCandidateStats::RTCIceCandidateStats(const RTCIceCandidateStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
2017-01-02 09:59:31 -08:00
|
|
|
transport_id(other.transport_id),
|
2017-01-02 04:46:15 -08:00
|
|
|
is_remote(other.is_remote),
|
2017-11-21 10:49:36 -08:00
|
|
|
network_type(other.network_type),
|
2016-10-07 02:18:47 -07:00
|
|
|
ip(other.ip),
|
|
|
|
|
port(other.port),
|
|
|
|
|
protocol(other.protocol),
|
2018-09-27 14:40:08 +02:00
|
|
|
relay_protocol(other.relay_protocol),
|
2016-10-07 02:18:47 -07:00
|
|
|
candidate_type(other.candidate_type),
|
|
|
|
|
priority(other.priority),
|
2017-01-02 08:09:59 -08:00
|
|
|
url(other.url),
|
2017-11-21 10:49:36 -08:00
|
|
|
deleted(other.deleted) {}
|
2016-10-07 02:18:47 -07:00
|
|
|
|
|
|
|
|
RTCIceCandidateStats::~RTCIceCandidateStats() {}
|
|
|
|
|
|
|
|
|
|
const char RTCLocalIceCandidateStats::kType[] = "local-candidate";
|
|
|
|
|
|
|
|
|
|
RTCLocalIceCandidateStats::RTCLocalIceCandidateStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
2017-01-02 04:46:15 -08:00
|
|
|
: RTCIceCandidateStats(id, timestamp_us, false) {}
|
2016-10-07 02:18:47 -07:00
|
|
|
|
|
|
|
|
RTCLocalIceCandidateStats::RTCLocalIceCandidateStats(std::string&& id,
|
|
|
|
|
int64_t timestamp_us)
|
2017-01-02 04:46:15 -08:00
|
|
|
: RTCIceCandidateStats(std::move(id), timestamp_us, false) {}
|
2016-10-07 02:18:47 -07:00
|
|
|
|
2018-03-20 13:24:20 +01:00
|
|
|
std::unique_ptr<RTCStats> RTCLocalIceCandidateStats::copy() const {
|
|
|
|
|
return std::unique_ptr<RTCStats>(new RTCLocalIceCandidateStats(*this));
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-07 02:18:47 -07:00
|
|
|
const char* RTCLocalIceCandidateStats::type() const {
|
|
|
|
|
return kType;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const char RTCRemoteIceCandidateStats::kType[] = "remote-candidate";
|
|
|
|
|
|
|
|
|
|
RTCRemoteIceCandidateStats::RTCRemoteIceCandidateStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
2017-01-02 04:46:15 -08:00
|
|
|
: RTCIceCandidateStats(id, timestamp_us, true) {}
|
2016-10-07 02:18:47 -07:00
|
|
|
|
|
|
|
|
RTCRemoteIceCandidateStats::RTCRemoteIceCandidateStats(std::string&& id,
|
|
|
|
|
int64_t timestamp_us)
|
2017-01-02 04:46:15 -08:00
|
|
|
: RTCIceCandidateStats(std::move(id), timestamp_us, true) {}
|
2016-10-07 02:18:47 -07:00
|
|
|
|
2018-03-20 13:24:20 +01:00
|
|
|
std::unique_ptr<RTCStats> RTCRemoteIceCandidateStats::copy() const {
|
|
|
|
|
return std::unique_ptr<RTCStats>(new RTCRemoteIceCandidateStats(*this));
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-07 02:18:47 -07:00
|
|
|
const char* RTCRemoteIceCandidateStats::type() const {
|
|
|
|
|
return kType;
|
|
|
|
|
}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-11-08 06:29:22 -08:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCMediaStreamStats, RTCStats, "stream",
|
|
|
|
|
&stream_identifier,
|
2019-02-20 10:13:16 -05:00
|
|
|
&track_ids)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-11-08 06:29:22 -08:00
|
|
|
|
|
|
|
|
RTCMediaStreamStats::RTCMediaStreamStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCMediaStreamStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCMediaStreamStats::RTCMediaStreamStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
stream_identifier("streamIdentifier"),
|
|
|
|
|
track_ids("trackIds") {}
|
|
|
|
|
|
|
|
|
|
RTCMediaStreamStats::RTCMediaStreamStats(const RTCMediaStreamStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
stream_identifier(other.stream_identifier),
|
|
|
|
|
track_ids(other.track_ids) {}
|
|
|
|
|
|
|
|
|
|
RTCMediaStreamStats::~RTCMediaStreamStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-11-08 06:29:22 -08:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCMediaStreamTrackStats, RTCStats, "track",
|
2017-07-14 12:17:49 -07:00
|
|
|
&track_identifier,
|
2019-05-22 15:49:42 +02:00
|
|
|
&media_source_id,
|
2017-07-14 12:17:49 -07:00
|
|
|
&remote_source,
|
|
|
|
|
&ended,
|
|
|
|
|
&detached,
|
|
|
|
|
&kind,
|
2017-10-02 12:00:34 +02:00
|
|
|
&jitter_buffer_delay,
|
2019-01-15 15:46:29 +01:00
|
|
|
&jitter_buffer_emitted_count,
|
2017-07-14 12:17:49 -07:00
|
|
|
&frame_width,
|
|
|
|
|
&frame_height,
|
|
|
|
|
&frames_per_second,
|
|
|
|
|
&frames_sent,
|
2018-02-28 16:35:03 +01:00
|
|
|
&huge_frames_sent,
|
2017-07-14 12:17:49 -07:00
|
|
|
&frames_received,
|
|
|
|
|
&frames_decoded,
|
|
|
|
|
&frames_dropped,
|
|
|
|
|
&frames_corrupted,
|
|
|
|
|
&partial_frames_lost,
|
|
|
|
|
&full_frames_lost,
|
|
|
|
|
&audio_level,
|
|
|
|
|
&total_audio_energy,
|
|
|
|
|
&echo_return_loss,
|
2017-08-24 17:15:13 -07:00
|
|
|
&echo_return_loss_enhancement,
|
|
|
|
|
&total_samples_received,
|
|
|
|
|
&total_samples_duration,
|
2017-09-18 09:28:20 +02:00
|
|
|
&concealed_samples,
|
2019-08-21 12:09:51 +02:00
|
|
|
&silent_concealed_samples,
|
2018-11-22 17:21:10 +01:00
|
|
|
&concealment_events,
|
2019-08-21 12:09:51 +02:00
|
|
|
&inserted_samples_for_deceleration,
|
|
|
|
|
&removed_samples_for_acceleration,
|
2018-11-27 12:52:16 +01:00
|
|
|
&jitter_buffer_flushes,
|
2019-01-31 16:45:42 +01:00
|
|
|
&delayed_packet_outage_samples,
|
2019-03-06 09:18:40 +01:00
|
|
|
&relative_packet_arrival_delay,
|
2020-03-11 11:18:54 +01:00
|
|
|
&jitter_buffer_target_delay,
|
2019-04-29 17:00:46 +02:00
|
|
|
&interruption_count,
|
|
|
|
|
&total_interruption_duration,
|
2019-01-31 16:45:42 +01:00
|
|
|
&freeze_count,
|
|
|
|
|
&pause_count,
|
|
|
|
|
&total_freezes_duration,
|
|
|
|
|
&total_pauses_duration,
|
|
|
|
|
&total_frames_duration,
|
2019-02-20 10:13:16 -05:00
|
|
|
&sum_squared_frame_durations)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-11-08 06:29:22 -08:00
|
|
|
|
|
|
|
|
RTCMediaStreamTrackStats::RTCMediaStreamTrackStats(const std::string& id,
|
2017-01-17 02:53:23 -08:00
|
|
|
int64_t timestamp_us,
|
|
|
|
|
const char* kind)
|
|
|
|
|
: RTCMediaStreamTrackStats(std::string(id), timestamp_us, kind) {}
|
2016-11-08 06:29:22 -08:00
|
|
|
|
2017-07-14 12:17:49 -07:00
|
|
|
RTCMediaStreamTrackStats::RTCMediaStreamTrackStats(std::string&& id,
|
|
|
|
|
int64_t timestamp_us,
|
|
|
|
|
const char* kind)
|
2016-11-08 06:29:22 -08:00
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
track_identifier("trackIdentifier"),
|
2019-05-22 15:49:42 +02:00
|
|
|
media_source_id("mediaSourceId"),
|
2016-11-08 06:29:22 -08:00
|
|
|
remote_source("remoteSource"),
|
|
|
|
|
ended("ended"),
|
|
|
|
|
detached("detached"),
|
2017-01-17 02:53:23 -08:00
|
|
|
kind("kind", kind),
|
2017-10-02 12:00:34 +02:00
|
|
|
jitter_buffer_delay("jitterBufferDelay"),
|
2019-01-15 15:46:29 +01:00
|
|
|
jitter_buffer_emitted_count("jitterBufferEmittedCount"),
|
2016-11-08 06:29:22 -08:00
|
|
|
frame_width("frameWidth"),
|
|
|
|
|
frame_height("frameHeight"),
|
|
|
|
|
frames_per_second("framesPerSecond"),
|
|
|
|
|
frames_sent("framesSent"),
|
2018-02-28 16:35:03 +01:00
|
|
|
huge_frames_sent("hugeFramesSent"),
|
2016-11-08 06:29:22 -08:00
|
|
|
frames_received("framesReceived"),
|
|
|
|
|
frames_decoded("framesDecoded"),
|
|
|
|
|
frames_dropped("framesDropped"),
|
|
|
|
|
frames_corrupted("framesCorrupted"),
|
|
|
|
|
partial_frames_lost("partialFramesLost"),
|
|
|
|
|
full_frames_lost("fullFramesLost"),
|
|
|
|
|
audio_level("audioLevel"),
|
2017-07-14 12:17:49 -07:00
|
|
|
total_audio_energy("totalAudioEnergy"),
|
2016-11-08 06:29:22 -08:00
|
|
|
echo_return_loss("echoReturnLoss"),
|
2017-08-24 17:15:13 -07:00
|
|
|
echo_return_loss_enhancement("echoReturnLossEnhancement"),
|
|
|
|
|
total_samples_received("totalSamplesReceived"),
|
|
|
|
|
total_samples_duration("totalSamplesDuration"),
|
2017-09-18 09:28:20 +02:00
|
|
|
concealed_samples("concealedSamples"),
|
2019-04-30 09:45:21 +02:00
|
|
|
silent_concealed_samples("silentConcealedSamples"),
|
2018-11-22 17:21:10 +01:00
|
|
|
concealment_events("concealmentEvents"),
|
2019-04-30 09:45:21 +02:00
|
|
|
inserted_samples_for_deceleration("insertedSamplesForDeceleration"),
|
|
|
|
|
removed_samples_for_acceleration("removedSamplesForAcceleration"),
|
2019-03-19 15:38:49 +01:00
|
|
|
jitter_buffer_flushes(
|
|
|
|
|
"jitterBufferFlushes",
|
|
|
|
|
{NonStandardGroupId::kRtcAudioJitterBufferMaxPackets}),
|
|
|
|
|
delayed_packet_outage_samples(
|
|
|
|
|
"delayedPacketOutageSamples",
|
|
|
|
|
{NonStandardGroupId::kRtcAudioJitterBufferMaxPackets,
|
|
|
|
|
NonStandardGroupId::kRtcStatsRelativePacketArrivalDelay}),
|
|
|
|
|
relative_packet_arrival_delay(
|
|
|
|
|
"relativePacketArrivalDelay",
|
|
|
|
|
{NonStandardGroupId::kRtcStatsRelativePacketArrivalDelay}),
|
2020-03-11 11:18:54 +01:00
|
|
|
jitter_buffer_target_delay("jitterBufferTargetDelay"),
|
2019-04-29 17:00:46 +02:00
|
|
|
interruption_count("interruptionCount"),
|
|
|
|
|
total_interruption_duration("totalInterruptionDuration"),
|
2019-01-31 16:45:42 +01:00
|
|
|
freeze_count("freezeCount"),
|
|
|
|
|
pause_count("pauseCount"),
|
|
|
|
|
total_freezes_duration("totalFreezesDuration"),
|
|
|
|
|
total_pauses_duration("totalPausesDuration"),
|
|
|
|
|
total_frames_duration("totalFramesDuration"),
|
|
|
|
|
sum_squared_frame_durations("sumOfSquaredFramesDuration") {
|
2017-01-17 02:53:23 -08:00
|
|
|
RTC_DCHECK(kind == RTCMediaStreamTrackKind::kAudio ||
|
|
|
|
|
kind == RTCMediaStreamTrackKind::kVideo);
|
2016-11-08 06:29:22 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
RTCMediaStreamTrackStats::RTCMediaStreamTrackStats(
|
|
|
|
|
const RTCMediaStreamTrackStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
track_identifier(other.track_identifier),
|
2019-05-22 15:49:42 +02:00
|
|
|
media_source_id(other.media_source_id),
|
2016-11-08 06:29:22 -08:00
|
|
|
remote_source(other.remote_source),
|
|
|
|
|
ended(other.ended),
|
|
|
|
|
detached(other.detached),
|
2017-01-17 02:53:23 -08:00
|
|
|
kind(other.kind),
|
2017-10-02 12:00:34 +02:00
|
|
|
jitter_buffer_delay(other.jitter_buffer_delay),
|
2019-01-15 15:46:29 +01:00
|
|
|
jitter_buffer_emitted_count(other.jitter_buffer_emitted_count),
|
2016-11-08 06:29:22 -08:00
|
|
|
frame_width(other.frame_width),
|
|
|
|
|
frame_height(other.frame_height),
|
|
|
|
|
frames_per_second(other.frames_per_second),
|
|
|
|
|
frames_sent(other.frames_sent),
|
2018-02-28 16:35:03 +01:00
|
|
|
huge_frames_sent(other.huge_frames_sent),
|
2016-11-08 06:29:22 -08:00
|
|
|
frames_received(other.frames_received),
|
|
|
|
|
frames_decoded(other.frames_decoded),
|
|
|
|
|
frames_dropped(other.frames_dropped),
|
|
|
|
|
frames_corrupted(other.frames_corrupted),
|
|
|
|
|
partial_frames_lost(other.partial_frames_lost),
|
|
|
|
|
full_frames_lost(other.full_frames_lost),
|
|
|
|
|
audio_level(other.audio_level),
|
2017-07-14 12:17:49 -07:00
|
|
|
total_audio_energy(other.total_audio_energy),
|
2016-11-08 06:29:22 -08:00
|
|
|
echo_return_loss(other.echo_return_loss),
|
2017-08-24 17:15:13 -07:00
|
|
|
echo_return_loss_enhancement(other.echo_return_loss_enhancement),
|
|
|
|
|
total_samples_received(other.total_samples_received),
|
|
|
|
|
total_samples_duration(other.total_samples_duration),
|
2017-09-18 09:28:20 +02:00
|
|
|
concealed_samples(other.concealed_samples),
|
2019-04-30 09:45:21 +02:00
|
|
|
silent_concealed_samples(other.silent_concealed_samples),
|
2018-11-22 17:21:10 +01:00
|
|
|
concealment_events(other.concealment_events),
|
2019-04-30 09:45:21 +02:00
|
|
|
inserted_samples_for_deceleration(
|
|
|
|
|
other.inserted_samples_for_deceleration),
|
|
|
|
|
removed_samples_for_acceleration(other.removed_samples_for_acceleration),
|
2018-11-27 12:52:16 +01:00
|
|
|
jitter_buffer_flushes(other.jitter_buffer_flushes),
|
2019-01-31 16:45:42 +01:00
|
|
|
delayed_packet_outage_samples(other.delayed_packet_outage_samples),
|
2019-03-06 09:18:40 +01:00
|
|
|
relative_packet_arrival_delay(other.relative_packet_arrival_delay),
|
2020-03-11 11:18:54 +01:00
|
|
|
jitter_buffer_target_delay(other.jitter_buffer_target_delay),
|
2019-04-29 17:00:46 +02:00
|
|
|
interruption_count(other.interruption_count),
|
|
|
|
|
total_interruption_duration(other.total_interruption_duration),
|
2019-01-31 16:45:42 +01:00
|
|
|
freeze_count(other.freeze_count),
|
|
|
|
|
pause_count(other.pause_count),
|
|
|
|
|
total_freezes_duration(other.total_freezes_duration),
|
|
|
|
|
total_pauses_duration(other.total_pauses_duration),
|
|
|
|
|
total_frames_duration(other.total_frames_duration),
|
|
|
|
|
sum_squared_frame_durations(other.sum_squared_frame_durations) {}
|
2016-11-08 06:29:22 -08:00
|
|
|
|
|
|
|
|
RTCMediaStreamTrackStats::~RTCMediaStreamTrackStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-10-24 04:00:05 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCPeerConnectionStats, RTCStats, "peer-connection",
|
|
|
|
|
&data_channels_opened,
|
2019-02-20 10:13:16 -05:00
|
|
|
&data_channels_closed)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-10-03 14:16:56 -07:00
|
|
|
|
2016-10-24 04:00:05 -07:00
|
|
|
RTCPeerConnectionStats::RTCPeerConnectionStats(const std::string& id,
|
2016-10-03 14:16:56 -07:00
|
|
|
int64_t timestamp_us)
|
2016-10-24 04:00:05 -07:00
|
|
|
: RTCPeerConnectionStats(std::string(id), timestamp_us) {}
|
2016-10-03 14:16:56 -07:00
|
|
|
|
2016-10-24 04:00:05 -07:00
|
|
|
RTCPeerConnectionStats::RTCPeerConnectionStats(std::string&& id,
|
2016-10-03 14:16:56 -07:00
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
2016-10-24 04:00:05 -07:00
|
|
|
data_channels_opened("dataChannelsOpened"),
|
|
|
|
|
data_channels_closed("dataChannelsClosed") {}
|
2016-10-03 14:16:56 -07:00
|
|
|
|
2016-10-24 04:00:05 -07:00
|
|
|
RTCPeerConnectionStats::RTCPeerConnectionStats(
|
|
|
|
|
const RTCPeerConnectionStats& other)
|
2016-10-06 02:06:10 -07:00
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
2016-10-24 04:00:05 -07:00
|
|
|
data_channels_opened(other.data_channels_opened),
|
|
|
|
|
data_channels_closed(other.data_channels_closed) {}
|
2016-10-06 02:06:10 -07:00
|
|
|
|
2016-10-24 04:00:05 -07:00
|
|
|
RTCPeerConnectionStats::~RTCPeerConnectionStats() {}
|
2016-10-06 02:06:10 -07:00
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-11-01 01:50:46 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCRTPStreamStats, RTCStats, "rtp",
|
|
|
|
|
&ssrc,
|
|
|
|
|
&is_remote,
|
|
|
|
|
&media_type,
|
2018-08-28 14:55:03 +02:00
|
|
|
&kind,
|
2017-01-27 06:35:16 -08:00
|
|
|
&track_id,
|
2016-11-01 01:50:46 -07:00
|
|
|
&transport_id,
|
|
|
|
|
&codec_id,
|
|
|
|
|
&fir_count,
|
|
|
|
|
&pli_count,
|
|
|
|
|
&nack_count,
|
2017-01-02 08:35:13 -08:00
|
|
|
&sli_count,
|
2019-02-20 10:13:16 -05:00
|
|
|
&qp_sum)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-11-01 01:50:46 -07:00
|
|
|
|
|
|
|
|
RTCRTPStreamStats::RTCRTPStreamStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCRTPStreamStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCRTPStreamStats::RTCRTPStreamStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
ssrc("ssrc"),
|
|
|
|
|
is_remote("isRemote", false),
|
|
|
|
|
media_type("mediaType"),
|
2018-08-28 14:55:03 +02:00
|
|
|
kind("kind"),
|
2017-01-27 06:35:16 -08:00
|
|
|
track_id("trackId"),
|
2016-11-01 01:50:46 -07:00
|
|
|
transport_id("transportId"),
|
|
|
|
|
codec_id("codecId"),
|
|
|
|
|
fir_count("firCount"),
|
|
|
|
|
pli_count("pliCount"),
|
|
|
|
|
nack_count("nackCount"),
|
2017-01-02 08:35:13 -08:00
|
|
|
sli_count("sliCount"),
|
|
|
|
|
qp_sum("qpSum") {}
|
2016-11-01 01:50:46 -07:00
|
|
|
|
|
|
|
|
RTCRTPStreamStats::RTCRTPStreamStats(const RTCRTPStreamStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
ssrc(other.ssrc),
|
|
|
|
|
is_remote(other.is_remote),
|
|
|
|
|
media_type(other.media_type),
|
2018-08-28 14:55:03 +02:00
|
|
|
kind(other.kind),
|
2017-01-27 06:35:16 -08:00
|
|
|
track_id(other.track_id),
|
2016-11-01 01:50:46 -07:00
|
|
|
transport_id(other.transport_id),
|
|
|
|
|
codec_id(other.codec_id),
|
|
|
|
|
fir_count(other.fir_count),
|
|
|
|
|
pli_count(other.pli_count),
|
|
|
|
|
nack_count(other.nack_count),
|
2017-01-02 08:35:13 -08:00
|
|
|
sli_count(other.sli_count),
|
|
|
|
|
qp_sum(other.qp_sum) {}
|
2016-11-01 01:50:46 -07:00
|
|
|
|
|
|
|
|
RTCRTPStreamStats::~RTCRTPStreamStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-11-01 03:00:17 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(
|
|
|
|
|
RTCInboundRTPStreamStats, RTCRTPStreamStats, "inbound-rtp",
|
|
|
|
|
&packets_received,
|
2020-01-28 11:15:35 +01:00
|
|
|
&fec_packets_received,
|
|
|
|
|
&fec_packets_discarded,
|
2016-11-01 03:00:17 -07:00
|
|
|
&bytes_received,
|
2019-10-09 15:01:33 +02:00
|
|
|
&header_bytes_received,
|
2016-11-01 03:00:17 -07:00
|
|
|
&packets_lost,
|
2019-04-15 17:32:00 +02:00
|
|
|
&last_packet_received_timestamp,
|
2016-11-01 03:00:17 -07:00
|
|
|
&jitter,
|
2017-03-01 01:02:45 -08:00
|
|
|
&round_trip_time,
|
2016-11-01 03:00:17 -07:00
|
|
|
&packets_discarded,
|
|
|
|
|
&packets_repaired,
|
|
|
|
|
&burst_packets_lost,
|
|
|
|
|
&burst_packets_discarded,
|
|
|
|
|
&burst_loss_count,
|
|
|
|
|
&burst_discard_count,
|
|
|
|
|
&burst_loss_rate,
|
|
|
|
|
&burst_discard_rate,
|
|
|
|
|
&gap_loss_rate,
|
2017-01-02 08:35:13 -08:00
|
|
|
&gap_discard_rate,
|
2019-04-09 13:59:31 +02:00
|
|
|
&frames_decoded,
|
2019-06-27 14:29:34 +02:00
|
|
|
&key_frames_decoded,
|
2019-07-01 10:07:50 +02:00
|
|
|
&total_decode_time,
|
2019-11-25 10:25:42 +01:00
|
|
|
&total_inter_frame_delay,
|
|
|
|
|
&total_squared_inter_frame_delay,
|
2019-08-16 13:09:51 +02:00
|
|
|
&content_type,
|
2019-10-22 15:23:44 +02:00
|
|
|
&estimated_playout_timestamp,
|
2019-08-16 13:09:51 +02:00
|
|
|
&decoder_implementation)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-11-01 03:00:17 -07:00
|
|
|
|
|
|
|
|
RTCInboundRTPStreamStats::RTCInboundRTPStreamStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCInboundRTPStreamStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCInboundRTPStreamStats::RTCInboundRTPStreamStats(std::string&& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCRTPStreamStats(std::move(id), timestamp_us),
|
|
|
|
|
packets_received("packetsReceived"),
|
2019-04-30 09:45:21 +02:00
|
|
|
fec_packets_received("fecPacketsReceived"),
|
|
|
|
|
fec_packets_discarded("fecPacketsDiscarded"),
|
2016-11-01 03:00:17 -07:00
|
|
|
bytes_received("bytesReceived"),
|
2019-10-09 15:01:33 +02:00
|
|
|
header_bytes_received("headerBytesReceived"),
|
2016-11-01 03:00:17 -07:00
|
|
|
packets_lost("packetsLost"),
|
2019-04-15 17:32:00 +02:00
|
|
|
last_packet_received_timestamp("lastPacketReceivedTimestamp"),
|
2016-11-01 03:00:17 -07:00
|
|
|
jitter("jitter"),
|
2017-03-01 01:02:45 -08:00
|
|
|
round_trip_time("roundTripTime"),
|
2016-11-01 03:00:17 -07:00
|
|
|
packets_discarded("packetsDiscarded"),
|
|
|
|
|
packets_repaired("packetsRepaired"),
|
|
|
|
|
burst_packets_lost("burstPacketsLost"),
|
|
|
|
|
burst_packets_discarded("burstPacketsDiscarded"),
|
|
|
|
|
burst_loss_count("burstLossCount"),
|
|
|
|
|
burst_discard_count("burstDiscardCount"),
|
|
|
|
|
burst_loss_rate("burstLossRate"),
|
|
|
|
|
burst_discard_rate("burstDiscardRate"),
|
|
|
|
|
gap_loss_rate("gapLossRate"),
|
2017-01-02 08:35:13 -08:00
|
|
|
gap_discard_rate("gapDiscardRate"),
|
2019-04-09 13:59:31 +02:00
|
|
|
frames_decoded("framesDecoded"),
|
2019-06-27 14:29:34 +02:00
|
|
|
key_frames_decoded("keyFramesDecoded"),
|
2019-07-01 10:07:50 +02:00
|
|
|
total_decode_time("totalDecodeTime"),
|
2019-11-25 10:25:42 +01:00
|
|
|
total_inter_frame_delay("totalInterFrameDelay"),
|
|
|
|
|
total_squared_inter_frame_delay("totalSquaredInterFrameDelay"),
|
2019-08-16 13:09:51 +02:00
|
|
|
content_type("contentType"),
|
2019-10-22 15:23:44 +02:00
|
|
|
estimated_playout_timestamp("estimatedPlayoutTimestamp"),
|
2019-08-16 13:09:51 +02:00
|
|
|
decoder_implementation("decoderImplementation") {}
|
2016-11-01 03:00:17 -07:00
|
|
|
|
|
|
|
|
RTCInboundRTPStreamStats::RTCInboundRTPStreamStats(
|
|
|
|
|
const RTCInboundRTPStreamStats& other)
|
|
|
|
|
: RTCRTPStreamStats(other),
|
|
|
|
|
packets_received(other.packets_received),
|
2019-04-30 09:45:21 +02:00
|
|
|
fec_packets_received(other.fec_packets_received),
|
|
|
|
|
fec_packets_discarded(other.fec_packets_discarded),
|
2016-11-01 03:00:17 -07:00
|
|
|
bytes_received(other.bytes_received),
|
2019-10-09 15:01:33 +02:00
|
|
|
header_bytes_received(other.header_bytes_received),
|
2016-11-01 03:00:17 -07:00
|
|
|
packets_lost(other.packets_lost),
|
2019-04-15 17:32:00 +02:00
|
|
|
last_packet_received_timestamp(other.last_packet_received_timestamp),
|
2016-11-01 03:00:17 -07:00
|
|
|
jitter(other.jitter),
|
2017-03-01 01:02:45 -08:00
|
|
|
round_trip_time(other.round_trip_time),
|
2016-11-01 03:00:17 -07:00
|
|
|
packets_discarded(other.packets_discarded),
|
|
|
|
|
packets_repaired(other.packets_repaired),
|
|
|
|
|
burst_packets_lost(other.burst_packets_lost),
|
|
|
|
|
burst_packets_discarded(other.burst_packets_discarded),
|
|
|
|
|
burst_loss_count(other.burst_loss_count),
|
|
|
|
|
burst_discard_count(other.burst_discard_count),
|
|
|
|
|
burst_loss_rate(other.burst_loss_rate),
|
|
|
|
|
burst_discard_rate(other.burst_discard_rate),
|
|
|
|
|
gap_loss_rate(other.gap_loss_rate),
|
2017-01-02 08:35:13 -08:00
|
|
|
gap_discard_rate(other.gap_discard_rate),
|
2019-04-09 13:59:31 +02:00
|
|
|
frames_decoded(other.frames_decoded),
|
2019-06-27 14:29:34 +02:00
|
|
|
key_frames_decoded(other.key_frames_decoded),
|
2019-07-01 10:07:50 +02:00
|
|
|
total_decode_time(other.total_decode_time),
|
2019-11-25 10:25:42 +01:00
|
|
|
total_inter_frame_delay(other.total_inter_frame_delay),
|
|
|
|
|
total_squared_inter_frame_delay(other.total_squared_inter_frame_delay),
|
2019-08-16 13:09:51 +02:00
|
|
|
content_type(other.content_type),
|
2019-10-22 15:23:44 +02:00
|
|
|
estimated_playout_timestamp(other.estimated_playout_timestamp),
|
2019-08-16 13:09:51 +02:00
|
|
|
decoder_implementation(other.decoder_implementation) {}
|
2016-11-01 03:00:17 -07:00
|
|
|
|
|
|
|
|
RTCInboundRTPStreamStats::~RTCInboundRTPStreamStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-11-01 01:50:46 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(
|
|
|
|
|
RTCOutboundRTPStreamStats, RTCRTPStreamStats, "outbound-rtp",
|
2019-05-22 15:49:42 +02:00
|
|
|
&media_source_id,
|
2019-12-19 13:27:27 +01:00
|
|
|
&remote_id,
|
Reland "Improve outbound-rtp statistics for simulcast"
This reverts commit 9a925c9ce33a6ccdd11b545b11ba68e985c2a65d.
Reason for revert: The original CL is updated in PS #2 to
fix the googRtt issue which was that when the legacy sender
stats were put in "aggregated_senders" we forgot to update
rtt_ms the same way that we do it for "senders".
Original change's description:
> Revert "Improve outbound-rtp statistics for simulcast"
>
> This reverts commit da6cda839dac7d9d18eba8d365188fa94831e0b1.
>
> Reason for revert: Breaks googRtt in legacy getStats API
>
> Original change's description:
> > Improve outbound-rtp statistics for simulcast
> >
> > Bug: webrtc:9547
> > Change-Id: Iec4eb976aa11ee743805425bedb77dcea7c2c9be
> > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/168120
> > Reviewed-by: Sebastian Jansson <srte@webrtc.org>
> > Reviewed-by: Erik Språng <sprang@webrtc.org>
> > Reviewed-by: Henrik Boström <hbos@webrtc.org>
> > Reviewed-by: Harald Alvestrand <hta@webrtc.org>
> > Commit-Queue: Eldar Rello <elrello@microsoft.com>
> > Cr-Commit-Position: refs/heads/master@{#31097}
>
> TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
>
> # Not skipping CQ checks because original CL landed > 1 day ago.
>
> Bug: webrtc:9547
> Change-Id: I06673328c2a5293a7eef03b3aaf2ded9d13df1b3
> Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174443
> Reviewed-by: Henrik Boström <hbos@webrtc.org>
> Commit-Queue: Henrik Boström <hbos@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#31165}
TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
# Not skipping CQ checks because this is a reland.
Bug: webrtc:9547
Change-Id: I723744c496c3c65f95ab6a8940862c8b9f544338
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174480
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#31169}
2020-05-05 15:54:46 +02:00
|
|
|
&rid,
|
2016-11-01 01:50:46 -07:00
|
|
|
&packets_sent,
|
2019-04-17 13:51:53 +02:00
|
|
|
&retransmitted_packets_sent,
|
2016-11-01 01:50:46 -07:00
|
|
|
&bytes_sent,
|
2019-10-09 15:01:33 +02:00
|
|
|
&header_bytes_sent,
|
2019-04-17 13:51:53 +02:00
|
|
|
&retransmitted_bytes_sent,
|
2016-11-01 01:50:46 -07:00
|
|
|
&target_bitrate,
|
2019-04-08 16:14:23 +02:00
|
|
|
&frames_encoded,
|
2019-06-27 14:29:34 +02:00
|
|
|
&key_frames_encoded,
|
2019-04-09 13:59:31 +02:00
|
|
|
&total_encode_time,
|
2019-05-20 15:15:38 +02:00
|
|
|
&total_encoded_bytes_target,
|
Reland "Improve outbound-rtp statistics for simulcast"
This reverts commit 9a925c9ce33a6ccdd11b545b11ba68e985c2a65d.
Reason for revert: The original CL is updated in PS #2 to
fix the googRtt issue which was that when the legacy sender
stats were put in "aggregated_senders" we forgot to update
rtt_ms the same way that we do it for "senders".
Original change's description:
> Revert "Improve outbound-rtp statistics for simulcast"
>
> This reverts commit da6cda839dac7d9d18eba8d365188fa94831e0b1.
>
> Reason for revert: Breaks googRtt in legacy getStats API
>
> Original change's description:
> > Improve outbound-rtp statistics for simulcast
> >
> > Bug: webrtc:9547
> > Change-Id: Iec4eb976aa11ee743805425bedb77dcea7c2c9be
> > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/168120
> > Reviewed-by: Sebastian Jansson <srte@webrtc.org>
> > Reviewed-by: Erik Språng <sprang@webrtc.org>
> > Reviewed-by: Henrik Boström <hbos@webrtc.org>
> > Reviewed-by: Harald Alvestrand <hta@webrtc.org>
> > Commit-Queue: Eldar Rello <elrello@microsoft.com>
> > Cr-Commit-Position: refs/heads/master@{#31097}
>
> TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
>
> # Not skipping CQ checks because original CL landed > 1 day ago.
>
> Bug: webrtc:9547
> Change-Id: I06673328c2a5293a7eef03b3aaf2ded9d13df1b3
> Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174443
> Reviewed-by: Henrik Boström <hbos@webrtc.org>
> Commit-Queue: Henrik Boström <hbos@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#31165}
TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
# Not skipping CQ checks because this is a reland.
Bug: webrtc:9547
Change-Id: I723744c496c3c65f95ab6a8940862c8b9f544338
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174480
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#31169}
2020-05-05 15:54:46 +02:00
|
|
|
&frame_width,
|
|
|
|
|
&frame_height,
|
|
|
|
|
&frames_per_second,
|
|
|
|
|
&frames_sent,
|
|
|
|
|
&huge_frames_sent,
|
2019-05-16 18:38:20 +02:00
|
|
|
&total_packet_send_delay,
|
2019-05-28 17:42:38 +02:00
|
|
|
&quality_limitation_reason,
|
2019-09-09 11:26:45 +02:00
|
|
|
&quality_limitation_resolution_changes,
|
2019-08-16 13:09:51 +02:00
|
|
|
&content_type,
|
|
|
|
|
&encoder_implementation)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-11-01 01:50:46 -07:00
|
|
|
|
|
|
|
|
RTCOutboundRTPStreamStats::RTCOutboundRTPStreamStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCOutboundRTPStreamStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCOutboundRTPStreamStats::RTCOutboundRTPStreamStats(std::string&& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCRTPStreamStats(std::move(id), timestamp_us),
|
2019-05-22 15:49:42 +02:00
|
|
|
media_source_id("mediaSourceId"),
|
2019-12-19 13:27:27 +01:00
|
|
|
remote_id("remoteId"),
|
Reland "Improve outbound-rtp statistics for simulcast"
This reverts commit 9a925c9ce33a6ccdd11b545b11ba68e985c2a65d.
Reason for revert: The original CL is updated in PS #2 to
fix the googRtt issue which was that when the legacy sender
stats were put in "aggregated_senders" we forgot to update
rtt_ms the same way that we do it for "senders".
Original change's description:
> Revert "Improve outbound-rtp statistics for simulcast"
>
> This reverts commit da6cda839dac7d9d18eba8d365188fa94831e0b1.
>
> Reason for revert: Breaks googRtt in legacy getStats API
>
> Original change's description:
> > Improve outbound-rtp statistics for simulcast
> >
> > Bug: webrtc:9547
> > Change-Id: Iec4eb976aa11ee743805425bedb77dcea7c2c9be
> > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/168120
> > Reviewed-by: Sebastian Jansson <srte@webrtc.org>
> > Reviewed-by: Erik Språng <sprang@webrtc.org>
> > Reviewed-by: Henrik Boström <hbos@webrtc.org>
> > Reviewed-by: Harald Alvestrand <hta@webrtc.org>
> > Commit-Queue: Eldar Rello <elrello@microsoft.com>
> > Cr-Commit-Position: refs/heads/master@{#31097}
>
> TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
>
> # Not skipping CQ checks because original CL landed > 1 day ago.
>
> Bug: webrtc:9547
> Change-Id: I06673328c2a5293a7eef03b3aaf2ded9d13df1b3
> Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174443
> Reviewed-by: Henrik Boström <hbos@webrtc.org>
> Commit-Queue: Henrik Boström <hbos@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#31165}
TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
# Not skipping CQ checks because this is a reland.
Bug: webrtc:9547
Change-Id: I723744c496c3c65f95ab6a8940862c8b9f544338
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174480
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#31169}
2020-05-05 15:54:46 +02:00
|
|
|
rid("rid"),
|
2016-11-01 01:50:46 -07:00
|
|
|
packets_sent("packetsSent"),
|
2019-04-17 13:51:53 +02:00
|
|
|
retransmitted_packets_sent("retransmittedPacketsSent"),
|
2016-11-01 01:50:46 -07:00
|
|
|
bytes_sent("bytesSent"),
|
2019-10-09 15:01:33 +02:00
|
|
|
header_bytes_sent("headerBytesSent"),
|
2019-04-17 13:51:53 +02:00
|
|
|
retransmitted_bytes_sent("retransmittedBytesSent"),
|
2016-11-01 01:50:46 -07:00
|
|
|
target_bitrate("targetBitrate"),
|
2019-04-08 16:14:23 +02:00
|
|
|
frames_encoded("framesEncoded"),
|
2019-06-27 14:29:34 +02:00
|
|
|
key_frames_encoded("keyFramesEncoded"),
|
2019-04-09 13:59:31 +02:00
|
|
|
total_encode_time("totalEncodeTime"),
|
2019-05-20 15:15:38 +02:00
|
|
|
total_encoded_bytes_target("totalEncodedBytesTarget"),
|
Reland "Improve outbound-rtp statistics for simulcast"
This reverts commit 9a925c9ce33a6ccdd11b545b11ba68e985c2a65d.
Reason for revert: The original CL is updated in PS #2 to
fix the googRtt issue which was that when the legacy sender
stats were put in "aggregated_senders" we forgot to update
rtt_ms the same way that we do it for "senders".
Original change's description:
> Revert "Improve outbound-rtp statistics for simulcast"
>
> This reverts commit da6cda839dac7d9d18eba8d365188fa94831e0b1.
>
> Reason for revert: Breaks googRtt in legacy getStats API
>
> Original change's description:
> > Improve outbound-rtp statistics for simulcast
> >
> > Bug: webrtc:9547
> > Change-Id: Iec4eb976aa11ee743805425bedb77dcea7c2c9be
> > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/168120
> > Reviewed-by: Sebastian Jansson <srte@webrtc.org>
> > Reviewed-by: Erik Språng <sprang@webrtc.org>
> > Reviewed-by: Henrik Boström <hbos@webrtc.org>
> > Reviewed-by: Harald Alvestrand <hta@webrtc.org>
> > Commit-Queue: Eldar Rello <elrello@microsoft.com>
> > Cr-Commit-Position: refs/heads/master@{#31097}
>
> TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
>
> # Not skipping CQ checks because original CL landed > 1 day ago.
>
> Bug: webrtc:9547
> Change-Id: I06673328c2a5293a7eef03b3aaf2ded9d13df1b3
> Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174443
> Reviewed-by: Henrik Boström <hbos@webrtc.org>
> Commit-Queue: Henrik Boström <hbos@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#31165}
TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
# Not skipping CQ checks because this is a reland.
Bug: webrtc:9547
Change-Id: I723744c496c3c65f95ab6a8940862c8b9f544338
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174480
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#31169}
2020-05-05 15:54:46 +02:00
|
|
|
frame_width("frameWidth"),
|
|
|
|
|
frame_height("frameHeight"),
|
|
|
|
|
frames_per_second("framesPerSecond"),
|
|
|
|
|
frames_sent("framesSent"),
|
|
|
|
|
huge_frames_sent("hugeFramesSent"),
|
2019-05-16 18:38:20 +02:00
|
|
|
total_packet_send_delay("totalPacketSendDelay"),
|
2019-05-28 17:42:38 +02:00
|
|
|
quality_limitation_reason("qualityLimitationReason"),
|
2019-09-09 11:26:45 +02:00
|
|
|
quality_limitation_resolution_changes(
|
|
|
|
|
"qualityLimitationResolutionChanges"),
|
2019-08-16 13:09:51 +02:00
|
|
|
content_type("contentType"),
|
|
|
|
|
encoder_implementation("encoderImplementation") {}
|
2016-11-01 01:50:46 -07:00
|
|
|
|
|
|
|
|
RTCOutboundRTPStreamStats::RTCOutboundRTPStreamStats(
|
|
|
|
|
const RTCOutboundRTPStreamStats& other)
|
|
|
|
|
: RTCRTPStreamStats(other),
|
2019-05-22 15:49:42 +02:00
|
|
|
media_source_id(other.media_source_id),
|
2019-12-19 13:27:27 +01:00
|
|
|
remote_id(other.remote_id),
|
Reland "Improve outbound-rtp statistics for simulcast"
This reverts commit 9a925c9ce33a6ccdd11b545b11ba68e985c2a65d.
Reason for revert: The original CL is updated in PS #2 to
fix the googRtt issue which was that when the legacy sender
stats were put in "aggregated_senders" we forgot to update
rtt_ms the same way that we do it for "senders".
Original change's description:
> Revert "Improve outbound-rtp statistics for simulcast"
>
> This reverts commit da6cda839dac7d9d18eba8d365188fa94831e0b1.
>
> Reason for revert: Breaks googRtt in legacy getStats API
>
> Original change's description:
> > Improve outbound-rtp statistics for simulcast
> >
> > Bug: webrtc:9547
> > Change-Id: Iec4eb976aa11ee743805425bedb77dcea7c2c9be
> > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/168120
> > Reviewed-by: Sebastian Jansson <srte@webrtc.org>
> > Reviewed-by: Erik Språng <sprang@webrtc.org>
> > Reviewed-by: Henrik Boström <hbos@webrtc.org>
> > Reviewed-by: Harald Alvestrand <hta@webrtc.org>
> > Commit-Queue: Eldar Rello <elrello@microsoft.com>
> > Cr-Commit-Position: refs/heads/master@{#31097}
>
> TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
>
> # Not skipping CQ checks because original CL landed > 1 day ago.
>
> Bug: webrtc:9547
> Change-Id: I06673328c2a5293a7eef03b3aaf2ded9d13df1b3
> Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174443
> Reviewed-by: Henrik Boström <hbos@webrtc.org>
> Commit-Queue: Henrik Boström <hbos@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#31165}
TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
# Not skipping CQ checks because this is a reland.
Bug: webrtc:9547
Change-Id: I723744c496c3c65f95ab6a8940862c8b9f544338
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174480
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#31169}
2020-05-05 15:54:46 +02:00
|
|
|
rid(other.rid),
|
2016-11-01 01:50:46 -07:00
|
|
|
packets_sent(other.packets_sent),
|
2019-04-17 13:51:53 +02:00
|
|
|
retransmitted_packets_sent(other.retransmitted_packets_sent),
|
2016-11-01 01:50:46 -07:00
|
|
|
bytes_sent(other.bytes_sent),
|
2019-10-09 15:01:33 +02:00
|
|
|
header_bytes_sent(other.header_bytes_sent),
|
2019-04-17 13:51:53 +02:00
|
|
|
retransmitted_bytes_sent(other.retransmitted_bytes_sent),
|
2016-11-01 01:50:46 -07:00
|
|
|
target_bitrate(other.target_bitrate),
|
2019-04-08 16:14:23 +02:00
|
|
|
frames_encoded(other.frames_encoded),
|
2019-06-27 14:29:34 +02:00
|
|
|
key_frames_encoded(other.key_frames_encoded),
|
2019-04-09 13:59:31 +02:00
|
|
|
total_encode_time(other.total_encode_time),
|
2019-05-20 15:15:38 +02:00
|
|
|
total_encoded_bytes_target(other.total_encoded_bytes_target),
|
Reland "Improve outbound-rtp statistics for simulcast"
This reverts commit 9a925c9ce33a6ccdd11b545b11ba68e985c2a65d.
Reason for revert: The original CL is updated in PS #2 to
fix the googRtt issue which was that when the legacy sender
stats were put in "aggregated_senders" we forgot to update
rtt_ms the same way that we do it for "senders".
Original change's description:
> Revert "Improve outbound-rtp statistics for simulcast"
>
> This reverts commit da6cda839dac7d9d18eba8d365188fa94831e0b1.
>
> Reason for revert: Breaks googRtt in legacy getStats API
>
> Original change's description:
> > Improve outbound-rtp statistics for simulcast
> >
> > Bug: webrtc:9547
> > Change-Id: Iec4eb976aa11ee743805425bedb77dcea7c2c9be
> > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/168120
> > Reviewed-by: Sebastian Jansson <srte@webrtc.org>
> > Reviewed-by: Erik Språng <sprang@webrtc.org>
> > Reviewed-by: Henrik Boström <hbos@webrtc.org>
> > Reviewed-by: Harald Alvestrand <hta@webrtc.org>
> > Commit-Queue: Eldar Rello <elrello@microsoft.com>
> > Cr-Commit-Position: refs/heads/master@{#31097}
>
> TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
>
> # Not skipping CQ checks because original CL landed > 1 day ago.
>
> Bug: webrtc:9547
> Change-Id: I06673328c2a5293a7eef03b3aaf2ded9d13df1b3
> Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174443
> Reviewed-by: Henrik Boström <hbos@webrtc.org>
> Commit-Queue: Henrik Boström <hbos@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#31165}
TBR=hbos@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,srte@webrtc.org,hta@webrtc.org,elrello@microsoft.com
# Not skipping CQ checks because this is a reland.
Bug: webrtc:9547
Change-Id: I723744c496c3c65f95ab6a8940862c8b9f544338
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/174480
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#31169}
2020-05-05 15:54:46 +02:00
|
|
|
frame_width(other.frame_width),
|
|
|
|
|
frame_height(other.frame_height),
|
|
|
|
|
frames_per_second(other.frames_per_second),
|
|
|
|
|
frames_sent(other.frames_sent),
|
|
|
|
|
huge_frames_sent(other.huge_frames_sent),
|
2019-05-16 18:38:20 +02:00
|
|
|
total_packet_send_delay(other.total_packet_send_delay),
|
2019-05-28 17:42:38 +02:00
|
|
|
quality_limitation_reason(other.quality_limitation_reason),
|
2019-09-09 11:26:45 +02:00
|
|
|
quality_limitation_resolution_changes(
|
|
|
|
|
other.quality_limitation_resolution_changes),
|
2019-08-16 13:09:51 +02:00
|
|
|
content_type(other.content_type),
|
|
|
|
|
encoder_implementation(other.encoder_implementation) {}
|
2016-11-01 01:50:46 -07:00
|
|
|
|
|
|
|
|
RTCOutboundRTPStreamStats::~RTCOutboundRTPStreamStats() {}
|
|
|
|
|
|
Implement RTCRemoteInboundRtpStreamStats for both audio and video.
This implements the essentials of RTCRemoteInboundRtpStreamStats. This
includes:
- ssrc
- transportId
- codecId
- packetsLost
- jitter
- localId
- roundTripTime
https://w3c.github.io/webrtc-stats/#remoteinboundrtpstats-dict*
The following members are not implemented because they require more
work...
- From RTCReceivedRtpStreamStats: packetsReceived, packetsDiscarded,
packetsRepaired, burstPacketsLost, burstPacketsDiscarded,
burstLossCount, burstDiscardCount, burstLossRate, burstDiscardRate,
gapLossRate and gapDiscardRate.
- From RTCRemoteInboundRtpStreamStats: fractionLost.
Bug: webrtc:10455, webrtc:10456
Change-Id: If2ab0da7105d8c93bba58e14aa93bd22ffe57f1d
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/138067
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#28073}
2019-05-27 13:40:25 +02:00
|
|
|
// clang-format off
|
|
|
|
|
WEBRTC_RTCSTATS_IMPL(
|
|
|
|
|
RTCRemoteInboundRtpStreamStats, RTCStats, "remote-inbound-rtp",
|
|
|
|
|
&ssrc,
|
|
|
|
|
&kind,
|
|
|
|
|
&transport_id,
|
|
|
|
|
&codec_id,
|
|
|
|
|
&packets_lost,
|
|
|
|
|
&jitter,
|
|
|
|
|
&local_id,
|
|
|
|
|
&round_trip_time)
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
RTCRemoteInboundRtpStreamStats::RTCRemoteInboundRtpStreamStats(
|
|
|
|
|
const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCRemoteInboundRtpStreamStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCRemoteInboundRtpStreamStats::RTCRemoteInboundRtpStreamStats(
|
|
|
|
|
std::string&& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
ssrc("ssrc"),
|
|
|
|
|
kind("kind"),
|
|
|
|
|
transport_id("transportId"),
|
|
|
|
|
codec_id("codecId"),
|
|
|
|
|
packets_lost("packetsLost"),
|
|
|
|
|
jitter("jitter"),
|
|
|
|
|
local_id("localId"),
|
|
|
|
|
round_trip_time("roundTripTime") {}
|
|
|
|
|
|
|
|
|
|
RTCRemoteInboundRtpStreamStats::RTCRemoteInboundRtpStreamStats(
|
|
|
|
|
const RTCRemoteInboundRtpStreamStats& other)
|
|
|
|
|
: RTCStats(other),
|
|
|
|
|
ssrc(other.ssrc),
|
|
|
|
|
kind(other.kind),
|
|
|
|
|
transport_id(other.transport_id),
|
|
|
|
|
codec_id(other.codec_id),
|
|
|
|
|
packets_lost(other.packets_lost),
|
|
|
|
|
jitter(other.jitter),
|
|
|
|
|
local_id(other.local_id),
|
|
|
|
|
round_trip_time(other.round_trip_time) {}
|
|
|
|
|
|
|
|
|
|
RTCRemoteInboundRtpStreamStats::~RTCRemoteInboundRtpStreamStats() {}
|
|
|
|
|
|
2019-05-22 15:49:42 +02:00
|
|
|
// clang-format off
|
|
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCMediaSourceStats, RTCStats, "parent-media-source",
|
|
|
|
|
&track_identifier,
|
|
|
|
|
&kind)
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
RTCMediaSourceStats::RTCMediaSourceStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCMediaSourceStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCMediaSourceStats::RTCMediaSourceStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
track_identifier("trackIdentifier"),
|
|
|
|
|
kind("kind") {}
|
|
|
|
|
|
|
|
|
|
RTCMediaSourceStats::RTCMediaSourceStats(const RTCMediaSourceStats& other)
|
|
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
track_identifier(other.track_identifier),
|
|
|
|
|
kind(other.kind) {}
|
|
|
|
|
|
|
|
|
|
RTCMediaSourceStats::~RTCMediaSourceStats() {}
|
|
|
|
|
|
|
|
|
|
// clang-format off
|
[getStats] Implement "media-source" audio levels, fixing Chrome bug.
Implements RTCAudioSourceStats members:
- audioLevel
- totalAudioEnergy
- totalSamplesDuration
In this CL description these are collectively referred to as the audio
levels.
The audio levels are removed from sending "track" stats (in Chrome,
these are now reported as undefined instead of 0).
Background:
For sending tracks, audio levels were always reported as 0 in Chrome
(https://crbug.com/736403), while audio levels were correctly reported
for receiving tracks. This problem affected the standard getStats() but
not the legacy getStats(), blocking some people from migrating. This
was likely not a problem in native third_party/webrtc code because the
delivery of audio frames from device to send-stream uses a different
code path outside of chromium.
A recent PR (https://github.com/w3c/webrtc-stats/pull/451) moved the
send-side audio levels to the RTCAudioSourceStats, while keeping the
receive-side audio levels on the "track" stats. This allows an
implementation to report the audio levels even if samples are not sent
onto the network (such as if an ICE connection has not been established
yet), reflecting some of the current implementation.
Changes:
1. Audio levels are added to RTCAudioSourceStats. Send-side audio
"track" stats are left undefined. Receive-side audio "track" stats
are not changed in this CL and continue to work.
2. Audio level computation is moved from the AudioState and
AudioTransportImpl to the AudioSendStream. This is because a) the
AudioTransportImpl::RecordedDataIsAvailable() code path is not
exercised in chromium, and b) audio levels should, per-spec, not be
calculated on a per-call basis, for which the AudioState is defined.
3. The audio level computation is now performed in
AudioSendStream::SendAudioData(), a code path used by both native
and chromium code.
4. Comments are added to document behavior of existing code, such as
AudioLevel and AudioSendStream::SendAudioData().
Note:
In this CL, just like before this CL, audio level is only calculated
after an AudioSendStream has been created. This means that before an
O/A negotiation, audio levels are unavailable.
According to spec, if we have an audio source, we should have audio
levels. An immediate solution to this would have been to calculate the
audio level at pc/rtp_sender.cc. The problem is that the
LocalAudioSinkAdapter::OnData() code path, while exercised in chromium,
is not exercised in native code. The issue of calculating audio levels
on a per-source bases rather than on a per-send stream basis is left to
https://crbug.com/webrtc/10771, an existing "media-source" bug.
This CL can be verified manually in Chrome at:
https://codepen.io/anon/pen/vqRGyq
Bug: chromium:736403, webrtc:10771
Change-Id: I8036cd9984f3b187c3177470a8c0d6670a201a5a
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/143789
Reviewed-by: Oskar Sundbom <ossu@webrtc.org>
Reviewed-by: Stefan Holmer <stefan@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#28480}
2019-07-03 17:11:10 +02:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCAudioSourceStats, RTCMediaSourceStats, "media-source",
|
|
|
|
|
&audio_level,
|
|
|
|
|
&total_audio_energy,
|
|
|
|
|
&total_samples_duration)
|
2019-05-22 15:49:42 +02:00
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
RTCAudioSourceStats::RTCAudioSourceStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCAudioSourceStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCAudioSourceStats::RTCAudioSourceStats(std::string&& id, int64_t timestamp_us)
|
[getStats] Implement "media-source" audio levels, fixing Chrome bug.
Implements RTCAudioSourceStats members:
- audioLevel
- totalAudioEnergy
- totalSamplesDuration
In this CL description these are collectively referred to as the audio
levels.
The audio levels are removed from sending "track" stats (in Chrome,
these are now reported as undefined instead of 0).
Background:
For sending tracks, audio levels were always reported as 0 in Chrome
(https://crbug.com/736403), while audio levels were correctly reported
for receiving tracks. This problem affected the standard getStats() but
not the legacy getStats(), blocking some people from migrating. This
was likely not a problem in native third_party/webrtc code because the
delivery of audio frames from device to send-stream uses a different
code path outside of chromium.
A recent PR (https://github.com/w3c/webrtc-stats/pull/451) moved the
send-side audio levels to the RTCAudioSourceStats, while keeping the
receive-side audio levels on the "track" stats. This allows an
implementation to report the audio levels even if samples are not sent
onto the network (such as if an ICE connection has not been established
yet), reflecting some of the current implementation.
Changes:
1. Audio levels are added to RTCAudioSourceStats. Send-side audio
"track" stats are left undefined. Receive-side audio "track" stats
are not changed in this CL and continue to work.
2. Audio level computation is moved from the AudioState and
AudioTransportImpl to the AudioSendStream. This is because a) the
AudioTransportImpl::RecordedDataIsAvailable() code path is not
exercised in chromium, and b) audio levels should, per-spec, not be
calculated on a per-call basis, for which the AudioState is defined.
3. The audio level computation is now performed in
AudioSendStream::SendAudioData(), a code path used by both native
and chromium code.
4. Comments are added to document behavior of existing code, such as
AudioLevel and AudioSendStream::SendAudioData().
Note:
In this CL, just like before this CL, audio level is only calculated
after an AudioSendStream has been created. This means that before an
O/A negotiation, audio levels are unavailable.
According to spec, if we have an audio source, we should have audio
levels. An immediate solution to this would have been to calculate the
audio level at pc/rtp_sender.cc. The problem is that the
LocalAudioSinkAdapter::OnData() code path, while exercised in chromium,
is not exercised in native code. The issue of calculating audio levels
on a per-source bases rather than on a per-send stream basis is left to
https://crbug.com/webrtc/10771, an existing "media-source" bug.
This CL can be verified manually in Chrome at:
https://codepen.io/anon/pen/vqRGyq
Bug: chromium:736403, webrtc:10771
Change-Id: I8036cd9984f3b187c3177470a8c0d6670a201a5a
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/143789
Reviewed-by: Oskar Sundbom <ossu@webrtc.org>
Reviewed-by: Stefan Holmer <stefan@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#28480}
2019-07-03 17:11:10 +02:00
|
|
|
: RTCMediaSourceStats(std::move(id), timestamp_us),
|
|
|
|
|
audio_level("audioLevel"),
|
|
|
|
|
total_audio_energy("totalAudioEnergy"),
|
|
|
|
|
total_samples_duration("totalSamplesDuration") {}
|
2019-05-22 15:49:42 +02:00
|
|
|
|
|
|
|
|
RTCAudioSourceStats::RTCAudioSourceStats(const RTCAudioSourceStats& other)
|
[getStats] Implement "media-source" audio levels, fixing Chrome bug.
Implements RTCAudioSourceStats members:
- audioLevel
- totalAudioEnergy
- totalSamplesDuration
In this CL description these are collectively referred to as the audio
levels.
The audio levels are removed from sending "track" stats (in Chrome,
these are now reported as undefined instead of 0).
Background:
For sending tracks, audio levels were always reported as 0 in Chrome
(https://crbug.com/736403), while audio levels were correctly reported
for receiving tracks. This problem affected the standard getStats() but
not the legacy getStats(), blocking some people from migrating. This
was likely not a problem in native third_party/webrtc code because the
delivery of audio frames from device to send-stream uses a different
code path outside of chromium.
A recent PR (https://github.com/w3c/webrtc-stats/pull/451) moved the
send-side audio levels to the RTCAudioSourceStats, while keeping the
receive-side audio levels on the "track" stats. This allows an
implementation to report the audio levels even if samples are not sent
onto the network (such as if an ICE connection has not been established
yet), reflecting some of the current implementation.
Changes:
1. Audio levels are added to RTCAudioSourceStats. Send-side audio
"track" stats are left undefined. Receive-side audio "track" stats
are not changed in this CL and continue to work.
2. Audio level computation is moved from the AudioState and
AudioTransportImpl to the AudioSendStream. This is because a) the
AudioTransportImpl::RecordedDataIsAvailable() code path is not
exercised in chromium, and b) audio levels should, per-spec, not be
calculated on a per-call basis, for which the AudioState is defined.
3. The audio level computation is now performed in
AudioSendStream::SendAudioData(), a code path used by both native
and chromium code.
4. Comments are added to document behavior of existing code, such as
AudioLevel and AudioSendStream::SendAudioData().
Note:
In this CL, just like before this CL, audio level is only calculated
after an AudioSendStream has been created. This means that before an
O/A negotiation, audio levels are unavailable.
According to spec, if we have an audio source, we should have audio
levels. An immediate solution to this would have been to calculate the
audio level at pc/rtp_sender.cc. The problem is that the
LocalAudioSinkAdapter::OnData() code path, while exercised in chromium,
is not exercised in native code. The issue of calculating audio levels
on a per-source bases rather than on a per-send stream basis is left to
https://crbug.com/webrtc/10771, an existing "media-source" bug.
This CL can be verified manually in Chrome at:
https://codepen.io/anon/pen/vqRGyq
Bug: chromium:736403, webrtc:10771
Change-Id: I8036cd9984f3b187c3177470a8c0d6670a201a5a
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/143789
Reviewed-by: Oskar Sundbom <ossu@webrtc.org>
Reviewed-by: Stefan Holmer <stefan@webrtc.org>
Commit-Queue: Henrik Boström <hbos@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#28480}
2019-07-03 17:11:10 +02:00
|
|
|
: RTCMediaSourceStats(other),
|
|
|
|
|
audio_level(other.audio_level),
|
|
|
|
|
total_audio_energy(other.total_audio_energy),
|
|
|
|
|
total_samples_duration(other.total_samples_duration) {}
|
2019-05-22 15:49:42 +02:00
|
|
|
|
|
|
|
|
RTCAudioSourceStats::~RTCAudioSourceStats() {}
|
|
|
|
|
|
|
|
|
|
// clang-format off
|
|
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCVideoSourceStats, RTCMediaSourceStats, "media-source",
|
|
|
|
|
&width,
|
|
|
|
|
&height,
|
|
|
|
|
&frames,
|
|
|
|
|
&frames_per_second)
|
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
|
|
RTCVideoSourceStats::RTCVideoSourceStats(const std::string& id,
|
|
|
|
|
int64_t timestamp_us)
|
|
|
|
|
: RTCVideoSourceStats(std::string(id), timestamp_us) {}
|
|
|
|
|
|
|
|
|
|
RTCVideoSourceStats::RTCVideoSourceStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCMediaSourceStats(std::move(id), timestamp_us),
|
|
|
|
|
width("width"),
|
|
|
|
|
height("height"),
|
|
|
|
|
frames("frames"),
|
|
|
|
|
frames_per_second("framesPerSecond") {}
|
|
|
|
|
|
|
|
|
|
RTCVideoSourceStats::RTCVideoSourceStats(const RTCVideoSourceStats& other)
|
|
|
|
|
: RTCMediaSourceStats(other),
|
|
|
|
|
width(other.width),
|
|
|
|
|
height(other.height),
|
|
|
|
|
frames(other.frames),
|
|
|
|
|
frames_per_second(other.frames_per_second) {}
|
|
|
|
|
|
|
|
|
|
RTCVideoSourceStats::~RTCVideoSourceStats() {}
|
|
|
|
|
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format off
|
2016-10-24 04:00:05 -07:00
|
|
|
WEBRTC_RTCSTATS_IMPL(RTCTransportStats, RTCStats, "transport",
|
2016-10-18 12:48:31 -07:00
|
|
|
&bytes_sent,
|
2016-10-24 04:00:05 -07:00
|
|
|
&bytes_received,
|
|
|
|
|
&rtcp_transport_stats_id,
|
2017-01-16 07:38:02 -08:00
|
|
|
&dtls_state,
|
2016-10-24 04:00:05 -07:00
|
|
|
&selected_candidate_pair_id,
|
|
|
|
|
&local_certificate_id,
|
2019-08-28 08:10:27 +02:00
|
|
|
&remote_certificate_id,
|
2019-10-28 09:51:17 +01:00
|
|
|
&tls_version,
|
|
|
|
|
&dtls_cipher,
|
|
|
|
|
&srtp_cipher,
|
2019-08-28 08:10:27 +02:00
|
|
|
&selected_candidate_pair_changes)
|
2017-08-18 09:40:25 -07:00
|
|
|
// clang-format on
|
2016-10-18 12:48:31 -07:00
|
|
|
|
2016-10-24 04:00:05 -07:00
|
|
|
RTCTransportStats::RTCTransportStats(const std::string& id,
|
2016-10-18 12:48:31 -07:00
|
|
|
int64_t timestamp_us)
|
2016-10-24 04:00:05 -07:00
|
|
|
: RTCTransportStats(std::string(id), timestamp_us) {}
|
2016-10-18 12:48:31 -07:00
|
|
|
|
|
|
|
|
RTCTransportStats::RTCTransportStats(std::string&& id, int64_t timestamp_us)
|
|
|
|
|
: RTCStats(std::move(id), timestamp_us),
|
|
|
|
|
bytes_sent("bytesSent"),
|
2016-10-24 04:00:05 -07:00
|
|
|
bytes_received("bytesReceived"),
|
|
|
|
|
rtcp_transport_stats_id("rtcpTransportStatsId"),
|
2017-01-16 07:38:02 -08:00
|
|
|
dtls_state("dtlsState"),
|
2016-10-24 04:00:05 -07:00
|
|
|
selected_candidate_pair_id("selectedCandidatePairId"),
|
|
|
|
|
local_certificate_id("localCertificateId"),
|
2019-08-28 08:10:27 +02:00
|
|
|
remote_certificate_id("remoteCertificateId"),
|
2019-10-28 09:51:17 +01:00
|
|
|
tls_version("tlsVersion"),
|
|
|
|
|
dtls_cipher("dtlsCipher"),
|
|
|
|
|
srtp_cipher("srtpCipher"),
|
2019-08-28 08:10:27 +02:00
|
|
|
selected_candidate_pair_changes("selectedCandidatePairChanges") {}
|
2016-10-18 12:48:31 -07:00
|
|
|
|
2016-10-24 04:00:05 -07:00
|
|
|
RTCTransportStats::RTCTransportStats(const RTCTransportStats& other)
|
2016-10-18 12:48:31 -07:00
|
|
|
: RTCStats(other.id(), other.timestamp_us()),
|
|
|
|
|
bytes_sent(other.bytes_sent),
|
2016-10-24 04:00:05 -07:00
|
|
|
bytes_received(other.bytes_received),
|
|
|
|
|
rtcp_transport_stats_id(other.rtcp_transport_stats_id),
|
2017-01-16 07:38:02 -08:00
|
|
|
dtls_state(other.dtls_state),
|
2016-10-24 04:00:05 -07:00
|
|
|
selected_candidate_pair_id(other.selected_candidate_pair_id),
|
|
|
|
|
local_certificate_id(other.local_certificate_id),
|
2019-08-28 08:10:27 +02:00
|
|
|
remote_certificate_id(other.remote_certificate_id),
|
2019-10-28 09:51:17 +01:00
|
|
|
tls_version(other.tls_version),
|
|
|
|
|
dtls_cipher(other.dtls_cipher),
|
|
|
|
|
srtp_cipher(other.srtp_cipher),
|
2019-08-28 08:10:27 +02:00
|
|
|
selected_candidate_pair_changes(other.selected_candidate_pair_changes) {}
|
2016-10-06 02:06:10 -07:00
|
|
|
|
2016-10-24 04:00:05 -07:00
|
|
|
RTCTransportStats::~RTCTransportStats() {}
|
2016-10-06 02:06:10 -07:00
|
|
|
|
2016-08-30 14:04:35 -07:00
|
|
|
} // namespace webrtc
|