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/logging/encoding_event_subscriber.h" | 5 #include "media/cast/logging/encoding_event_subscriber.h" |
6 | 6 |
7 #include <cstring> | 7 #include <cstring> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
55 first_rtp_timestamp_(0u) {} | 55 first_rtp_timestamp_(0u) {} |
56 | 56 |
57 EncodingEventSubscriber::~EncodingEventSubscriber() { | 57 EncodingEventSubscriber::~EncodingEventSubscriber() { |
58 DCHECK(thread_checker_.CalledOnValidThread()); | 58 DCHECK(thread_checker_.CalledOnValidThread()); |
59 } | 59 } |
60 | 60 |
61 void EncodingEventSubscriber::OnReceiveFrameEvent( | 61 void EncodingEventSubscriber::OnReceiveFrameEvent( |
62 const FrameEvent& frame_event) { | 62 const FrameEvent& frame_event) { |
63 DCHECK(thread_checker_.CalledOnValidThread()); | 63 DCHECK(thread_checker_.CalledOnValidThread()); |
64 | 64 |
65 if (!ShouldProcessEvent(frame_event.type)) | 65 if (event_media_type_ != frame_event.media_type) |
66 return; | 66 return; |
67 | 67 |
68 RtpTimestamp relative_rtp_timestamp = | 68 RtpTimestamp relative_rtp_timestamp = |
69 GetRelativeRtpTimestamp(frame_event.rtp_timestamp); | 69 GetRelativeRtpTimestamp(frame_event.rtp_timestamp); |
70 FrameEventMap::iterator it = frame_event_map_.find(relative_rtp_timestamp); | 70 FrameEventMap::iterator it = frame_event_map_.find(relative_rtp_timestamp); |
71 linked_ptr<AggregatedFrameEvent> event_proto; | 71 linked_ptr<AggregatedFrameEvent> event_proto; |
72 | 72 |
73 // Look up existing entry. If not found, create a new entry and add to map. | 73 // Look up existing entry. If not found, create a new entry and add to map. |
74 if (it == frame_event_map_.end()) { | 74 if (it == frame_event_map_.end()) { |
75 event_proto.reset(new AggregatedFrameEvent); | 75 event_proto.reset(new AggregatedFrameEvent); |
76 event_proto->set_relative_rtp_timestamp(relative_rtp_timestamp); | 76 event_proto->set_relative_rtp_timestamp(relative_rtp_timestamp); |
77 frame_event_map_.insert( | 77 frame_event_map_.insert( |
78 std::make_pair(relative_rtp_timestamp, event_proto)); | 78 std::make_pair(relative_rtp_timestamp, event_proto)); |
79 } else { | 79 } else { |
80 event_proto = it->second; | 80 event_proto = it->second; |
81 if (event_proto->event_type_size() >= kMaxEventsPerProto) { | 81 if (event_proto->event_type_size() >= kMaxEventsPerProto) { |
82 DVLOG(2) << "Too many events in frame " << frame_event.rtp_timestamp | 82 DVLOG(2) << "Too many events in frame " << frame_event.rtp_timestamp |
83 << ". Using new frame event proto."; | 83 << ". Using new frame event proto."; |
84 AddFrameEventToStorage(event_proto); | 84 AddFrameEventToStorage(event_proto); |
85 event_proto.reset(new AggregatedFrameEvent); | 85 event_proto.reset(new AggregatedFrameEvent); |
86 event_proto->set_relative_rtp_timestamp(relative_rtp_timestamp); | 86 event_proto->set_relative_rtp_timestamp(relative_rtp_timestamp); |
87 it->second = event_proto; | 87 it->second = event_proto; |
88 } | 88 } |
89 } | 89 } |
90 | 90 |
91 event_proto->add_event_type(ToProtoEventType(frame_event.type)); | 91 event_proto->add_event_type(ToProtoEventType(frame_event.type)); |
92 event_proto->add_event_timestamp_ms( | 92 event_proto->add_event_timestamp_ms( |
93 (frame_event.timestamp - base::TimeTicks()).InMilliseconds()); | 93 (frame_event.timestamp - base::TimeTicks()).InMilliseconds()); |
94 | 94 |
95 if (frame_event.type == kAudioFrameEncoded) { | 95 if (frame_event.type == FRAME_ENCODED) { |
96 event_proto->set_encoded_frame_size(frame_event.size); | 96 event_proto->set_encoded_frame_size(frame_event.size); |
97 } else if (frame_event.type == kVideoFrameEncoded) { | 97 if (frame_event.media_type == VIDEO_EVENT) { |
98 event_proto->set_encoded_frame_size(frame_event.size); | 98 event_proto->set_encoded_frame_size(frame_event.size); |
99 event_proto->set_key_frame(frame_event.key_frame); | 99 event_proto->set_key_frame(frame_event.key_frame); |
100 event_proto->set_target_bitrate(frame_event.target_bitrate); | 100 event_proto->set_target_bitrate(frame_event.target_bitrate); |
101 } else if (frame_event.type == kAudioPlayoutDelay || | 101 } |
102 frame_event.type == kVideoRenderDelay) { | 102 } else if (frame_event.type == FRAME_PLAYOUT) { |
103 event_proto->set_delay_millis(frame_event.delay_delta.InMilliseconds()); | 103 event_proto->set_delay_millis(frame_event.delay_delta.InMilliseconds()); |
104 } | 104 } |
105 | 105 |
106 if (frame_event_map_.size() > kMaxMapSize) | 106 if (frame_event_map_.size() > kMaxMapSize) |
107 TransferFrameEvents(kNumMapEntriesToTransfer); | 107 TransferFrameEvents(kNumMapEntriesToTransfer); |
108 | 108 |
109 DCHECK(frame_event_map_.size() <= kMaxMapSize); | 109 DCHECK(frame_event_map_.size() <= kMaxMapSize); |
110 DCHECK(frame_event_storage_.size() <= max_frames_); | 110 DCHECK(frame_event_storage_.size() <= max_frames_); |
111 } | 111 } |
112 | 112 |
113 void EncodingEventSubscriber::OnReceivePacketEvent( | 113 void EncodingEventSubscriber::OnReceivePacketEvent( |
114 const PacketEvent& packet_event) { | 114 const PacketEvent& packet_event) { |
115 DCHECK(thread_checker_.CalledOnValidThread()); | 115 DCHECK(thread_checker_.CalledOnValidThread()); |
116 | 116 |
117 if (!ShouldProcessEvent(packet_event.type)) | 117 if (event_media_type_ != packet_event.media_type) |
118 return; | 118 return; |
119 RtpTimestamp relative_rtp_timestamp = | 119 RtpTimestamp relative_rtp_timestamp = |
120 GetRelativeRtpTimestamp(packet_event.rtp_timestamp); | 120 GetRelativeRtpTimestamp(packet_event.rtp_timestamp); |
121 PacketEventMap::iterator it = | 121 PacketEventMap::iterator it = |
122 packet_event_map_.find(relative_rtp_timestamp); | 122 packet_event_map_.find(relative_rtp_timestamp); |
123 linked_ptr<AggregatedPacketEvent> event_proto; | 123 linked_ptr<AggregatedPacketEvent> event_proto; |
124 BasePacketEvent* base_packet_event_proto = NULL; | 124 BasePacketEvent* base_packet_event_proto = NULL; |
125 | 125 |
126 // Look up existing entry. If not found, create a new entry and add to map. | 126 // Look up existing entry. If not found, create a new entry and add to map. |
127 if (it == packet_event_map_.end()) { | 127 if (it == packet_event_map_.end()) { |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
201 metadata->set_first_rtp_timestamp(first_rtp_timestamp_); | 201 metadata->set_first_rtp_timestamp(first_rtp_timestamp_); |
202 metadata->set_num_frame_events(frame_event_storage_.size()); | 202 metadata->set_num_frame_events(frame_event_storage_.size()); |
203 metadata->set_num_packet_events(packet_event_storage_.size()); | 203 metadata->set_num_packet_events(packet_event_storage_.size()); |
204 metadata->set_reference_timestamp_ms_at_unix_epoch( | 204 metadata->set_reference_timestamp_ms_at_unix_epoch( |
205 (base::TimeTicks::UnixEpoch() - base::TimeTicks()).InMilliseconds()); | 205 (base::TimeTicks::UnixEpoch() - base::TimeTicks()).InMilliseconds()); |
206 frame_events->swap(frame_event_storage_); | 206 frame_events->swap(frame_event_storage_); |
207 packet_events->swap(packet_event_storage_); | 207 packet_events->swap(packet_event_storage_); |
208 Reset(); | 208 Reset(); |
209 } | 209 } |
210 | 210 |
211 bool EncodingEventSubscriber::ShouldProcessEvent(CastLoggingEvent event) { | |
212 return GetEventMediaType(event) == event_media_type_; | |
213 } | |
214 | |
215 void EncodingEventSubscriber::TransferFrameEvents(size_t max_num_entries) { | 211 void EncodingEventSubscriber::TransferFrameEvents(size_t max_num_entries) { |
216 DCHECK(frame_event_map_.size() >= max_num_entries); | 212 DCHECK(frame_event_map_.size() >= max_num_entries); |
217 | 213 |
218 FrameEventMap::iterator it = frame_event_map_.begin(); | 214 FrameEventMap::iterator it = frame_event_map_.begin(); |
219 for (size_t i = 0; | 215 for (size_t i = 0; |
220 i < max_num_entries && it != frame_event_map_.end(); | 216 i < max_num_entries && it != frame_event_map_.end(); |
221 i++, ++it) { | 217 i++, ++it) { |
222 AddFrameEventToStorage(it->second); | 218 AddFrameEventToStorage(it->second); |
223 } | 219 } |
224 | 220 |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
273 frame_event_storage_index_ = 0; | 269 frame_event_storage_index_ = 0; |
274 packet_event_map_.clear(); | 270 packet_event_map_.clear(); |
275 packet_event_storage_.clear(); | 271 packet_event_storage_.clear(); |
276 packet_event_storage_index_ = 0; | 272 packet_event_storage_index_ = 0; |
277 seen_first_rtp_timestamp_ = false; | 273 seen_first_rtp_timestamp_ = false; |
278 first_rtp_timestamp_ = 0u; | 274 first_rtp_timestamp_ = 0u; |
279 } | 275 } |
280 | 276 |
281 } // namespace cast | 277 } // namespace cast |
282 } // namespace media | 278 } // namespace media |
OLD | NEW |