OLD | NEW |
---|---|
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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/browser/renderer_host/media/video_capture_buffer_pool.h" | 5 #include "content/browser/renderer_host/media/video_capture_buffer_pool.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
10 #include "content/browser/gpu/browser_gpu_memory_buffer_manager.h" | 10 #include "content/browser/gpu/browser_gpu_memory_buffer_manager.h" |
11 #include "content/common/gpu/client/gpu_memory_buffer_impl.h" | 11 #include "content/common/gpu/client/gpu_memory_buffer_impl.h" |
12 #include "content/public/browser/browser_thread.h" | 12 #include "content/public/browser/browser_thread.h" |
13 | 13 |
14 namespace content { | 14 namespace content { |
15 | 15 |
16 const int VideoCaptureBufferPool::kInvalidId = -1; | 16 const int VideoCaptureBufferPool::kInvalidId = -1; |
17 | 17 |
18 // A simple holder of a memory-backed buffer and accesors to it. | 18 // A simple holder of a memory-backed buffer and accesors to it. |
19 class SimpleBufferHandle final : public VideoCaptureBufferPool::BufferHandle { | 19 class SimpleBufferHandle final : public VideoCaptureBufferPool::BufferHandle { |
20 public: | 20 public: |
21 SimpleBufferHandle(void* data, size_t size, base::SharedMemoryHandle handle) | 21 SimpleBufferHandle(void* data, size_t size, base::SharedMemoryHandle handle) |
22 : data_(data), size_(size), handle_(handle) {} | 22 : data_(data), |
23 #if defined(OS_POSIX) | |
24 handle_(handle), | |
25 #endif | |
26 size_(size) {} | |
23 ~SimpleBufferHandle() override {} | 27 ~SimpleBufferHandle() override {} |
24 | 28 |
25 size_t size() const override { return size_; } | 29 size_t size() const override { return size_; } |
26 void* data() override { return data_; } | 30 void* data() override { return data_; } |
27 ClientBuffer AsClientBuffer() override { return nullptr; } | 31 ClientBuffer AsClientBuffer() override { return nullptr; } |
28 #if defined(OS_POSIX) | 32 #if defined(OS_POSIX) |
29 base::FileDescriptor AsPlatformFile() override { | 33 base::FileDescriptor AsPlatformFile() override { |
30 #if defined(OS_MACOSX) | 34 #if defined(OS_MACOSX) |
31 return handle_.GetFileDescriptor(); | 35 return handle_.GetFileDescriptor(); |
32 #else | 36 #else |
33 return handle_; | 37 return handle_; |
34 #endif // defined(OS_MACOSX) | 38 #endif // defined(OS_MACOSX) |
35 } | 39 } |
36 #endif | 40 #endif |
37 | 41 |
38 private: | 42 private: |
39 void* const data_; | 43 void* const data_; |
44 #if defined(OS_POSIX) | |
45 const base::SharedMemoryHandle handle_; | |
Nico
2015/07/09 01:58:16
nit: It's strange to have data_ and size_ not next
benwells
2015/07/09 11:43:02
Done.
| |
46 #endif | |
40 const size_t size_; | 47 const size_t size_; |
41 const base::SharedMemoryHandle handle_; | |
42 }; | 48 }; |
43 | 49 |
44 // A holder of a GpuMemoryBuffer-backed buffer, Map()ed on ctor and Unmap()ed on | 50 // A holder of a GpuMemoryBuffer-backed buffer, Map()ed on ctor and Unmap()ed on |
45 // dtor. Holds a weak reference to its GpuMemoryBuffer. | 51 // dtor. Holds a weak reference to its GpuMemoryBuffer. |
46 // TODO(mcasas) Map()ed on ctor, or on first use? | 52 // TODO(mcasas) Map()ed on ctor, or on first use? |
47 class GpuMemoryBufferBufferHandle | 53 class GpuMemoryBufferBufferHandle |
48 final : public VideoCaptureBufferPool::BufferHandle { | 54 final : public VideoCaptureBufferPool::BufferHandle { |
49 public: | 55 public: |
50 GpuMemoryBufferBufferHandle(gfx::GpuMemoryBuffer* gmb, size_t size) | 56 GpuMemoryBufferBufferHandle(gfx::GpuMemoryBuffer* gmb, size_t size) |
51 : gmb_(gmb), | 57 : gmb_(gmb), |
(...skipping 310 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
362 return buffer_id; | 368 return buffer_id; |
363 } | 369 } |
364 | 370 |
365 VideoCaptureBufferPool::Tracker* VideoCaptureBufferPool::GetTracker( | 371 VideoCaptureBufferPool::Tracker* VideoCaptureBufferPool::GetTracker( |
366 int buffer_id) { | 372 int buffer_id) { |
367 TrackerMap::const_iterator it = trackers_.find(buffer_id); | 373 TrackerMap::const_iterator it = trackers_.find(buffer_id); |
368 return (it == trackers_.end()) ? NULL : it->second; | 374 return (it == trackers_.end()) ? NULL : it->second; |
369 } | 375 } |
370 | 376 |
371 } // namespace content | 377 } // namespace content |
OLD | NEW |