1*d9f75844SAndroid Build Coastguard Worker /*
2*d9f75844SAndroid Build Coastguard Worker * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
3*d9f75844SAndroid Build Coastguard Worker *
4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker */
10*d9f75844SAndroid Build Coastguard Worker
11*d9f75844SAndroid Build Coastguard Worker #include "call/video_receive_stream.h"
12*d9f75844SAndroid Build Coastguard Worker
13*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/strings/string_builder.h"
14*d9f75844SAndroid Build Coastguard Worker
15*d9f75844SAndroid Build Coastguard Worker namespace webrtc {
16*d9f75844SAndroid Build Coastguard Worker
Decoder(SdpVideoFormat video_format,int payload_type)17*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Decoder::Decoder(SdpVideoFormat video_format,
18*d9f75844SAndroid Build Coastguard Worker int payload_type)
19*d9f75844SAndroid Build Coastguard Worker : video_format(std::move(video_format)), payload_type(payload_type) {}
Decoder()20*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Decoder::Decoder() : video_format("Unset") {}
21*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Decoder::Decoder(const Decoder&) = default;
22*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Decoder::~Decoder() = default;
23*d9f75844SAndroid Build Coastguard Worker
operator ==(const Decoder & other) const24*d9f75844SAndroid Build Coastguard Worker bool VideoReceiveStreamInterface::Decoder::operator==(
25*d9f75844SAndroid Build Coastguard Worker const Decoder& other) const {
26*d9f75844SAndroid Build Coastguard Worker return payload_type == other.payload_type &&
27*d9f75844SAndroid Build Coastguard Worker video_format == other.video_format;
28*d9f75844SAndroid Build Coastguard Worker }
29*d9f75844SAndroid Build Coastguard Worker
ToString() const30*d9f75844SAndroid Build Coastguard Worker std::string VideoReceiveStreamInterface::Decoder::ToString() const {
31*d9f75844SAndroid Build Coastguard Worker char buf[1024];
32*d9f75844SAndroid Build Coastguard Worker rtc::SimpleStringBuilder ss(buf);
33*d9f75844SAndroid Build Coastguard Worker ss << "{payload_type: " << payload_type;
34*d9f75844SAndroid Build Coastguard Worker ss << ", payload_name: " << video_format.name;
35*d9f75844SAndroid Build Coastguard Worker ss << ", codec_params: {";
36*d9f75844SAndroid Build Coastguard Worker for (auto it = video_format.parameters.begin();
37*d9f75844SAndroid Build Coastguard Worker it != video_format.parameters.end(); ++it) {
38*d9f75844SAndroid Build Coastguard Worker if (it != video_format.parameters.begin()) {
39*d9f75844SAndroid Build Coastguard Worker ss << ", ";
40*d9f75844SAndroid Build Coastguard Worker }
41*d9f75844SAndroid Build Coastguard Worker ss << it->first << ": " << it->second;
42*d9f75844SAndroid Build Coastguard Worker }
43*d9f75844SAndroid Build Coastguard Worker ss << '}';
44*d9f75844SAndroid Build Coastguard Worker ss << '}';
45*d9f75844SAndroid Build Coastguard Worker
46*d9f75844SAndroid Build Coastguard Worker return ss.str();
47*d9f75844SAndroid Build Coastguard Worker }
48*d9f75844SAndroid Build Coastguard Worker
49*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Stats::Stats() = default;
50*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Stats::~Stats() = default;
51*d9f75844SAndroid Build Coastguard Worker
ToString(int64_t time_ms) const52*d9f75844SAndroid Build Coastguard Worker std::string VideoReceiveStreamInterface::Stats::ToString(
53*d9f75844SAndroid Build Coastguard Worker int64_t time_ms) const {
54*d9f75844SAndroid Build Coastguard Worker char buf[2048];
55*d9f75844SAndroid Build Coastguard Worker rtc::SimpleStringBuilder ss(buf);
56*d9f75844SAndroid Build Coastguard Worker ss << "VideoReceiveStreamInterface stats: " << time_ms << ", {ssrc: " << ssrc
57*d9f75844SAndroid Build Coastguard Worker << ", ";
58*d9f75844SAndroid Build Coastguard Worker ss << "total_bps: " << total_bitrate_bps << ", ";
59*d9f75844SAndroid Build Coastguard Worker ss << "width: " << width << ", ";
60*d9f75844SAndroid Build Coastguard Worker ss << "height: " << height << ", ";
61*d9f75844SAndroid Build Coastguard Worker ss << "key: " << frame_counts.key_frames << ", ";
62*d9f75844SAndroid Build Coastguard Worker ss << "delta: " << frame_counts.delta_frames << ", ";
63*d9f75844SAndroid Build Coastguard Worker ss << "frames_dropped: " << frames_dropped << ", ";
64*d9f75844SAndroid Build Coastguard Worker ss << "network_fps: " << network_frame_rate << ", ";
65*d9f75844SAndroid Build Coastguard Worker ss << "decode_fps: " << decode_frame_rate << ", ";
66*d9f75844SAndroid Build Coastguard Worker ss << "render_fps: " << render_frame_rate << ", ";
67*d9f75844SAndroid Build Coastguard Worker ss << "decode_ms: " << decode_ms << ", ";
68*d9f75844SAndroid Build Coastguard Worker ss << "max_decode_ms: " << max_decode_ms << ", ";
69*d9f75844SAndroid Build Coastguard Worker ss << "first_frame_received_to_decoded_ms: "
70*d9f75844SAndroid Build Coastguard Worker << first_frame_received_to_decoded_ms << ", ";
71*d9f75844SAndroid Build Coastguard Worker ss << "cur_delay_ms: " << current_delay_ms << ", ";
72*d9f75844SAndroid Build Coastguard Worker ss << "targ_delay_ms: " << target_delay_ms << ", ";
73*d9f75844SAndroid Build Coastguard Worker ss << "jb_delay_ms: " << jitter_buffer_ms << ", ";
74*d9f75844SAndroid Build Coastguard Worker ss << "jb_cumulative_delay_seconds: " << jitter_buffer_delay_seconds << ", ";
75*d9f75844SAndroid Build Coastguard Worker ss << "jb_emitted_count: " << jitter_buffer_emitted_count << ", ";
76*d9f75844SAndroid Build Coastguard Worker ss << "min_playout_delay_ms: " << min_playout_delay_ms << ", ";
77*d9f75844SAndroid Build Coastguard Worker ss << "sync_offset_ms: " << sync_offset_ms << ", ";
78*d9f75844SAndroid Build Coastguard Worker ss << "cum_loss: " << rtp_stats.packets_lost << ", ";
79*d9f75844SAndroid Build Coastguard Worker ss << "nack: " << rtcp_packet_type_counts.nack_packets << ", ";
80*d9f75844SAndroid Build Coastguard Worker ss << "fir: " << rtcp_packet_type_counts.fir_packets << ", ";
81*d9f75844SAndroid Build Coastguard Worker ss << "pli: " << rtcp_packet_type_counts.pli_packets;
82*d9f75844SAndroid Build Coastguard Worker ss << '}';
83*d9f75844SAndroid Build Coastguard Worker return ss.str();
84*d9f75844SAndroid Build Coastguard Worker }
85*d9f75844SAndroid Build Coastguard Worker
86*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::Config(const Config&) = default;
87*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::Config(Config&&) = default;
Config(Transport * rtcp_send_transport,VideoDecoderFactory * decoder_factory)88*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::Config(
89*d9f75844SAndroid Build Coastguard Worker Transport* rtcp_send_transport,
90*d9f75844SAndroid Build Coastguard Worker VideoDecoderFactory* decoder_factory)
91*d9f75844SAndroid Build Coastguard Worker : decoder_factory(decoder_factory),
92*d9f75844SAndroid Build Coastguard Worker rtcp_send_transport(rtcp_send_transport) {}
93*d9f75844SAndroid Build Coastguard Worker
94*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config&
95*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::operator=(Config&&) = default;
96*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::Config::~Config() = default;
97*d9f75844SAndroid Build Coastguard Worker
ToString() const98*d9f75844SAndroid Build Coastguard Worker std::string VideoReceiveStreamInterface::Config::ToString() const {
99*d9f75844SAndroid Build Coastguard Worker char buf[4 * 1024];
100*d9f75844SAndroid Build Coastguard Worker rtc::SimpleStringBuilder ss(buf);
101*d9f75844SAndroid Build Coastguard Worker ss << "{decoders: [";
102*d9f75844SAndroid Build Coastguard Worker for (size_t i = 0; i < decoders.size(); ++i) {
103*d9f75844SAndroid Build Coastguard Worker ss << decoders[i].ToString();
104*d9f75844SAndroid Build Coastguard Worker if (i != decoders.size() - 1)
105*d9f75844SAndroid Build Coastguard Worker ss << ", ";
106*d9f75844SAndroid Build Coastguard Worker }
107*d9f75844SAndroid Build Coastguard Worker ss << ']';
108*d9f75844SAndroid Build Coastguard Worker ss << ", rtp: " << rtp.ToString();
109*d9f75844SAndroid Build Coastguard Worker ss << ", renderer: " << (renderer ? "(renderer)" : "nullptr");
110*d9f75844SAndroid Build Coastguard Worker ss << ", render_delay_ms: " << render_delay_ms;
111*d9f75844SAndroid Build Coastguard Worker if (!sync_group.empty())
112*d9f75844SAndroid Build Coastguard Worker ss << ", sync_group: " << sync_group;
113*d9f75844SAndroid Build Coastguard Worker ss << '}';
114*d9f75844SAndroid Build Coastguard Worker
115*d9f75844SAndroid Build Coastguard Worker return ss.str();
116*d9f75844SAndroid Build Coastguard Worker }
117*d9f75844SAndroid Build Coastguard Worker
118*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::Rtp::Rtp() = default;
119*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::Rtp::Rtp(const Rtp&) = default;
120*d9f75844SAndroid Build Coastguard Worker VideoReceiveStreamInterface::Config::Rtp::~Rtp() = default;
121*d9f75844SAndroid Build Coastguard Worker
ToString() const122*d9f75844SAndroid Build Coastguard Worker std::string VideoReceiveStreamInterface::Config::Rtp::ToString() const {
123*d9f75844SAndroid Build Coastguard Worker char buf[2 * 1024];
124*d9f75844SAndroid Build Coastguard Worker rtc::SimpleStringBuilder ss(buf);
125*d9f75844SAndroid Build Coastguard Worker ss << "{remote_ssrc: " << remote_ssrc;
126*d9f75844SAndroid Build Coastguard Worker ss << ", local_ssrc: " << local_ssrc;
127*d9f75844SAndroid Build Coastguard Worker ss << ", rtcp_mode: "
128*d9f75844SAndroid Build Coastguard Worker << (rtcp_mode == RtcpMode::kCompound ? "RtcpMode::kCompound"
129*d9f75844SAndroid Build Coastguard Worker : "RtcpMode::kReducedSize");
130*d9f75844SAndroid Build Coastguard Worker ss << ", rtcp_xr: ";
131*d9f75844SAndroid Build Coastguard Worker ss << "{receiver_reference_time_report: "
132*d9f75844SAndroid Build Coastguard Worker << (rtcp_xr.receiver_reference_time_report ? "on" : "off");
133*d9f75844SAndroid Build Coastguard Worker ss << '}';
134*d9f75844SAndroid Build Coastguard Worker ss << ", transport_cc: " << (transport_cc ? "on" : "off");
135*d9f75844SAndroid Build Coastguard Worker ss << ", lntf: {enabled: " << (lntf.enabled ? "true" : "false") << '}';
136*d9f75844SAndroid Build Coastguard Worker ss << ", nack: {rtp_history_ms: " << nack.rtp_history_ms << '}';
137*d9f75844SAndroid Build Coastguard Worker ss << ", ulpfec_payload_type: " << ulpfec_payload_type;
138*d9f75844SAndroid Build Coastguard Worker ss << ", red_type: " << red_payload_type;
139*d9f75844SAndroid Build Coastguard Worker ss << ", rtx_ssrc: " << rtx_ssrc;
140*d9f75844SAndroid Build Coastguard Worker ss << ", rtx_payload_types: {";
141*d9f75844SAndroid Build Coastguard Worker for (auto& kv : rtx_associated_payload_types) {
142*d9f75844SAndroid Build Coastguard Worker ss << kv.first << " (pt) -> " << kv.second << " (apt), ";
143*d9f75844SAndroid Build Coastguard Worker }
144*d9f75844SAndroid Build Coastguard Worker ss << '}';
145*d9f75844SAndroid Build Coastguard Worker ss << ", raw_payload_types: {";
146*d9f75844SAndroid Build Coastguard Worker for (const auto& pt : raw_payload_types) {
147*d9f75844SAndroid Build Coastguard Worker ss << pt << ", ";
148*d9f75844SAndroid Build Coastguard Worker }
149*d9f75844SAndroid Build Coastguard Worker ss << '}';
150*d9f75844SAndroid Build Coastguard Worker ss << ", extensions: [";
151*d9f75844SAndroid Build Coastguard Worker for (size_t i = 0; i < extensions.size(); ++i) {
152*d9f75844SAndroid Build Coastguard Worker ss << extensions[i].ToString();
153*d9f75844SAndroid Build Coastguard Worker if (i != extensions.size() - 1)
154*d9f75844SAndroid Build Coastguard Worker ss << ", ";
155*d9f75844SAndroid Build Coastguard Worker }
156*d9f75844SAndroid Build Coastguard Worker ss << ']';
157*d9f75844SAndroid Build Coastguard Worker ss << '}';
158*d9f75844SAndroid Build Coastguard Worker return ss.str();
159*d9f75844SAndroid Build Coastguard Worker }
160*d9f75844SAndroid Build Coastguard Worker
161*d9f75844SAndroid Build Coastguard Worker } // namespace webrtc
162