| 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/sender/frame_sender.h" | 5 #include "media/cast/sender/frame_sender.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <limits> | 8 #include <limits> |
| 9 #include <utility> | 9 #include <utility> |
| 10 #include <vector> | 10 #include <vector> |
| 11 | 11 |
| 12 #include "base/macros.h" | 12 #include "base/macros.h" |
| 13 #include "base/numerics/safe_conversions.h" |
| 13 #include "base/trace_event/trace_event.h" | 14 #include "base/trace_event/trace_event.h" |
| 14 #include "media/cast/cast_defines.h" | 15 #include "media/cast/cast_defines.h" |
| 15 #include "media/cast/constants.h" | 16 #include "media/cast/constants.h" |
| 16 #include "media/cast/sender/sender_encoded_frame.h" | 17 #include "media/cast/sender/sender_encoded_frame.h" |
| 17 | 18 |
| 18 namespace media { | 19 namespace media { |
| 19 namespace cast { | 20 namespace cast { |
| 20 namespace { | 21 namespace { |
| 21 | 22 |
| 22 const int kMinSchedulingDelayMs = 1; | 23 const int kMinSchedulingDelayMs = 1; |
| (...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 232 | 233 |
| 233 VLOG_IF(1, !is_audio_ && encoded_frame->dependency == EncodedFrame::KEY) | 234 VLOG_IF(1, !is_audio_ && encoded_frame->dependency == EncodedFrame::KEY) |
| 234 << SENDER_SSRC << "Sending encoded key frame, id=" << frame_id; | 235 << SENDER_SSRC << "Sending encoded key frame, id=" << frame_id; |
| 235 | 236 |
| 236 scoped_ptr<FrameEvent> encode_event(new FrameEvent()); | 237 scoped_ptr<FrameEvent> encode_event(new FrameEvent()); |
| 237 encode_event->timestamp = encoded_frame->encode_completion_time; | 238 encode_event->timestamp = encoded_frame->encode_completion_time; |
| 238 encode_event->type = FRAME_ENCODED; | 239 encode_event->type = FRAME_ENCODED; |
| 239 encode_event->media_type = is_audio_ ? AUDIO_EVENT : VIDEO_EVENT; | 240 encode_event->media_type = is_audio_ ? AUDIO_EVENT : VIDEO_EVENT; |
| 240 encode_event->rtp_timestamp = encoded_frame->rtp_timestamp; | 241 encode_event->rtp_timestamp = encoded_frame->rtp_timestamp; |
| 241 encode_event->frame_id = frame_id; | 242 encode_event->frame_id = frame_id; |
| 242 encode_event->size = encoded_frame->data.size(); | 243 encode_event->size = base::checked_cast<uint32_t>(encoded_frame->data.size()); |
| 243 encode_event->key_frame = encoded_frame->dependency == EncodedFrame::KEY; | 244 encode_event->key_frame = encoded_frame->dependency == EncodedFrame::KEY; |
| 244 encode_event->target_bitrate = requested_bitrate_before_encode; | 245 encode_event->target_bitrate = requested_bitrate_before_encode; |
| 245 encode_event->encoder_cpu_utilization = encoded_frame->deadline_utilization; | 246 encode_event->encoder_cpu_utilization = encoded_frame->deadline_utilization; |
| 246 encode_event->idealized_bitrate_utilization = | 247 encode_event->idealized_bitrate_utilization = |
| 247 encoded_frame->lossy_utilization; | 248 encoded_frame->lossy_utilization; |
| 248 cast_environment_->logger()->DispatchFrameEvent(std::move(encode_event)); | 249 cast_environment_->logger()->DispatchFrameEvent(std::move(encode_event)); |
| 249 | 250 |
| 250 RecordLatestFrameTimestamps(frame_id, | 251 RecordLatestFrameTimestamps(frame_id, |
| 251 encoded_frame->reference_time, | 252 encoded_frame->reference_time, |
| 252 encoded_frame->rtp_timestamp); | 253 encoded_frame->rtp_timestamp); |
| (...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 420 VLOG(1) << SENDER_SSRC << "Dropping: In-flight duration would be too high."; | 421 VLOG(1) << SENDER_SSRC << "Dropping: In-flight duration would be too high."; |
| 421 return true; | 422 return true; |
| 422 } | 423 } |
| 423 | 424 |
| 424 // Next frame is accepted. | 425 // Next frame is accepted. |
| 425 return false; | 426 return false; |
| 426 } | 427 } |
| 427 | 428 |
| 428 } // namespace cast | 429 } // namespace cast |
| 429 } // namespace media | 430 } // namespace media |
| OLD | NEW |