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

Side by Side Diff: media/cast/net/rtcp/receiver_rtcp_event_subscriber.cc

Issue 765643006: Cast: Make receiver use cast_transport (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years 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 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "media/cast/net/rtcp/receiver_rtcp_event_subscriber.h" 5 #include "media/cast/net/rtcp/receiver_rtcp_event_subscriber.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 namespace media { 9 namespace media {
10 namespace cast { 10 namespace cast {
11 11
12 ReceiverRtcpEventSubscriber::ReceiverRtcpEventSubscriber( 12 ReceiverRtcpEventSubscriber::ReceiverRtcpEventSubscriber(
13 const size_t max_size_to_retain, EventMediaType type) 13 const size_t max_size_to_retain, EventMediaType type)
14 : max_size_to_retain_(max_size_to_retain), type_(type) { 14 : max_size_to_retain_(
15 max_size_to_retain * (kResendDelay * kNumResends + 1)),
16 type_(type) {
15 DCHECK(max_size_to_retain_ > 0u); 17 DCHECK(max_size_to_retain_ > 0u);
16 DCHECK(type_ == AUDIO_EVENT || type_ == VIDEO_EVENT); 18 DCHECK(type_ == AUDIO_EVENT || type_ == VIDEO_EVENT);
19 for (size_t i = 0; i < kNumResends; i++) {
miu 2014/12/04 04:18:53 nit: memset(send_ptrs_, 0, sizeof(send_ptrs_));
hubbe 2014/12/05 23:57:20 Not sure that is better. The compiler should be mu
20 send_ptrs_[i] = 0;
21 }
17 } 22 }
18 23
19 ReceiverRtcpEventSubscriber::~ReceiverRtcpEventSubscriber() { 24 ReceiverRtcpEventSubscriber::~ReceiverRtcpEventSubscriber() {
20 DCHECK(thread_checker_.CalledOnValidThread()); 25 DCHECK(thread_checker_.CalledOnValidThread());
21 } 26 }
22 27
23 void ReceiverRtcpEventSubscriber::OnReceiveFrameEvent( 28 void ReceiverRtcpEventSubscriber::OnReceiveFrameEvent(
24 const FrameEvent& frame_event) { 29 const FrameEvent& frame_event) {
25 DCHECK(thread_checker_.CalledOnValidThread()); 30 DCHECK(thread_checker_.CalledOnValidThread());
26 31
27 if (ShouldProcessEvent(frame_event.type, frame_event.media_type)) { 32 if (ShouldProcessEvent(frame_event.type, frame_event.media_type)) {
28 RtcpEvent rtcp_event; 33 RtcpEvent rtcp_event;
29 switch (frame_event.type) { 34 switch (frame_event.type) {
30 case FRAME_PLAYOUT: 35 case FRAME_PLAYOUT:
31 rtcp_event.delay_delta = frame_event.delay_delta; 36 rtcp_event.delay_delta = frame_event.delay_delta;
32 case FRAME_ACK_SENT: 37 case FRAME_ACK_SENT:
33 case FRAME_DECODED: 38 case FRAME_DECODED:
34 rtcp_event.type = frame_event.type; 39 rtcp_event.type = frame_event.type;
35 rtcp_event.timestamp = frame_event.timestamp; 40 rtcp_event.timestamp = frame_event.timestamp;
36 rtcp_events_.insert( 41 rtcp_events_.push_back(
37 std::make_pair(frame_event.rtp_timestamp, rtcp_event)); 42 std::make_pair(frame_event.rtp_timestamp, rtcp_event));
38 break; 43 break;
39 default: 44 default:
40 break; 45 break;
41 } 46 }
42 } 47 }
43 48
44 TruncateMapIfNeeded(); 49 TruncateMapIfNeeded();
45 50
46 DCHECK(rtcp_events_.size() <= max_size_to_retain_); 51 DCHECK(rtcp_events_.size() <= max_size_to_retain_);
miu 2014/12/04 04:18:53 This DCHECK should probably be moved to the end of
hubbe 2014/12/05 23:57:20 Done.
47 } 52 }
48 53
49 void ReceiverRtcpEventSubscriber::OnReceivePacketEvent( 54 void ReceiverRtcpEventSubscriber::OnReceivePacketEvent(
50 const PacketEvent& packet_event) { 55 const PacketEvent& packet_event) {
51 DCHECK(thread_checker_.CalledOnValidThread()); 56 DCHECK(thread_checker_.CalledOnValidThread());
52 57
53 if (ShouldProcessEvent(packet_event.type, packet_event.media_type)) { 58 if (ShouldProcessEvent(packet_event.type, packet_event.media_type)) {
54 RtcpEvent rtcp_event; 59 RtcpEvent rtcp_event;
55 if (packet_event.type == PACKET_RECEIVED) { 60 if (packet_event.type == PACKET_RECEIVED) {
56 rtcp_event.type = packet_event.type; 61 rtcp_event.type = packet_event.type;
57 rtcp_event.timestamp = packet_event.timestamp; 62 rtcp_event.timestamp = packet_event.timestamp;
58 rtcp_event.packet_id = packet_event.packet_id; 63 rtcp_event.packet_id = packet_event.packet_id;
59 rtcp_events_.insert( 64 rtcp_events_.push_back(
60 std::make_pair(packet_event.rtp_timestamp, rtcp_event)); 65 std::make_pair(packet_event.rtp_timestamp, rtcp_event));
61 } 66 }
62 } 67 }
63 68
64 TruncateMapIfNeeded(); 69 TruncateMapIfNeeded();
65 70
66 DCHECK(rtcp_events_.size() <= max_size_to_retain_); 71 DCHECK(rtcp_events_.size() <= max_size_to_retain_);
miu 2014/12/04 04:18:53 ditto
hubbe 2014/12/05 23:57:20 Done.
67 } 72 }
68 73
69 void ReceiverRtcpEventSubscriber::GetRtcpEventsAndReset( 74 struct CompareByFirst {
70 RtcpEventMultiMap* rtcp_events) { 75 bool operator()(const std::pair<RtpTimestamp, RtcpEvent>& a,
76 const std::pair<RtpTimestamp, RtcpEvent>& b) {
77 return a.first < b.first;
78 }
79 };
80
81 void ReceiverRtcpEventSubscriber::GetRtcpEventsWithRedundancy(
82 RtcpEvents* rtcp_events) {
71 DCHECK(thread_checker_.CalledOnValidThread()); 83 DCHECK(thread_checker_.CalledOnValidThread());
72 DCHECK(rtcp_events); 84 DCHECK(rtcp_events);
73 rtcp_events->swap(rtcp_events_); 85
74 rtcp_events_.clear(); 86 uint64 event_level = rtcp_events_.size() + popped_events_;
87 event_levels_for_past_frames_.push_back(event_level);
88
89 for (size_t i = 0; i < kNumResends; i++) {
90 size_t resend_delay = kResendDelay * i;
91 if (event_levels_for_past_frames_.size() < resend_delay + 1)
92 break;
93
94 uint64 send_limit = event_levels_for_past_frames_[
95 event_levels_for_past_frames_.size() - 1 - resend_delay];
96
97 if (send_ptrs_[i] < popped_events_) {
98 send_ptrs_[i] = popped_events_;
99 }
100
101 while (send_ptrs_[i] < send_limit &&
102 rtcp_events->size() < kMaxEventsPerRTCP) {
103 rtcp_events->push_back(rtcp_events_[send_ptrs_[i] - popped_events_]);
104 send_ptrs_[i]++;
105 }
106 send_limit = send_ptrs_[i];
107 }
108
109 if (event_levels_for_past_frames_.size() > kResendDelay * (kNumResends + 1)) {
110 while (popped_events_ < event_levels_for_past_frames_[0]) {
111 rtcp_events_.pop_front();
112 popped_events_++;
113 }
114 event_levels_for_past_frames_.pop_front();
115 }
116
117 std::sort(rtcp_events->begin(), rtcp_events->end(), CompareByFirst());
75 } 118 }
76 119
77 void ReceiverRtcpEventSubscriber::TruncateMapIfNeeded() { 120 void ReceiverRtcpEventSubscriber::TruncateMapIfNeeded() {
78 // If map size has exceeded |max_size_to_retain_|, remove entry with 121 // If map size has exceeded |max_size_to_retain_|, remove entry with
79 // the smallest RTP timestamp. 122 // the smallest RTP timestamp.
80 if (rtcp_events_.size() > max_size_to_retain_) { 123 if (rtcp_events_.size() > max_size_to_retain_) {
81 DVLOG(3) << "RTCP event map exceeded size limit; " 124 DVLOG(3) << "RTCP event map exceeded size limit; "
82 << "removing oldest entry"; 125 << "removing oldest entry";
83 // This is fine since we only insert elements one at a time. 126 // This is fine since we only insert elements one at a time.
84 rtcp_events_.erase(rtcp_events_.begin()); 127 rtcp_events_.pop_front();
128 popped_events_++;
85 } 129 }
86 } 130 }
87 131
88 bool ReceiverRtcpEventSubscriber::ShouldProcessEvent( 132 bool ReceiverRtcpEventSubscriber::ShouldProcessEvent(
89 CastLoggingEvent event_type, EventMediaType event_media_type) { 133 CastLoggingEvent event_type, EventMediaType event_media_type) {
90 return type_ == event_media_type && 134 return type_ == event_media_type &&
91 (event_type == FRAME_ACK_SENT || event_type == FRAME_DECODED || 135 (event_type == FRAME_ACK_SENT || event_type == FRAME_DECODED ||
92 event_type == FRAME_PLAYOUT || event_type == PACKET_RECEIVED); 136 event_type == FRAME_PLAYOUT || event_type == PACKET_RECEIVED);
93 } 137 }
94 138
95 } // namespace cast 139 } // namespace cast
96 } // namespace media 140 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698