OLD | NEW |
---|---|
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 |
OLD | NEW |