OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/filters/vpx_video_decoder.h" | 5 #include "media/filters/vpx_video_decoder.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/bind.h" | 11 #include "base/bind.h" |
12 #include "base/callback_helpers.h" | 12 #include "base/callback_helpers.h" |
13 #include "base/command_line.h" | 13 #include "base/command_line.h" |
14 #include "base/debug/trace_event.h" | |
14 #include "base/location.h" | 15 #include "base/location.h" |
15 #include "base/logging.h" | 16 #include "base/logging.h" |
16 #include "base/single_thread_task_runner.h" | 17 #include "base/single_thread_task_runner.h" |
17 #include "base/stl_util.h" | 18 #include "base/stl_util.h" |
18 #include "base/strings/string_number_conversions.h" | 19 #include "base/strings/string_number_conversions.h" |
19 #include "base/sys_byteorder.h" | 20 #include "base/sys_byteorder.h" |
20 #include "media/base/bind_to_current_loop.h" | 21 #include "media/base/bind_to_current_loop.h" |
21 #include "media/base/decoder_buffer.h" | 22 #include "media/base/decoder_buffer.h" |
22 #include "media/base/demuxer_stream.h" | 23 #include "media/base/demuxer_stream.h" |
23 #include "media/base/limits.h" | 24 #include "media/base/limits.h" |
(...skipping 330 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
354 } | 355 } |
355 | 356 |
356 base::ResetAndReturn(&decode_cb_).Run(kOk); | 357 base::ResetAndReturn(&decode_cb_).Run(kOk); |
357 | 358 |
358 if (video_frame.get()) | 359 if (video_frame.get()) |
359 output_cb_.Run(video_frame); | 360 output_cb_.Run(video_frame); |
360 } | 361 } |
361 | 362 |
362 bool VpxVideoDecoder::VpxDecode(const scoped_refptr<DecoderBuffer>& buffer, | 363 bool VpxVideoDecoder::VpxDecode(const scoped_refptr<DecoderBuffer>& buffer, |
363 scoped_refptr<VideoFrame>* video_frame) { | 364 scoped_refptr<VideoFrame>* video_frame) { |
365 TRACE_EVENT0("video", "VpxDecode"); | |
fgalligan1
2014/12/03 18:29:56
Is this needed?
Tom Finegan
2014/12/03 18:51:39
This tracked the entire VpxDecode() call. Removed.
| |
364 DCHECK(video_frame); | 366 DCHECK(video_frame); |
365 DCHECK(!buffer->end_of_stream()); | 367 DCHECK(!buffer->end_of_stream()); |
366 | 368 |
367 // Pass |buffer| to libvpx. | 369 // Pass |buffer| to libvpx. |
368 int64 timestamp = buffer->timestamp().InMicroseconds(); | 370 int64 timestamp = buffer->timestamp().InMicroseconds(); |
369 void* user_priv = reinterpret_cast<void*>(×tamp); | 371 void* user_priv = reinterpret_cast<void*>(×tamp); |
372 | |
373 TRACE_EVENT_BEGIN0("video", "vpx_codec_decode"); | |
fgalligan1
2014/12/03 18:29:56
Maybe add the timestamp so we could distinguish th
Tom Finegan
2014/12/03 18:51:39
Done.
| |
370 vpx_codec_err_t status = vpx_codec_decode(vpx_codec_, | 374 vpx_codec_err_t status = vpx_codec_decode(vpx_codec_, |
371 buffer->data(), | 375 buffer->data(), |
372 buffer->data_size(), | 376 buffer->data_size(), |
373 user_priv, | 377 user_priv, |
374 0); | 378 0); |
379 TRACE_EVENT_END0("video", "vpx_codec_decode"); | |
375 if (status != VPX_CODEC_OK) { | 380 if (status != VPX_CODEC_OK) { |
376 LOG(ERROR) << "vpx_codec_decode() failed, status=" << status; | 381 LOG(ERROR) << "vpx_codec_decode() failed, status=" << status; |
377 return false; | 382 return false; |
378 } | 383 } |
379 | 384 |
380 // Gets pointer to decoded data. | 385 // Gets pointer to decoded data. |
381 vpx_codec_iter_t iter = NULL; | 386 vpx_codec_iter_t iter = NULL; |
387 TRACE_EVENT_BEGIN0("video", "vpx_codec_get_frame"); | |
fgalligan1
2014/12/03 18:29:56
I think we can get rid of these. They should prett
Tom Finegan
2014/12/03 18:51:39
Done.
| |
382 const vpx_image_t* vpx_image = vpx_codec_get_frame(vpx_codec_, &iter); | 388 const vpx_image_t* vpx_image = vpx_codec_get_frame(vpx_codec_, &iter); |
389 TRACE_EVENT_END0("video", "vpx_codec_get_frame"); | |
383 if (!vpx_image) { | 390 if (!vpx_image) { |
384 *video_frame = NULL; | 391 *video_frame = NULL; |
385 return true; | 392 return true; |
386 } | 393 } |
387 | 394 |
388 if (vpx_image->user_priv != reinterpret_cast<void*>(×tamp)) { | 395 if (vpx_image->user_priv != reinterpret_cast<void*>(×tamp)) { |
389 LOG(ERROR) << "Invalid output timestamp."; | 396 LOG(ERROR) << "Invalid output timestamp."; |
390 return false; | 397 return false; |
391 } | 398 } |
392 | 399 |
393 const vpx_image_t* vpx_image_alpha = NULL; | 400 const vpx_image_t* vpx_image_alpha = NULL; |
394 if (vpx_codec_alpha_ && buffer->side_data_size() >= 8) { | 401 if (vpx_codec_alpha_ && buffer->side_data_size() >= 8) { |
395 // Pass alpha data to libvpx. | 402 // Pass alpha data to libvpx. |
396 int64 timestamp_alpha = buffer->timestamp().InMicroseconds(); | 403 int64 timestamp_alpha = buffer->timestamp().InMicroseconds(); |
397 void* user_priv_alpha = reinterpret_cast<void*>(×tamp_alpha); | 404 void* user_priv_alpha = reinterpret_cast<void*>(×tamp_alpha); |
398 | 405 |
399 // First 8 bytes of side data is side_data_id in big endian. | 406 // First 8 bytes of side data is side_data_id in big endian. |
400 const uint64 side_data_id = base::NetToHost64( | 407 const uint64 side_data_id = base::NetToHost64( |
401 *(reinterpret_cast<const uint64*>(buffer->side_data()))); | 408 *(reinterpret_cast<const uint64*>(buffer->side_data()))); |
402 if (side_data_id == 1) { | 409 if (side_data_id == 1) { |
410 TRACE_EVENT_BEGIN0("video", "vpx_codec_decode_alpha"); | |
403 status = vpx_codec_decode(vpx_codec_alpha_, | 411 status = vpx_codec_decode(vpx_codec_alpha_, |
404 buffer->side_data() + 8, | 412 buffer->side_data() + 8, |
405 buffer->side_data_size() - 8, | 413 buffer->side_data_size() - 8, |
406 user_priv_alpha, | 414 user_priv_alpha, |
407 0); | 415 0); |
416 TRACE_EVENT_END0("video", "vpx_codec_decode_alpha"); | |
408 | 417 |
409 if (status != VPX_CODEC_OK) { | 418 if (status != VPX_CODEC_OK) { |
410 LOG(ERROR) << "vpx_codec_decode() failed on alpha, status=" << status; | 419 LOG(ERROR) << "vpx_codec_decode() failed on alpha, status=" << status; |
411 return false; | 420 return false; |
412 } | 421 } |
413 | 422 |
414 // Gets pointer to decoded data. | 423 // Gets pointer to decoded data. |
415 vpx_codec_iter_t iter_alpha = NULL; | 424 vpx_codec_iter_t iter_alpha = NULL; |
425 TRACE_EVENT_BEGIN0("video", "vpx_codec_get_frame_alpha"); | |
416 vpx_image_alpha = vpx_codec_get_frame(vpx_codec_alpha_, &iter_alpha); | 426 vpx_image_alpha = vpx_codec_get_frame(vpx_codec_alpha_, &iter_alpha); |
427 TRACE_EVENT_END0("video", "vpx_codec_get_frame_alpha"); | |
417 if (!vpx_image_alpha) { | 428 if (!vpx_image_alpha) { |
418 *video_frame = NULL; | 429 *video_frame = NULL; |
419 return true; | 430 return true; |
420 } | 431 } |
421 | 432 |
422 if (vpx_image_alpha->user_priv != | 433 if (vpx_image_alpha->user_priv != |
423 reinterpret_cast<void*>(×tamp_alpha)) { | 434 reinterpret_cast<void*>(×tamp_alpha)) { |
424 LOG(ERROR) << "Invalid output timestamp on alpha."; | 435 LOG(ERROR) << "Invalid output timestamp on alpha."; |
425 return false; | 436 return false; |
426 } | 437 } |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
494 vpx_image->stride[VPX_PLANE_Y], vpx_image->d_h, video_frame->get()); | 505 vpx_image->stride[VPX_PLANE_Y], vpx_image->d_h, video_frame->get()); |
495 return; | 506 return; |
496 } | 507 } |
497 CopyAPlane(vpx_image_alpha->planes[VPX_PLANE_Y], | 508 CopyAPlane(vpx_image_alpha->planes[VPX_PLANE_Y], |
498 vpx_image->stride[VPX_PLANE_Y], | 509 vpx_image->stride[VPX_PLANE_Y], |
499 vpx_image->d_h, | 510 vpx_image->d_h, |
500 video_frame->get()); | 511 video_frame->get()); |
501 } | 512 } |
502 | 513 |
503 } // namespace media | 514 } // namespace media |
OLD | NEW |