Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/browser/renderer_host/media/video_capture_device_client.h" | 5 #include "content/browser/renderer_host/media/video_capture_device_client.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/strings/stringprintf.h" | 8 #include "base/strings/stringprintf.h" |
| 9 #include "base/trace_event/trace_event.h" | 9 #include "base/trace_event/trace_event.h" |
| 10 #include "content/browser/compositor/image_transport_factory.h" | 10 #include "content/browser/compositor/image_transport_factory.h" |
| 11 #include "content/browser/gpu/browser_gpu_channel_host_factory.h" | 11 #include "content/browser/gpu/browser_gpu_channel_host_factory.h" |
| 12 #include "content/browser/gpu/browser_gpu_memory_buffer_manager.h" | 12 #include "content/browser/gpu/browser_gpu_memory_buffer_manager.h" |
| 13 #include "content/browser/gpu/gpu_data_manager_impl.h" | 13 #include "content/browser/gpu/gpu_data_manager_impl.h" |
| 14 #include "content/browser/renderer_host/gpu_jpeg_decoder.h" | |
| 14 #include "content/browser/renderer_host/media/video_capture_buffer_pool.h" | 15 #include "content/browser/renderer_host/media/video_capture_buffer_pool.h" |
| 15 #include "content/browser/renderer_host/media/video_capture_controller.h" | 16 #include "content/browser/renderer_host/media/video_capture_controller.h" |
| 16 #include "content/common/gpu/client/context_provider_command_buffer.h" | 17 #include "content/common/gpu/client/context_provider_command_buffer.h" |
| 17 #include "content/common/gpu/client/gl_helper.h" | 18 #include "content/common/gpu/client/gl_helper.h" |
| 18 #include "content/common/gpu/client/gpu_channel_host.h" | 19 #include "content/common/gpu/client/gpu_channel_host.h" |
| 19 #include "content/common/gpu/client/webgraphicscontext3d_command_buffer_impl.h" | 20 #include "content/common/gpu/client/webgraphicscontext3d_command_buffer_impl.h" |
| 20 #include "content/common/gpu/gpu_process_launch_causes.h" | 21 #include "content/common/gpu/gpu_process_launch_causes.h" |
| 21 #include "content/public/browser/browser_thread.h" | 22 #include "content/public/browser/browser_thread.h" |
| 22 #include "gpu/command_buffer/common/mailbox_holder.h" | 23 #include "gpu/command_buffer/common/mailbox_holder.h" |
| 23 #include "media/base/bind_to_current_loop.h" | 24 #include "media/base/bind_to_current_loop.h" |
| (...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 113 pool_(pool), | 114 pool_(pool), |
| 114 buffer_handle_(pool_->GetBufferHandle(buffer_id).Pass()) { | 115 buffer_handle_(pool_->GetBufferHandle(buffer_id).Pass()) { |
| 115 DCHECK(pool_.get()); | 116 DCHECK(pool_.get()); |
| 116 } | 117 } |
| 117 int id() const override { return id_; } | 118 int id() const override { return id_; } |
| 118 size_t size() const override { return buffer_handle_->size(); } | 119 size_t size() const override { return buffer_handle_->size(); } |
| 119 void* data() override { return buffer_handle_->data(); } | 120 void* data() override { return buffer_handle_->data(); } |
| 120 ClientBuffer AsClientBuffer() override { | 121 ClientBuffer AsClientBuffer() override { |
| 121 return buffer_handle_->AsClientBuffer(); | 122 return buffer_handle_->AsClientBuffer(); |
| 122 } | 123 } |
| 124 base::SharedMemoryHandle AsPlatformHandle() override { | |
| 125 return buffer_handle_->AsPlatformHandle(); | |
| 126 } | |
| 123 | 127 |
| 124 private: | 128 private: |
| 125 ~AutoReleaseBuffer() override { pool_->RelinquishProducerReservation(id_); } | 129 ~AutoReleaseBuffer() override { pool_->RelinquishProducerReservation(id_); } |
| 126 | 130 |
| 127 const int id_; | 131 const int id_; |
| 128 const scoped_refptr<VideoCaptureBufferPool> pool_; | 132 const scoped_refptr<VideoCaptureBufferPool> pool_; |
| 129 const scoped_ptr<VideoCaptureBufferPool::BufferHandle> buffer_handle_; | 133 const scoped_ptr<VideoCaptureBufferPool::BufferHandle> buffer_handle_; |
| 130 }; | 134 }; |
| 131 | 135 |
| 132 // Internal ref-counted class wrapping an incoming GpuMemoryBuffer into a | 136 // Internal ref-counted class wrapping an incoming GpuMemoryBuffer into a |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 190 | 194 |
| 191 VideoCaptureDeviceClient::VideoCaptureDeviceClient( | 195 VideoCaptureDeviceClient::VideoCaptureDeviceClient( |
| 192 const base::WeakPtr<VideoCaptureController>& controller, | 196 const base::WeakPtr<VideoCaptureController>& controller, |
| 193 const scoped_refptr<VideoCaptureBufferPool>& buffer_pool, | 197 const scoped_refptr<VideoCaptureBufferPool>& buffer_pool, |
| 194 const scoped_refptr<base::SingleThreadTaskRunner>& capture_task_runner) | 198 const scoped_refptr<base::SingleThreadTaskRunner>& capture_task_runner) |
| 195 : controller_(controller), | 199 : controller_(controller), |
| 196 buffer_pool_(buffer_pool), | 200 buffer_pool_(buffer_pool), |
| 197 capture_task_runner_(capture_task_runner), | 201 capture_task_runner_(capture_task_runner), |
| 198 last_captured_pixel_format_(media::PIXEL_FORMAT_UNKNOWN) { | 202 last_captured_pixel_format_(media::PIXEL_FORMAT_UNKNOWN) { |
| 199 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 203 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 204 if (GpuJpegDecoder::Supported()) { | |
| 205 external_jpeg_decoder_.reset(new GpuJpegDecoder( | |
| 206 this, | |
| 207 base::Bind( | |
| 208 &VideoCaptureController::DoIncomingCapturedVideoFrameOnIOThread, | |
| 209 controller_))); | |
| 210 } | |
| 200 } | 211 } |
| 201 | 212 |
| 202 VideoCaptureDeviceClient::~VideoCaptureDeviceClient() {} | 213 VideoCaptureDeviceClient::~VideoCaptureDeviceClient() { |
| 214 } | |
| 203 | 215 |
| 204 void VideoCaptureDeviceClient::OnIncomingCapturedData( | 216 void VideoCaptureDeviceClient::OnIncomingCapturedData( |
| 205 const uint8* data, | 217 const uint8* data, |
| 206 int length, | 218 int length, |
| 207 const VideoCaptureFormat& frame_format, | 219 const VideoCaptureFormat& frame_format, |
| 208 int rotation, | 220 int rotation, |
| 209 const base::TimeTicks& timestamp) { | 221 const base::TimeTicks& timestamp) { |
| 210 TRACE_EVENT0("video", "VideoCaptureDeviceClient::OnIncomingCapturedData"); | 222 TRACE_EVENT0("video", "VideoCaptureDeviceClient::OnIncomingCapturedData"); |
| 211 | 223 |
| 212 if (last_captured_pixel_format_ != frame_format.pixel_format) { | 224 if (last_captured_pixel_format_ != frame_format.pixel_format) { |
| 213 OnLog("Pixel format: " + media::VideoCaptureFormat::PixelFormatToString( | 225 OnLog("Pixel format: " + media::VideoCaptureFormat::PixelFormatToString( |
| 214 frame_format.pixel_format)); | 226 frame_format.pixel_format)); |
| 215 last_captured_pixel_format_ = frame_format.pixel_format; | 227 last_captured_pixel_format_ = frame_format.pixel_format; |
| 228 | |
| 229 if (frame_format.pixel_format == media::PIXEL_FORMAT_MJPEG && | |
| 230 external_jpeg_decoder_) | |
|
mcasas
2015/05/07 00:59:03
With this condition, we would be calling
external
wuchengli
2015/05/07 06:23:14
Not every incoming frame. Only when format changes
kcwu
2015/05/08 14:42:42
This only happens when pixel_format becomes from n
kcwu
2015/05/08 14:42:42
Acknowledged.
| |
| 231 ignore_result(external_jpeg_decoder_->Initialize()); | |
|
wuchengli
2015/05/04 14:14:41
Why not set |external_jpeg_decoder_| to NULL if In
wuchengli
2015/05/06 07:59:18
As discussed, if Initialize fails, there will be n
kcwu
2015/05/08 14:42:42
Done.
kcwu
2015/05/08 14:42:42
Done.
| |
| 216 } | 232 } |
| 217 | 233 |
| 218 if (!frame_format.IsValid()) | 234 if (!frame_format.IsValid()) |
| 219 return; | 235 return; |
| 220 | 236 |
| 237 if (frame_format.pixel_format == media::PIXEL_FORMAT_MJPEG && | |
| 238 external_jpeg_decoder_) { | |
|
mcasas
2015/05/07 00:59:03
nit: Merge all conditions in lines l.237-238.
kcwu
2015/05/08 14:42:42
Acknowledged.
This is changed to no fallback.
| |
| 239 if (external_jpeg_decoder_->DecodeCapturedData(data, length, frame_format, | |
| 240 rotation, timestamp)) | |
| 241 return; | |
| 242 } | |
| 243 | |
| 221 // |chopped_{width,height} and |new_unrotated_{width,height}| are the lowest | 244 // |chopped_{width,height} and |new_unrotated_{width,height}| are the lowest |
| 222 // bit decomposition of {width, height}, grabbing the odd and even parts. | 245 // bit decomposition of {width, height}, grabbing the odd and even parts. |
| 223 const int chopped_width = frame_format.frame_size.width() & 1; | 246 const int chopped_width = frame_format.frame_size.width() & 1; |
| 224 const int chopped_height = frame_format.frame_size.height() & 1; | 247 const int chopped_height = frame_format.frame_size.height() & 1; |
| 225 const int new_unrotated_width = frame_format.frame_size.width() & ~1; | 248 const int new_unrotated_width = frame_format.frame_size.width() & ~1; |
| 226 const int new_unrotated_height = frame_format.frame_size.height() & ~1; | 249 const int new_unrotated_height = frame_format.frame_size.height() & ~1; |
| 227 | 250 |
| 228 int destination_width = new_unrotated_width; | 251 int destination_width = new_unrotated_width; |
| 229 int destination_height = new_unrotated_height; | 252 int destination_height = new_unrotated_height; |
| 230 if (rotation == 90 || rotation == 270) { | 253 if (rotation == 90 || rotation == 270) { |
| (...skipping 433 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 664 void VideoCaptureDeviceClient::TextureWrapHelper::OnError( | 687 void VideoCaptureDeviceClient::TextureWrapHelper::OnError( |
| 665 const std::string& message) { | 688 const std::string& message) { |
| 666 DCHECK(capture_task_runner_->BelongsToCurrentThread()); | 689 DCHECK(capture_task_runner_->BelongsToCurrentThread()); |
| 667 DLOG(ERROR) << message; | 690 DLOG(ERROR) << message; |
| 668 BrowserThread::PostTask( | 691 BrowserThread::PostTask( |
| 669 BrowserThread::IO, FROM_HERE, | 692 BrowserThread::IO, FROM_HERE, |
| 670 base::Bind(&VideoCaptureController::DoErrorOnIOThread, controller_)); | 693 base::Bind(&VideoCaptureController::DoErrorOnIOThread, controller_)); |
| 671 } | 694 } |
| 672 | 695 |
| 673 } // namespace content | 696 } // namespace content |
| OLD | NEW |