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

Side by Side Diff: webrtc/api/rtcstatscollector.cc

Issue 2452043002: RTCInboundRTPStreamStats added. (Closed)
Patch Set: Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2016 The WebRTC Project Authors. All rights reserved. 2 * Copyright 2016 The WebRTC Project Authors. All rights reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
46 std::string RTCTransportStatsIDFromBaseChannel( 46 std::string RTCTransportStatsIDFromBaseChannel(
47 const ProxyTransportMap& proxy_to_transport, 47 const ProxyTransportMap& proxy_to_transport,
48 const cricket::BaseChannel& base_channel) { 48 const cricket::BaseChannel& base_channel) {
49 auto proxy_it = proxy_to_transport.find(base_channel.content_name()); 49 auto proxy_it = proxy_to_transport.find(base_channel.content_name());
50 if (proxy_it == proxy_to_transport.cend()) 50 if (proxy_it == proxy_to_transport.cend())
51 return ""; 51 return "";
52 return RTCTransportStatsIDFromTransportChannel( 52 return RTCTransportStatsIDFromTransportChannel(
53 proxy_it->second, cricket::ICE_CANDIDATE_COMPONENT_RTP); 53 proxy_it->second, cricket::ICE_CANDIDATE_COMPONENT_RTP);
54 } 54 }
55 55
56 std::string RTCInboundRTPStreamStatsIDFromSSRC(bool audio, uint32_t ssrc) {
57 return audio ? "RTCInboundRTPAudioStream_" + rtc::ToString<>(ssrc)
58 : "RTCInboundRTPVideoStream_" + rtc::ToString<>(ssrc);
59 }
60
56 std::string RTCOutboundRTPStreamStatsIDFromSSRC(bool audio, uint32_t ssrc) { 61 std::string RTCOutboundRTPStreamStatsIDFromSSRC(bool audio, uint32_t ssrc) {
57 return audio ? "RTCOutboundRTPAudioStream_" + rtc::ToString<>(ssrc) 62 return audio ? "RTCOutboundRTPAudioStream_" + rtc::ToString<>(ssrc)
58 : "RTCOutboundRTPVideoStream_" + rtc::ToString<>(ssrc); 63 : "RTCOutboundRTPVideoStream_" + rtc::ToString<>(ssrc);
59 } 64 }
60 65
61 const char* CandidateTypeToRTCIceCandidateType(const std::string& type) { 66 const char* CandidateTypeToRTCIceCandidateType(const std::string& type) {
62 if (type == cricket::LOCAL_PORT_TYPE) 67 if (type == cricket::LOCAL_PORT_TYPE)
63 return RTCIceCandidateType::kHost; 68 return RTCIceCandidateType::kHost;
64 if (type == cricket::STUN_PORT_TYPE) 69 if (type == cricket::STUN_PORT_TYPE)
65 return RTCIceCandidateType::kSrflx; 70 return RTCIceCandidateType::kSrflx;
(...skipping 15 matching lines...) Expand all
81 case DataChannelInterface::kClosing: 86 case DataChannelInterface::kClosing:
82 return RTCDataChannelState::kClosing; 87 return RTCDataChannelState::kClosing;
83 case DataChannelInterface::kClosed: 88 case DataChannelInterface::kClosed:
84 return RTCDataChannelState::kClosed; 89 return RTCDataChannelState::kClosed;
85 default: 90 default:
86 RTC_NOTREACHED(); 91 RTC_NOTREACHED();
87 return nullptr; 92 return nullptr;
88 } 93 }
89 } 94 }
90 95
96 void SetInboundRTPStreamStatsFromMediaReceiverInfo(
97 const cricket::MediaReceiverInfo& media_receiver_info,
98 RTCInboundRTPStreamStats* inbound_stats) {
99 RTC_DCHECK(inbound_stats);
100 inbound_stats->ssrc = rtc::ToString<>(media_receiver_info.ssrc());
101 // TODO(hbos): Support the remote case. crbug.com/657855
102 inbound_stats->is_remote = false;
103 // TODO(hbos): Set |codec_id| when we have |RTCCodecStats|. Maybe relevant:
104 // |media_receiver_info.codec_name|. crbug.com/657854, 657855, 659117
105 inbound_stats->packets_received =
106 static_cast<uint32_t>(media_receiver_info.packets_rcvd);
107 inbound_stats->bytes_received =
108 static_cast<uint64_t>(media_receiver_info.bytes_rcvd);
109 inbound_stats->fraction_lost =
110 static_cast<double>(media_receiver_info.fraction_lost);
111 }
112
113 void SetInboundRTPStreamStatsFromVoiceReceiverInfo(
114 const cricket::VoiceReceiverInfo& voice_receiver_info,
115 RTCInboundRTPStreamStats* inbound_stats) {
116 SetInboundRTPStreamStatsFromMediaReceiverInfo(
117 voice_receiver_info, inbound_stats);
118 inbound_stats->media_type = "audio";
119 inbound_stats->jitter =
120 static_cast<double>(voice_receiver_info.jitter_buffer_ms) /
Taylor Brandstetter 2016/10/27 21:26:03 I don't think this is right; it looks like jitter_
hbos 2016/10/28 10:03:48 Done. The audio case has jitter_ms, jitter_buffer_
121 rtc::kNumMillisecsPerSec;
122 }
123
124 void SetInboundRTPStreamStatsFromVideoReceiverInfo(
125 const cricket::VideoReceiverInfo& video_receiver_info,
126 RTCInboundRTPStreamStats* inbound_stats) {
127 SetInboundRTPStreamStatsFromMediaReceiverInfo(
128 video_receiver_info, inbound_stats);
129 inbound_stats->media_type = "video";
130 inbound_stats->jitter =
131 static_cast<double>(video_receiver_info.jitter_buffer_ms) /
132 rtc::kNumMillisecsPerSec;
133 }
134
91 void SetOutboundRTPStreamStatsFromMediaSenderInfo( 135 void SetOutboundRTPStreamStatsFromMediaSenderInfo(
92 const cricket::MediaSenderInfo& media_sender_info, 136 const cricket::MediaSenderInfo& media_sender_info,
93 RTCOutboundRTPStreamStats* outbound_stats) { 137 RTCOutboundRTPStreamStats* outbound_stats) {
94 RTC_DCHECK(outbound_stats); 138 RTC_DCHECK(outbound_stats);
95 outbound_stats->ssrc = rtc::ToString<>(media_sender_info.ssrc()); 139 outbound_stats->ssrc = rtc::ToString<>(media_sender_info.ssrc());
96 // TODO(hbos): Support the remote case. crbug.com/657856 140 // TODO(hbos): Support the remote case. crbug.com/657856
97 outbound_stats->is_remote = false; 141 outbound_stats->is_remote = false;
98 // TODO(hbos): Set |codec_id| when we have |RTCCodecStats|. Maybe relevant: 142 // TODO(hbos): Set |codec_id| when we have |RTCCodecStats|. Maybe relevant:
99 // |media_sender_info.codec_name|. crbug.com/657854, 657856, 659117 143 // |media_sender_info.codec_name|. crbug.com/657854, 657856, 659117
100 outbound_stats->packets_sent = 144 outbound_stats->packets_sent =
(...skipping 356 matching lines...) Expand 10 before | Expand all | Expand 10 after
457 int64_t timestamp_us, const SessionStats& session_stats, 501 int64_t timestamp_us, const SessionStats& session_stats,
458 RTCStatsReport* report) const { 502 RTCStatsReport* report) const {
459 RTC_DCHECK(signaling_thread_->IsCurrent()); 503 RTC_DCHECK(signaling_thread_->IsCurrent());
460 504
461 // Audio 505 // Audio
462 if (pc_->session()->voice_channel()) { 506 if (pc_->session()->voice_channel()) {
463 cricket::VoiceMediaInfo voice_media_info; 507 cricket::VoiceMediaInfo voice_media_info;
464 if (pc_->session()->voice_channel()->GetStats(&voice_media_info)) { 508 if (pc_->session()->voice_channel()->GetStats(&voice_media_info)) {
465 std::string transport_id = RTCTransportStatsIDFromBaseChannel( 509 std::string transport_id = RTCTransportStatsIDFromBaseChannel(
466 session_stats.proxy_to_transport, *pc_->session()->voice_channel()); 510 session_stats.proxy_to_transport, *pc_->session()->voice_channel());
511 // Inbound
512 for (const cricket::VoiceReceiverInfo& voice_receiver_info :
513 voice_media_info.receivers) {
514 // TODO(nisse): SSRC == 0 currently means none. Delete check when that
515 // is fixed.
516 if (voice_receiver_info.ssrc() == 0)
517 continue;
518 std::unique_ptr<RTCInboundRTPStreamStats> inbound_audio(
519 new RTCInboundRTPStreamStats(
520 RTCInboundRTPStreamStatsIDFromSSRC(
521 true, voice_receiver_info.ssrc()),
522 timestamp_us));
523 SetInboundRTPStreamStatsFromVoiceReceiverInfo(
524 voice_receiver_info, inbound_audio.get());
525 if (!transport_id.empty())
Taylor Brandstetter 2016/10/27 21:26:03 Is it ever possible for transport_id to be empty h
Taylor Brandstetter 2016/10/27 21:28:30 Oh, I see now. It's possible given how "proxy_to_t
hbos 2016/10/28 10:03:48 Done.
526 inbound_audio->transport_id = transport_id;
527 report->AddStats(std::move(inbound_audio));
528 }
529 // Outbound
467 for (const cricket::VoiceSenderInfo& voice_sender_info : 530 for (const cricket::VoiceSenderInfo& voice_sender_info :
468 voice_media_info.senders) { 531 voice_media_info.senders) {
469 // TODO(nisse): SSRC == 0 currently means none. Delete check when that 532 // TODO(nisse): SSRC == 0 currently means none. Delete check when that
470 // is fixed. 533 // is fixed.
471 if (voice_sender_info.ssrc() == 0) 534 if (voice_sender_info.ssrc() == 0)
472 continue; 535 continue;
473 std::unique_ptr<RTCOutboundRTPStreamStats> outbound_audio( 536 std::unique_ptr<RTCOutboundRTPStreamStats> outbound_audio(
474 new RTCOutboundRTPStreamStats( 537 new RTCOutboundRTPStreamStats(
475 RTCOutboundRTPStreamStatsIDFromSSRC( 538 RTCOutboundRTPStreamStatsIDFromSSRC(
476 true, voice_sender_info.ssrc()), 539 true, voice_sender_info.ssrc()),
477 timestamp_us)); 540 timestamp_us));
478 SetOutboundRTPStreamStatsFromVoiceSenderInfo( 541 SetOutboundRTPStreamStatsFromVoiceSenderInfo(
479 voice_sender_info, outbound_audio.get()); 542 voice_sender_info, outbound_audio.get());
480 if (!transport_id.empty()) 543 if (!transport_id.empty())
481 outbound_audio->transport_id = transport_id; 544 outbound_audio->transport_id = transport_id;
482 report->AddStats(std::move(outbound_audio)); 545 report->AddStats(std::move(outbound_audio));
483 } 546 }
484 } 547 }
485 } 548 }
486 // Video 549 // Video
487 if (pc_->session()->video_channel()) { 550 if (pc_->session()->video_channel()) {
488 cricket::VideoMediaInfo video_media_info; 551 cricket::VideoMediaInfo video_media_info;
489 if (pc_->session()->video_channel()->GetStats(&video_media_info)) { 552 if (pc_->session()->video_channel()->GetStats(&video_media_info)) {
490 std::string transport_id = RTCTransportStatsIDFromBaseChannel( 553 std::string transport_id = RTCTransportStatsIDFromBaseChannel(
491 session_stats.proxy_to_transport, *pc_->session()->video_channel()); 554 session_stats.proxy_to_transport, *pc_->session()->video_channel());
555 // Inbound
556 for (const cricket::VideoReceiverInfo& video_receiver_info :
557 video_media_info.receivers) {
558 // TODO(nisse): SSRC == 0 currently means none. Delete check when that
559 // is fixed.
560 if (video_receiver_info.ssrc() == 0)
561 continue;
562 std::unique_ptr<RTCInboundRTPStreamStats> inbound_video(
563 new RTCInboundRTPStreamStats(
564 RTCInboundRTPStreamStatsIDFromSSRC(
565 false, video_receiver_info.ssrc()),
566 timestamp_us));
567 SetInboundRTPStreamStatsFromVideoReceiverInfo(
568 video_receiver_info, inbound_video.get());
569 if (!transport_id.empty())
570 inbound_video->transport_id = transport_id;
571 report->AddStats(std::move(inbound_video));
572 }
573 // Outbound
492 for (const cricket::VideoSenderInfo& video_sender_info : 574 for (const cricket::VideoSenderInfo& video_sender_info :
493 video_media_info.senders) { 575 video_media_info.senders) {
494 // TODO(nisse): SSRC == 0 currently means none. Delete check when that 576 // TODO(nisse): SSRC == 0 currently means none. Delete check when that
495 // is fixed. 577 // is fixed.
496 if (video_sender_info.ssrc() == 0) 578 if (video_sender_info.ssrc() == 0)
497 continue; 579 continue;
498 std::unique_ptr<RTCOutboundRTPStreamStats> outbound_video( 580 std::unique_ptr<RTCOutboundRTPStreamStats> outbound_video(
499 new RTCOutboundRTPStreamStats( 581 new RTCOutboundRTPStreamStats(
500 RTCOutboundRTPStreamStatsIDFromSSRC( 582 RTCOutboundRTPStreamStatsIDFromSSRC(
501 false, video_sender_info.ssrc()), 583 false, video_sender_info.ssrc()),
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after
606 const std::string& type) { 688 const std::string& type) {
607 return CandidateTypeToRTCIceCandidateType(type); 689 return CandidateTypeToRTCIceCandidateType(type);
608 } 690 }
609 691
610 const char* DataStateToRTCDataChannelStateForTesting( 692 const char* DataStateToRTCDataChannelStateForTesting(
611 DataChannelInterface::DataState state) { 693 DataChannelInterface::DataState state) {
612 return DataStateToRTCDataChannelState(state); 694 return DataStateToRTCDataChannelState(state);
613 } 695 }
614 696
615 } // namespace webrtc 697 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698