Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(86)

Side by Side Diff: content/common/gpu/media/gpu_video_encode_accelerator.cc

Issue 832383004: Revert of Support multiple video decoders and encoders (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "content/common/gpu/media/gpu_video_encode_accelerator.h" 5 #include "content/common/gpu/media/gpu_video_encode_accelerator.h"
6 6
7 #include "base/callback.h" 7 #include "base/callback.h"
8 #include "base/command_line.h" 8 #include "base/command_line.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/memory/shared_memory.h" 10 #include "base/memory/shared_memory.h"
11 #include "base/message_loop/message_loop_proxy.h" 11 #include "base/message_loop/message_loop_proxy.h"
12 #include "build/build_config.h" 12 #include "build/build_config.h"
13 #include "content/common/gpu/gpu_channel.h" 13 #include "content/common/gpu/gpu_channel.h"
14 #include "content/common/gpu/gpu_messages.h" 14 #include "content/common/gpu/gpu_messages.h"
15 #include "content/public/common/content_switches.h" 15 #include "content/public/common/content_switches.h"
16 #include "ipc/ipc_message_macros.h" 16 #include "ipc/ipc_message_macros.h"
17 #include "media/base/limits.h" 17 #include "media/base/limits.h"
18 #include "media/base/video_frame.h" 18 #include "media/base/video_frame.h"
19 19
20 #if defined(OS_CHROMEOS) 20 #if defined(OS_CHROMEOS)
21 #if defined(USE_OZONE) || defined(ARCH_CPU_ARMEL) 21
22 #if defined(ARCH_CPU_ARMEL) && defined(USE_X11)
22 #include "content/common/gpu/media/v4l2_video_encode_accelerator.h" 23 #include "content/common/gpu/media/v4l2_video_encode_accelerator.h"
23 #endif // defined(USE_OZONE) || defined(ARCH_CPU_ARMEL) 24 #elif defined(ARCH_CPU_X86_FAMILY)
24 #if defined(ARCH_CPU_X86_FAMILY)
25 #include "content/common/gpu/media/vaapi_video_encode_accelerator.h" 25 #include "content/common/gpu/media/vaapi_video_encode_accelerator.h"
26 #endif // defined(ARCH_CPU_X86_FAMILY) 26 #endif
27
27 #elif defined(OS_ANDROID) && defined(ENABLE_WEBRTC) 28 #elif defined(OS_ANDROID) && defined(ENABLE_WEBRTC)
28 #include "content/common/gpu/media/android_video_encode_accelerator.h" 29 #include "content/common/gpu/media/android_video_encode_accelerator.h"
29 #endif 30 #endif
30 31
31 namespace content { 32 namespace content {
32 33
33 static bool MakeDecoderContextCurrent( 34 static bool MakeDecoderContextCurrent(
34 const base::WeakPtr<GpuCommandBufferStub> stub) { 35 const base::WeakPtr<GpuCommandBufferStub> stub) {
35 if (!stub) { 36 if (!stub) {
36 DLOG(ERROR) << "Stub is gone; won't MakeCurrent()."; 37 DLOG(ERROR) << "Stub is gone; won't MakeCurrent().";
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
86 if (input_visible_size.width() > media::limits::kMaxDimension || 87 if (input_visible_size.width() > media::limits::kMaxDimension ||
87 input_visible_size.height() > media::limits::kMaxDimension || 88 input_visible_size.height() > media::limits::kMaxDimension ||
88 input_visible_size.GetArea() > media::limits::kMaxCanvas) { 89 input_visible_size.GetArea() > media::limits::kMaxCanvas) {
89 DLOG(ERROR) << "GpuVideoEncodeAccelerator::Initialize(): " 90 DLOG(ERROR) << "GpuVideoEncodeAccelerator::Initialize(): "
90 "input_visible_size " << input_visible_size.ToString() 91 "input_visible_size " << input_visible_size.ToString()
91 << " too large"; 92 << " too large";
92 SendCreateEncoderReply(init_done_msg, false); 93 SendCreateEncoderReply(init_done_msg, false);
93 return; 94 return;
94 } 95 }
95 96
96 std::vector<GpuVideoEncodeAccelerator::CreateVEAFp> 97 encoder_ = CreateEncoder();
97 create_vea_fps = CreateVEAFps(); 98 if (!encoder_) {
98 // Try all possible encoders and use the first successful encoder. 99 DLOG(ERROR)
99 for (size_t i = 0; i < create_vea_fps.size(); ++i) { 100 << "GpuVideoEncodeAccelerator::Initialize(): VEA creation failed";
100 encoder_ = (*create_vea_fps[i])(); 101 SendCreateEncoderReply(init_done_msg, false);
101 if (encoder_ && encoder_->Initialize(input_format, 102 return;
102 input_visible_size,
103 output_profile,
104 initial_bitrate,
105 this)) {
106 input_format_ = input_format;
107 input_visible_size_ = input_visible_size;
108 SendCreateEncoderReply(init_done_msg, true);
109 return;
110 }
111 } 103 }
112 encoder_.reset(); 104 if (!encoder_->Initialize(input_format,
113 DLOG(ERROR) 105 input_visible_size,
114 << "GpuVideoEncodeAccelerator::Initialize(): VEA initialization failed"; 106 output_profile,
115 SendCreateEncoderReply(init_done_msg, false); 107 initial_bitrate,
108 this)) {
109 DLOG(ERROR)
110 << "GpuVideoEncodeAccelerator::Initialize(): VEA initialization failed";
111 SendCreateEncoderReply(init_done_msg, false);
112 return;
113 }
114 input_format_ = input_format;
115 input_visible_size_ = input_visible_size;
116 SendCreateEncoderReply(init_done_msg, true);
116 } 117 }
117 118
118 bool GpuVideoEncodeAccelerator::OnMessageReceived(const IPC::Message& message) { 119 bool GpuVideoEncodeAccelerator::OnMessageReceived(const IPC::Message& message) {
119 bool handled = true; 120 bool handled = true;
120 IPC_BEGIN_MESSAGE_MAP(GpuVideoEncodeAccelerator, message) 121 IPC_BEGIN_MESSAGE_MAP(GpuVideoEncodeAccelerator, message)
121 IPC_MESSAGE_HANDLER(AcceleratedVideoEncoderMsg_Encode, OnEncode) 122 IPC_MESSAGE_HANDLER(AcceleratedVideoEncoderMsg_Encode, OnEncode)
122 IPC_MESSAGE_HANDLER(AcceleratedVideoEncoderMsg_UseOutputBitstreamBuffer, 123 IPC_MESSAGE_HANDLER(AcceleratedVideoEncoderMsg_UseOutputBitstreamBuffer,
123 OnUseOutputBitstreamBuffer) 124 OnUseOutputBitstreamBuffer)
124 IPC_MESSAGE_HANDLER( 125 IPC_MESSAGE_HANDLER(
125 AcceleratedVideoEncoderMsg_RequestEncodingParametersChange, 126 AcceleratedVideoEncoderMsg_RequestEncodingParametersChange,
(...skipping 30 matching lines...) Expand all
156 DCHECK(stub_); 157 DCHECK(stub_);
157 stub_->channel()->RemoveRoute(host_route_id_); 158 stub_->channel()->RemoveRoute(host_route_id_);
158 stub_->RemoveDestructionObserver(this); 159 stub_->RemoveDestructionObserver(this);
159 encoder_.reset(); 160 encoder_.reset();
160 delete this; 161 delete this;
161 } 162 }
162 163
163 // static 164 // static
164 std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> 165 std::vector<gpu::VideoEncodeAcceleratorSupportedProfile>
165 GpuVideoEncodeAccelerator::GetSupportedProfiles() { 166 GpuVideoEncodeAccelerator::GetSupportedProfiles() {
166 std::vector<media::VideoEncodeAccelerator::SupportedProfile> profiles; 167 scoped_ptr<media::VideoEncodeAccelerator> encoder = CreateEncoder();
167 std::vector<GpuVideoEncodeAccelerator::CreateVEAFp> 168 if (!encoder)
168 create_vea_fps = CreateVEAFps(); 169 return std::vector<gpu::VideoEncodeAcceleratorSupportedProfile>();
169 170 return ConvertMediaToGpuProfiles(encoder->GetSupportedProfiles());
170 for (size_t i = 0; i < create_vea_fps.size(); ++i) {
171 scoped_ptr<media::VideoEncodeAccelerator>
172 encoder = (*create_vea_fps[i])();
173 if (!encoder)
174 continue;
175 std::vector<media::VideoEncodeAccelerator::SupportedProfile>
176 vea_profiles = encoder->GetSupportedProfiles();
177 profiles.insert(profiles.end(), vea_profiles.begin(), vea_profiles.end());
178 }
179 return ConvertMediaToGpuProfiles(profiles);
180 } 171 }
181 172
182 // static
183 std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> 173 std::vector<gpu::VideoEncodeAcceleratorSupportedProfile>
184 GpuVideoEncodeAccelerator::ConvertMediaToGpuProfiles(const std::vector< 174 GpuVideoEncodeAccelerator::ConvertMediaToGpuProfiles(const std::vector<
185 media::VideoEncodeAccelerator::SupportedProfile>& media_profiles) { 175 media::VideoEncodeAccelerator::SupportedProfile>& media_profiles) {
186 std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> profiles; 176 std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> profiles;
187 for (size_t i = 0; i < media_profiles.size(); i++) { 177 for (size_t i = 0; i < media_profiles.size(); i++) {
188 gpu::VideoEncodeAcceleratorSupportedProfile profile; 178 gpu::VideoEncodeAcceleratorSupportedProfile profile;
189 profile.profile = 179 profile.profile =
190 static_cast<gpu::VideoCodecProfile>(media_profiles[i].profile); 180 static_cast<gpu::VideoCodecProfile>(media_profiles[i].profile);
191 profile.max_resolution = media_profiles[i].max_resolution; 181 profile.max_resolution = media_profiles[i].max_resolution;
192 profile.max_framerate_numerator = media_profiles[i].max_framerate_numerator; 182 profile.max_framerate_numerator = media_profiles[i].max_framerate_numerator;
193 profile.max_framerate_denominator = 183 profile.max_framerate_denominator =
194 media_profiles[i].max_framerate_denominator; 184 media_profiles[i].max_framerate_denominator;
195 profiles.push_back(profile); 185 profiles.push_back(profile);
196 } 186 }
197 return profiles; 187 return profiles;
198 } 188 }
199 189
200 // static
201 std::vector<GpuVideoEncodeAccelerator::CreateVEAFp>
202 GpuVideoEncodeAccelerator::CreateVEAFps() {
203 std::vector<GpuVideoEncodeAccelerator::CreateVEAFp> create_vea_fps;
204 create_vea_fps.push_back(&GpuVideoEncodeAccelerator::CreateV4L2VEA);
205 create_vea_fps.push_back(&GpuVideoEncodeAccelerator::CreateVaapiVEA);
206 create_vea_fps.push_back(&GpuVideoEncodeAccelerator::CreateAndroidVEA);
207 return create_vea_fps;
208 }
209
210 // static
211 scoped_ptr<media::VideoEncodeAccelerator> 190 scoped_ptr<media::VideoEncodeAccelerator>
212 GpuVideoEncodeAccelerator::CreateV4L2VEA() { 191 GpuVideoEncodeAccelerator::CreateEncoder() {
213 scoped_ptr<media::VideoEncodeAccelerator> encoder; 192 scoped_ptr<media::VideoEncodeAccelerator> encoder;
214 #if defined(OS_CHROMEOS) && (defined(USE_OZONE) || defined(ARCH_CPU_ARMEL)) 193 #if defined(OS_CHROMEOS)
194 #if defined(ARCH_CPU_ARMEL) && defined(USE_X11)
215 scoped_ptr<V4L2Device> device = V4L2Device::Create(V4L2Device::kEncoder); 195 scoped_ptr<V4L2Device> device = V4L2Device::Create(V4L2Device::kEncoder);
216 if (device) 196 if (device)
217 encoder.reset(new V4L2VideoEncodeAccelerator(device.Pass())); 197 encoder.reset(new V4L2VideoEncodeAccelerator(device.Pass()));
218 #endif 198 #elif defined(ARCH_CPU_X86_FAMILY)
219 return encoder.Pass();
220 }
221
222 // static
223 scoped_ptr<media::VideoEncodeAccelerator>
224 GpuVideoEncodeAccelerator::CreateVaapiVEA() {
225 scoped_ptr<media::VideoEncodeAccelerator> encoder;
226 #if defined(OS_CHROMEOS) && defined(ARCH_CPU_X86_FAMILY)
227 const base::CommandLine* cmd_line = base::CommandLine::ForCurrentProcess(); 199 const base::CommandLine* cmd_line = base::CommandLine::ForCurrentProcess();
228 if (!cmd_line->HasSwitch(switches::kDisableVaapiAcceleratedVideoEncode)) 200 if (!cmd_line->HasSwitch(switches::kDisableVaapiAcceleratedVideoEncode))
229 encoder.reset(new VaapiVideoEncodeAccelerator()); 201 encoder.reset(new VaapiVideoEncodeAccelerator());
230 #endif 202 #endif
231 return encoder.Pass(); 203 #elif defined(OS_ANDROID) && defined(ENABLE_WEBRTC)
232 }
233
234 // static
235 scoped_ptr<media::VideoEncodeAccelerator>
236 GpuVideoEncodeAccelerator::CreateAndroidVEA() {
237 scoped_ptr<media::VideoEncodeAccelerator> encoder;
238 #if defined(OS_ANDROID) && defined(ENABLE_WEBRTC)
239 encoder.reset(new AndroidVideoEncodeAccelerator()); 204 encoder.reset(new AndroidVideoEncodeAccelerator());
240 #endif 205 #endif
241 return encoder.Pass(); 206 return encoder.Pass();
242 } 207 }
243 208
244 void GpuVideoEncodeAccelerator::OnEncode(int32 frame_id, 209 void GpuVideoEncodeAccelerator::OnEncode(int32 frame_id,
245 base::SharedMemoryHandle buffer_handle, 210 base::SharedMemoryHandle buffer_handle,
246 uint32 buffer_size, 211 uint32 buffer_size,
247 bool force_keyframe) { 212 bool force_keyframe) {
248 DVLOG(3) << "GpuVideoEncodeAccelerator::OnEncode(): frame_id=" << frame_id 213 DVLOG(3) << "GpuVideoEncodeAccelerator::OnEncode(): frame_id=" << frame_id
(...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after
349 stub_->channel()->Send(message); 314 stub_->channel()->Send(message);
350 } 315 }
351 316
352 void GpuVideoEncodeAccelerator::SendCreateEncoderReply(IPC::Message* message, 317 void GpuVideoEncodeAccelerator::SendCreateEncoderReply(IPC::Message* message,
353 bool succeeded) { 318 bool succeeded) {
354 GpuCommandBufferMsg_CreateVideoEncoder::WriteReplyParams(message, succeeded); 319 GpuCommandBufferMsg_CreateVideoEncoder::WriteReplyParams(message, succeeded);
355 Send(message); 320 Send(message);
356 } 321 }
357 322
358 } // namespace content 323 } // namespace content
OLDNEW
« no previous file with comments | « content/common/gpu/media/gpu_video_encode_accelerator.h ('k') | content/common/gpu/media/v4l2_image_processor.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698