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/rtcp/sender_rtcp_event_subscriber.h" | 5 #include "media/cast/rtcp/sender_rtcp_event_subscriber.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "media/cast/rtcp/rtcp_defines.h" | 10 #include "media/cast/rtcp/rtcp_defines.h" |
11 | 11 |
12 namespace media { | 12 namespace media { |
13 namespace cast { | 13 namespace cast { |
14 | 14 |
15 SenderRtcpEventSubscriber::SenderRtcpEventSubscriber( | 15 SenderRtcpEventSubscriber::SenderRtcpEventSubscriber( |
16 const size_t max_size_to_retain) | 16 const size_t max_size_to_retain) |
17 : max_size_to_retain_(max_size_to_retain) { | 17 : max_size_to_retain_(max_size_to_retain) { |
18 DCHECK(max_size_to_retain_ > 0u); | 18 DCHECK(max_size_to_retain_ > 0u); |
19 } | 19 } |
20 | 20 |
21 SenderRtcpEventSubscriber::~SenderRtcpEventSubscriber() { | 21 SenderRtcpEventSubscriber::~SenderRtcpEventSubscriber() { |
22 DCHECK(thread_checker_.CalledOnValidThread()); | 22 DCHECK(thread_checker_.CalledOnValidThread()); |
23 } | 23 } |
24 | 24 |
25 void SenderRtcpEventSubscriber::OnReceiveFrameEvent( | 25 void SenderRtcpEventSubscriber::OnReceiveFrameEvent( |
26 const FrameEvent& frame_event) { | 26 const FrameEvent& frame_event) { |
27 DCHECK(thread_checker_.CalledOnValidThread()); | 27 DCHECK(thread_checker_.CalledOnValidThread()); |
28 if (frame_event.type != kVideoFrameCaptureBegin && | 28 if (frame_event.media_type != VIDEO_EVENT) |
29 frame_event.type != kVideoFrameSentToEncoder && | 29 return; |
30 frame_event.type != kVideoFrameEncoded) { | 30 if (frame_event.type != FRAME_CAPTURE_BEGIN && |
| 31 frame_event.type != FRAME_ENCODED) { |
31 // Not interested in other events. | 32 // Not interested in other events. |
32 return; | 33 return; |
33 } | 34 } |
34 | 35 |
35 RtcpEventMap::iterator it = rtcp_events_.find(frame_event.rtp_timestamp); | 36 RtcpEventMap::iterator it = rtcp_events_.find(frame_event.rtp_timestamp); |
36 if (it == rtcp_events_.end()) { | 37 if (it == rtcp_events_.end()) { |
37 // We have not stored this frame (RTP timestamp) in our map. | 38 // We have not stored this frame (RTP timestamp) in our map. |
38 RtcpEvent rtcp_event; | 39 RtcpEvent rtcp_event; |
39 rtcp_event.type = frame_event.type; | 40 rtcp_event.type = frame_event.type; |
40 rtcp_event.timestamp = frame_event.timestamp; | 41 rtcp_event.timestamp = frame_event.timestamp; |
41 | 42 |
42 // Do not need to fill out rtcp_event.delay_delta or rtcp_event.packet_id | 43 // Do not need to fill out rtcp_event.delay_delta or rtcp_event.packet_id |
43 // as they are not set in frame events we are interested in. | 44 // as they are not set in frame events we are interested in. |
44 rtcp_events_.insert(std::make_pair(frame_event.rtp_timestamp, rtcp_event)); | 45 rtcp_events_.insert(std::make_pair(frame_event.rtp_timestamp, rtcp_event)); |
45 | 46 |
46 TruncateMapIfNeeded(); | 47 TruncateMapIfNeeded(); |
47 } else { | 48 } else { |
48 // We already have this frame (RTP timestamp) in our map. | 49 // We already have this frame (RTP timestamp) in our map. |
49 // Only update events that are later in the chain. | 50 // Only update events that are later in the chain. |
50 // This is due to that events can be reordered on the wire. | 51 // This is due to that events can be reordered on the wire. |
51 if (frame_event.type == kVideoFrameCaptureBegin) { | 52 if (frame_event.type == FRAME_CAPTURE_BEGIN) { |
52 return; // First event in chain can not be late by definition. | 53 return; // First event in chain can not be late by definition. |
53 } | 54 } |
54 | 55 |
55 if (it->second.type == kVideoFrameEncoded) { | 56 if (it->second.type == FRAME_ENCODED) { |
56 return; // Last event in chain should not be updated. | 57 return; // Last event in chain should not be updated. |
57 } | 58 } |
58 | 59 |
59 // Update existing entry. | 60 // Update existing entry. |
60 it->second.type = frame_event.type; | 61 it->second.type = frame_event.type; |
61 } | 62 } |
62 | 63 |
63 DCHECK(rtcp_events_.size() <= max_size_to_retain_); | 64 DCHECK(rtcp_events_.size() <= max_size_to_retain_); |
64 } | 65 } |
65 | 66 |
(...skipping 16 matching lines...) Expand all Loading... |
82 if (rtcp_events_.size() > max_size_to_retain_) { | 83 if (rtcp_events_.size() > max_size_to_retain_) { |
83 DVLOG(2) << "RTCP event map exceeded size limit; " | 84 DVLOG(2) << "RTCP event map exceeded size limit; " |
84 << "removing oldest entry"; | 85 << "removing oldest entry"; |
85 // This is fine since we only insert elements one at a time. | 86 // This is fine since we only insert elements one at a time. |
86 rtcp_events_.erase(rtcp_events_.begin()); | 87 rtcp_events_.erase(rtcp_events_.begin()); |
87 } | 88 } |
88 } | 89 } |
89 | 90 |
90 } // namespace cast | 91 } // namespace cast |
91 } // namespace media | 92 } // namespace media |
OLD | NEW |