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 <fcntl.h> | 5 #include <fcntl.h> |
6 #include <linux/videodev2.h> | 6 #include <linux/videodev2.h> |
7 #include <poll.h> | 7 #include <poll.h> |
8 #include <string.h> | 8 #include <string.h> |
9 #include <sys/eventfd.h> | 9 #include <sys/eventfd.h> |
10 #include <sys/ioctl.h> | 10 #include <sys/ioctl.h> |
11 #include <sys/mman.h> | 11 #include <sys/mman.h> |
12 #include <utility> | 12 #include <utility> |
13 | 13 |
14 #include "base/callback.h" | 14 #include "base/callback.h" |
15 #include "base/command_line.h" | 15 #include "base/command_line.h" |
16 #include "base/macros.h" | 16 #include "base/macros.h" |
17 #include "base/numerics/safe_conversions.h" | 17 #include "base/numerics/safe_conversions.h" |
18 #include "base/thread_task_runner_handle.h" | 18 #include "base/thread_task_runner_handle.h" |
19 #include "base/trace_event/trace_event.h" | 19 #include "base/trace_event/trace_event.h" |
| 20 #include "content/common/gpu/media/shared_memory_region.h" |
20 #include "content/common/gpu/media/v4l2_video_encode_accelerator.h" | 21 #include "content/common/gpu/media/v4l2_video_encode_accelerator.h" |
21 #include "content/public/common/content_switches.h" | 22 #include "content/public/common/content_switches.h" |
22 #include "media/base/bitstream_buffer.h" | 23 #include "media/base/bitstream_buffer.h" |
23 | 24 |
24 #define NOTIFY_ERROR(x) \ | 25 #define NOTIFY_ERROR(x) \ |
25 do { \ | 26 do { \ |
26 LOG(ERROR) << "Setting error state:" << x; \ | 27 LOG(ERROR) << "Setting error state:" << x; \ |
27 SetErrorState(x); \ | 28 SetErrorState(x); \ |
28 } while (0) | 29 } while (0) |
29 | 30 |
(...skipping 14 matching lines...) Expand all Loading... |
44 | 45 |
45 #define IOCTL_OR_LOG_ERROR(type, arg) \ | 46 #define IOCTL_OR_LOG_ERROR(type, arg) \ |
46 do { \ | 47 do { \ |
47 if (device_->Ioctl(type, arg) != 0) \ | 48 if (device_->Ioctl(type, arg) != 0) \ |
48 PLOG(ERROR) << __func__ << "(): ioctl() failed: " << #type; \ | 49 PLOG(ERROR) << __func__ << "(): ioctl() failed: " << #type; \ |
49 } while (0) | 50 } while (0) |
50 | 51 |
51 namespace content { | 52 namespace content { |
52 | 53 |
53 struct V4L2VideoEncodeAccelerator::BitstreamBufferRef { | 54 struct V4L2VideoEncodeAccelerator::BitstreamBufferRef { |
54 BitstreamBufferRef(int32_t id, | 55 BitstreamBufferRef(int32_t id, scoped_ptr<SharedMemoryRegion> shm) |
55 scoped_ptr<base::SharedMemory> shm, | 56 : id(id), shm(std::move(shm)) {} |
56 size_t size) | |
57 : id(id), shm(std::move(shm)), size(size) {} | |
58 const int32_t id; | 57 const int32_t id; |
59 const scoped_ptr<base::SharedMemory> shm; | 58 const scoped_ptr<SharedMemoryRegion> shm; |
60 const size_t size; | |
61 }; | 59 }; |
62 | 60 |
63 V4L2VideoEncodeAccelerator::InputRecord::InputRecord() : at_device(false) { | 61 V4L2VideoEncodeAccelerator::InputRecord::InputRecord() : at_device(false) { |
64 } | 62 } |
65 | 63 |
66 V4L2VideoEncodeAccelerator::InputRecord::~InputRecord() { | 64 V4L2VideoEncodeAccelerator::InputRecord::~InputRecord() { |
67 } | 65 } |
68 | 66 |
69 V4L2VideoEncodeAccelerator::OutputRecord::OutputRecord() | 67 V4L2VideoEncodeAccelerator::OutputRecord::OutputRecord() |
70 : at_device(false), address(NULL), length(0) { | 68 : at_device(false), address(NULL), length(0) { |
(...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
217 void V4L2VideoEncodeAccelerator::UseOutputBitstreamBuffer( | 215 void V4L2VideoEncodeAccelerator::UseOutputBitstreamBuffer( |
218 const media::BitstreamBuffer& buffer) { | 216 const media::BitstreamBuffer& buffer) { |
219 DVLOG(3) << "UseOutputBitstreamBuffer(): id=" << buffer.id(); | 217 DVLOG(3) << "UseOutputBitstreamBuffer(): id=" << buffer.id(); |
220 DCHECK(child_task_runner_->BelongsToCurrentThread()); | 218 DCHECK(child_task_runner_->BelongsToCurrentThread()); |
221 | 219 |
222 if (buffer.size() < output_buffer_byte_size_) { | 220 if (buffer.size() < output_buffer_byte_size_) { |
223 NOTIFY_ERROR(kInvalidArgumentError); | 221 NOTIFY_ERROR(kInvalidArgumentError); |
224 return; | 222 return; |
225 } | 223 } |
226 | 224 |
227 scoped_ptr<base::SharedMemory> shm( | 225 scoped_ptr<SharedMemoryRegion> shm(new SharedMemoryRegion(buffer, false)); |
228 new base::SharedMemory(buffer.handle(), false)); | 226 if (!shm->Map()) { |
229 if (!shm->Map(buffer.size())) { | |
230 NOTIFY_ERROR(kPlatformFailureError); | 227 NOTIFY_ERROR(kPlatformFailureError); |
231 return; | 228 return; |
232 } | 229 } |
233 | 230 |
234 scoped_ptr<BitstreamBufferRef> buffer_ref( | 231 scoped_ptr<BitstreamBufferRef> buffer_ref( |
235 new BitstreamBufferRef(buffer.id(), std::move(shm), buffer.size())); | 232 new BitstreamBufferRef(buffer.id(), std::move(shm))); |
236 encoder_thread_.message_loop()->PostTask( | 233 encoder_thread_.message_loop()->PostTask( |
237 FROM_HERE, | 234 FROM_HERE, |
238 base::Bind(&V4L2VideoEncodeAccelerator::UseOutputBitstreamBufferTask, | 235 base::Bind(&V4L2VideoEncodeAccelerator::UseOutputBitstreamBufferTask, |
239 base::Unretained(this), | 236 base::Unretained(this), |
240 base::Passed(&buffer_ref))); | 237 base::Passed(&buffer_ref))); |
241 } | 238 } |
242 | 239 |
243 void V4L2VideoEncodeAccelerator::RequestEncodingParametersChange( | 240 void V4L2VideoEncodeAccelerator::RequestEncodingParametersChange( |
244 uint32_t bitrate, | 241 uint32_t bitrate, |
245 uint32_t framerate) { | 242 uint32_t framerate) { |
(...skipping 928 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1174 reqbufs.count = 0; | 1171 reqbufs.count = 0; |
1175 reqbufs.type = V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE; | 1172 reqbufs.type = V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE; |
1176 reqbufs.memory = V4L2_MEMORY_MMAP; | 1173 reqbufs.memory = V4L2_MEMORY_MMAP; |
1177 IOCTL_OR_LOG_ERROR(VIDIOC_REQBUFS, &reqbufs); | 1174 IOCTL_OR_LOG_ERROR(VIDIOC_REQBUFS, &reqbufs); |
1178 | 1175 |
1179 output_buffer_map_.clear(); | 1176 output_buffer_map_.clear(); |
1180 free_output_buffers_.clear(); | 1177 free_output_buffers_.clear(); |
1181 } | 1178 } |
1182 | 1179 |
1183 } // namespace content | 1180 } // namespace content |
OLD | NEW |