Chromium Code Reviews| 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/test/fake_video_encode_accelerator.h" | 5 #include "media/video/fake_video_encode_accelerator.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/location.h" | 8 #include "base/location.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/message_loop/message_loop_proxy.h" | |
| 10 #include "base/single_thread_task_runner.h" | 11 #include "base/single_thread_task_runner.h" |
| 11 | 12 |
| 12 namespace media { | 13 namespace media { |
| 13 namespace cast { | |
| 14 namespace test { | |
| 15 | 14 |
| 16 static const unsigned int kMinimumInputCount = 1; | 15 static const unsigned int kMinimumInputCount = 1; |
| 17 static const size_t kMinimumOutputBufferSize = 123456; | 16 static const size_t kMinimumOutputBufferSize = 1234; |
|
wuchengli
2014/12/09 14:29:25
Why this has been changed?
hellner1
2014/12/10 22:38:59
It happened during debugging. I put the old value
| |
| 17 | |
| 18 struct FakeVideoEncodeAccelerator::BitstreamBufferRef { | |
| 19 BitstreamBufferRef(int id, scoped_ptr<base::SharedMemory> shm, size_t size) | |
| 20 : id(id), shm(shm.Pass()), size(size) {} | |
| 21 const int id; | |
| 22 const scoped_ptr<base::SharedMemory> shm; | |
| 23 const size_t size; | |
| 24 }; | |
| 18 | 25 |
| 19 FakeVideoEncodeAccelerator::FakeVideoEncodeAccelerator( | 26 FakeVideoEncodeAccelerator::FakeVideoEncodeAccelerator( |
| 20 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, | 27 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, |
| 21 std::vector<uint32>* stored_bitrates) | 28 const std::vector<uint32>& stored_bitrates) |
| 22 : task_runner_(task_runner), | 29 : child_message_loop_proxy_(task_runner), |
|
wuchengli
2014/12/09 14:29:25
I assume you don't force FakeVEA to run on the chi
hellner1
2014/12/10 22:38:59
Done.
| |
| 23 stored_bitrates_(stored_bitrates), | 30 stored_bitrates_(stored_bitrates), |
| 24 client_(NULL), | 31 client_(NULL), |
| 25 first_(true), | 32 first_(true), |
| 26 will_initialization_succeed_(true), | 33 weak_this_factory_(this) {} |
| 27 weak_this_factory_(this) { | |
| 28 DCHECK(stored_bitrates_); | |
| 29 } | |
| 30 | 34 |
| 31 FakeVideoEncodeAccelerator::~FakeVideoEncodeAccelerator() { | 35 FakeVideoEncodeAccelerator::~FakeVideoEncodeAccelerator() { |
| 32 weak_this_factory_.InvalidateWeakPtrs(); | 36 weak_this_factory_.InvalidateWeakPtrs(); |
| 33 } | 37 } |
| 34 | 38 |
| 35 std::vector<VideoEncodeAccelerator::SupportedProfile> | 39 std::vector<VideoEncodeAccelerator::SupportedProfile> |
| 36 FakeVideoEncodeAccelerator::GetSupportedProfiles() { | 40 FakeVideoEncodeAccelerator::GetSupportedProfiles() { |
| 37 return std::vector<VideoEncodeAccelerator::SupportedProfile>(); | 41 return std::vector<VideoEncodeAccelerator::SupportedProfile>(); |
| 38 } | 42 } |
| 39 | 43 |
| 40 bool FakeVideoEncodeAccelerator::Initialize( | 44 bool FakeVideoEncodeAccelerator::Initialize( |
| 41 media::VideoFrame::Format input_format, | 45 VideoFrame::Format input_format, |
| 42 const gfx::Size& input_visible_size, | 46 const gfx::Size& input_visible_size, |
| 43 VideoCodecProfile output_profile, | 47 VideoCodecProfile output_profile, |
| 44 uint32 initial_bitrate, | 48 uint32 initial_bitrate, |
| 45 Client* client) { | 49 Client* client) { |
| 46 if (!will_initialization_succeed_) | 50 if (output_profile == VIDEO_CODEC_PROFILE_UNKNOWN) { |
|
wuchengli
2014/12/09 14:29:25
Return false for profile > VIDEO_CODEC_PROFILE_MAX
hellner1
2014/12/10 22:38:59
Done.
| |
| 47 return false; | |
| 48 client_ = client; | |
| 49 if (output_profile != media::VP8PROFILE_ANY && | |
| 50 output_profile != media::H264PROFILE_MAIN) { | |
| 51 return false; | 51 return false; |
|
wuchengli
2014/12/09 14:29:25
Why will_initialization_succeed_ is removed?
hellner1
2014/12/10 22:38:59
Done.
| |
| 52 } | 52 } |
| 53 task_runner_->PostTask( | 53 client_ = client; |
| 54 child_message_loop_proxy_->PostTask( | |
| 54 FROM_HERE, | 55 FROM_HERE, |
| 55 base::Bind(&FakeVideoEncodeAccelerator::DoRequireBitstreamBuffers, | 56 base::Bind(&FakeVideoEncodeAccelerator::DoRequireBitstreamBuffers, |
| 56 weak_this_factory_.GetWeakPtr(), | 57 weak_this_factory_.GetWeakPtr(), |
| 57 kMinimumInputCount, | 58 kMinimumInputCount, |
| 58 input_visible_size, | 59 input_visible_size, |
| 59 kMinimumOutputBufferSize)); | 60 kMinimumOutputBufferSize)); |
| 60 return true; | 61 return true; |
| 61 } | 62 } |
| 62 | 63 |
| 63 void FakeVideoEncodeAccelerator::Encode(const scoped_refptr<VideoFrame>& frame, | 64 void FakeVideoEncodeAccelerator::Encode( |
| 64 bool force_keyframe) { | 65 const scoped_refptr<VideoFrame>& frame, |
| 66 bool force_keyframe) { | |
| 65 DCHECK(client_); | 67 DCHECK(client_); |
| 66 DCHECK(!available_buffer_ids_.empty()); | 68 DCHECK(!available_buffers_.empty()); |
| 67 | 69 |
| 68 // Fake that we have encoded the frame; resulting in using the full output | 70 // Create fake encoded frame by just signaling that the buffer contains |
| 69 // buffer. | 71 // data. Note that the only thing written to the buffer is whether it is |
| 70 int32 id = available_buffer_ids_.front(); | 72 // a key frame or not. |
| 71 available_buffer_ids_.pop_front(); | 73 BitstreamBufferRef* buffer = available_buffers_.front().get(); |
| 74 int32 id = buffer->id; | |
| 75 bool is_key_frame = first_ || force_keyframe; | |
| 76 first_ = false; | |
| 72 | 77 |
| 73 bool is_key_fame = force_keyframe; | 78 uint8* stream = static_cast<uint8*>(buffer->shm->memory()); |
| 74 if (first_) { | 79 stream[0] = is_key_frame ? 0x00 : 0x01; // Key frame scheme = VP8 |
| 75 is_key_fame = true; | 80 DoBitstreamBufferReady(id, |
|
wuchengli
2014/12/09 14:29:25
Remove DoBitstreamBufferReady and just call client
hellner1
2014/12/10 22:38:59
I have to post here because calling client_->Bitst
wuchengli
2014/12/11 02:14:31
So you'll change this back to PostTask? The latest
hellner1
2014/12/11 19:34:19
Sorry, my bad here. Calling without posting does n
| |
| 76 first_ = false; | 81 kMinimumOutputBufferSize, |
| 77 } | 82 is_key_frame); |
| 78 task_runner_->PostTask( | 83 available_buffers_.pop_front(); |
| 79 FROM_HERE, | |
| 80 base::Bind(&FakeVideoEncodeAccelerator::DoBitstreamBufferReady, | |
| 81 weak_this_factory_.GetWeakPtr(), | |
| 82 id, | |
| 83 kMinimumOutputBufferSize, | |
| 84 is_key_fame)); | |
| 85 } | 84 } |
| 86 | 85 |
| 87 void FakeVideoEncodeAccelerator::UseOutputBitstreamBuffer( | 86 void FakeVideoEncodeAccelerator::UseOutputBitstreamBuffer( |
| 88 const BitstreamBuffer& buffer) { | 87 const BitstreamBuffer& buffer) { |
| 89 available_buffer_ids_.push_back(buffer.id()); | 88 scoped_ptr<base::SharedMemory> shm( |
| 89 new base::SharedMemory(buffer.handle(), false)); | |
| 90 if (!shm->Map(buffer.size())) { | |
| 91 LOG(ERROR) << "Shared memory failure"; | |
| 92 return; | |
| 93 } | |
| 94 available_buffers_.push_back( | |
|
wuchengli
2014/12/09 14:29:25
Can we store BitstreamBuffer in |available_buffers
hellner1
2014/12/10 22:38:59
FYI: this behavior is taken from here: https://cod
wuchengli
2014/12/11 02:14:31
I guess v4l2VEA needs to map the memory in UseOutp
hellner1
2014/12/11 19:34:19
Done.
| |
| 95 scoped_ptr<BitstreamBufferRef>( | |
| 96 new BitstreamBufferRef(buffer.id(), shm.Pass(), buffer.size()))); | |
| 90 } | 97 } |
| 91 | 98 |
| 92 void FakeVideoEncodeAccelerator::RequestEncodingParametersChange( | 99 void FakeVideoEncodeAccelerator::RequestEncodingParametersChange( |
| 93 uint32 bitrate, | 100 uint32 bitrate, |
| 94 uint32 framerate) { | 101 uint32 framerate) { |
| 95 stored_bitrates_->push_back(bitrate); | 102 stored_bitrates_.push_back(bitrate); |
| 96 } | 103 } |
| 97 | 104 |
| 98 void FakeVideoEncodeAccelerator::Destroy() { delete this; } | 105 void FakeVideoEncodeAccelerator::Destroy() { delete this; } |
| 99 | 106 |
| 100 void FakeVideoEncodeAccelerator::SendDummyFrameForTesting(bool key_frame) { | 107 void FakeVideoEncodeAccelerator::SendDummyFrameForTesting(bool key_frame) { |
| 101 DoBitstreamBufferReady(0, 23, key_frame); | 108 DoBitstreamBufferReady(0, 23, key_frame); |
| 102 } | 109 } |
| 103 | 110 |
| 111 void FakeVideoEncodeAccelerator::SetWillInitializationSucceed( | |
| 112 bool will_initialization_succeed) { | |
| 113 will_initialization_succeed_ = will_initialization_succeed; | |
| 114 } | |
| 115 | |
| 104 void FakeVideoEncodeAccelerator::DoRequireBitstreamBuffers( | 116 void FakeVideoEncodeAccelerator::DoRequireBitstreamBuffers( |
| 105 unsigned int input_count, | 117 unsigned int input_count, |
| 106 const gfx::Size& input_coded_size, | 118 const gfx::Size& input_coded_size, |
| 107 size_t output_buffer_size) const { | 119 size_t output_buffer_size) const { |
| 108 client_->RequireBitstreamBuffers( | 120 client_->RequireBitstreamBuffers( |
| 109 input_count, input_coded_size, output_buffer_size); | 121 input_count, input_coded_size, output_buffer_size); |
| 110 } | 122 } |
| 111 | 123 |
| 112 void FakeVideoEncodeAccelerator::DoBitstreamBufferReady( | 124 void FakeVideoEncodeAccelerator::DoBitstreamBufferReady( |
| 113 int32 bitstream_buffer_id, | 125 int32 bitstream_buffer_id, |
| 114 size_t payload_size, | 126 size_t payload_size, |
| 115 bool key_frame) const { | 127 bool key_frame) const { |
| 116 client_->BitstreamBufferReady(bitstream_buffer_id, payload_size, key_frame); | 128 client_->BitstreamBufferReady(bitstream_buffer_id, payload_size, key_frame); |
| 117 } | 129 } |
| 118 | 130 |
| 119 } // namespace test | |
| 120 } // namespace cast | |
| 121 } // namespace media | 131 } // namespace media |
| OLD | NEW |