OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 #ifndef MEDIA_VIDEO_CAPTURE_VIDEO_CAPTURE_BUFFER_POOL_H_ | 5 #ifndef MEDIA_VIDEO_CAPTURE_VIDEO_CAPTURE_BUFFER_POOL_H_ |
6 #define MEDIA_VIDEO_CAPTURE_VIDEO_CAPTURE_BUFFER_POOL_H_ | 6 #define MEDIA_VIDEO_CAPTURE_VIDEO_CAPTURE_BUFFER_POOL_H_ |
7 | 7 |
8 #include "base/memory/ref_counted.h" | 8 #include "base/memory/ref_counted.h" |
9 #include "media/base/video_capture_types.h" | 9 #include "media/base/video_capture_types.h" |
10 #include "media/capture/capture_export.h" | 10 #include "media/capture/capture_export.h" |
| 11 #include "mojo/public/cpp/system/buffer.h" |
11 #include "ui/gfx/geometry/size.h" | 12 #include "ui/gfx/geometry/size.h" |
12 #include "ui/gfx/gpu_memory_buffer.h" | 13 #include "ui/gfx/gpu_memory_buffer.h" |
13 | 14 |
14 namespace media { | 15 namespace media { |
15 | 16 |
16 class VideoCaptureBufferHandle; | 17 class VideoCaptureBufferHandle; |
17 | 18 |
18 // A thread-safe class that does the bookkeeping and lifetime management for a | 19 // A thread-safe class that does the bookkeeping and lifetime management for a |
19 // pool of pixel buffers cycled between an in-process producer (e.g. a | 20 // pool of pixel buffers cycled between an in-process producer (e.g. a |
20 // VideoCaptureDevice) and a set of out-of-process consumers. The pool is | 21 // VideoCaptureDevice) and a set of out-of-process consumers. The pool is |
(...skipping 12 matching lines...) Expand all Loading... |
33 // called |buffer_id|. -1 (kInvalidId) is never a valid ID, and is returned by | 34 // called |buffer_id|. -1 (kInvalidId) is never a valid ID, and is returned by |
34 // some methods to indicate failure. The active set of buffer ids may change | 35 // some methods to indicate failure. The active set of buffer ids may change |
35 // over the lifetime of the buffer pool, as existing buffers are freed and | 36 // over the lifetime of the buffer pool, as existing buffers are freed and |
36 // reallocated at larger size. When reallocation occurs, new buffer IDs will | 37 // reallocated at larger size. When reallocation occurs, new buffer IDs will |
37 // circulate. | 38 // circulate. |
38 class CAPTURE_EXPORT VideoCaptureBufferPool | 39 class CAPTURE_EXPORT VideoCaptureBufferPool |
39 : public base::RefCountedThreadSafe<VideoCaptureBufferPool> { | 40 : public base::RefCountedThreadSafe<VideoCaptureBufferPool> { |
40 public: | 41 public: |
41 static constexpr int kInvalidId = -1; | 42 static constexpr int kInvalidId = -1; |
42 | 43 |
43 // One-time (per client/per-buffer) initialization to share a particular | 44 // One-time (per client/per-buffer) call to allow sharing |buffer_id|. |
44 // buffer to a process. The shared handle is returned as |new_handle|. | 45 virtual mojo::ScopedSharedBufferHandle GetHandleForTransit(int buffer_id) = 0; |
45 virtual bool ShareToProcess(int buffer_id, | |
46 base::ProcessHandle process_handle, | |
47 base::SharedMemoryHandle* new_handle) = 0; | |
48 | 46 |
49 // Try and obtain a BufferHandle for |buffer_id|. | 47 // Try and obtain a BufferHandle for |buffer_id|. |
50 virtual std::unique_ptr<VideoCaptureBufferHandle> GetBufferHandle( | 48 virtual std::unique_ptr<VideoCaptureBufferHandle> GetBufferHandle( |
51 int buffer_id) = 0; | 49 int buffer_id) = 0; |
52 | 50 |
53 // Reserve or allocate a buffer to support a packed frame of |dimensions| of | 51 // Reserve or allocate a buffer to support a packed frame of |dimensions| of |
54 // pixel |format| and return its id. This will fail (returning kInvalidId) if | 52 // pixel |format| and return its id. This will fail (returning kInvalidId) if |
55 // the pool already is at its |count| limit of the number of allocations, and | 53 // the pool already is at its |count| limit of the number of allocations, and |
56 // all allocated buffers are in use by the producer and/or consumers. | 54 // all allocated buffers are in use by the producer and/or consumers. |
57 // | 55 // |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
102 protected: | 100 protected: |
103 virtual ~VideoCaptureBufferPool() {} | 101 virtual ~VideoCaptureBufferPool() {} |
104 | 102 |
105 private: | 103 private: |
106 friend class base::RefCountedThreadSafe<VideoCaptureBufferPool>; | 104 friend class base::RefCountedThreadSafe<VideoCaptureBufferPool>; |
107 }; | 105 }; |
108 | 106 |
109 } // namespace media | 107 } // namespace media |
110 | 108 |
111 #endif // MEDIA_VIDEO_CAPTURE_VIDEO_CAPTURE_BUFFER_POOL_H_ | 109 #endif // MEDIA_VIDEO_CAPTURE_VIDEO_CAPTURE_BUFFER_POOL_H_ |
OLD | NEW |