Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / media / base / video_frame.h
blobee228fda70130ccc77f9d7267849acd7a479af16
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef MEDIA_BASE_VIDEO_FRAME_H_
6 #define MEDIA_BASE_VIDEO_FRAME_H_
8 #include <vector>
10 #include "base/callback.h"
11 #include "base/md5.h"
12 #include "base/memory/shared_memory.h"
13 #include "base/synchronization/lock.h"
14 #include "gpu/command_buffer/common/mailbox_holder.h"
15 #include "media/base/video_frame_metadata.h"
16 #include "media/base/video_types.h"
17 #include "ui/gfx/geometry/rect.h"
18 #include "ui/gfx/geometry/size.h"
20 #if defined(OS_MACOSX)
21 #include <CoreVideo/CVPixelBuffer.h>
22 #include "base/mac/scoped_cftyperef.h"
23 #endif
25 namespace media {
27 class MEDIA_EXPORT VideoFrame : public base::RefCountedThreadSafe<VideoFrame> {
28 public:
29 enum {
30 kFrameSizeAlignment = 16,
31 kFrameSizePadding = 16,
32 kFrameAddressAlignment = 32
35 enum {
36 kMaxPlanes = 4,
38 kYPlane = 0,
39 kARGBPlane = kYPlane,
40 kUPlane = 1,
41 kUVPlane = kUPlane,
42 kVPlane = 2,
43 kAPlane = 3,
46 // Defines the pixel storage type. Differentiates between directly accessible
47 // |data_| and pixels that are only indirectly accessible and not via mappable
48 // memory.
49 // Note that VideoFrames of any StorageType can also have Texture backing,
50 // with "classical" GPU Driver-only textures identified as STORAGE_OPAQUE.
51 enum StorageType {
52 STORAGE_UNKNOWN = 0,
53 STORAGE_OPAQUE = 1, // We don't know how VideoFrame's pixels are stored.
54 STORAGE_UNOWNED_MEMORY = 2, // External, non owned data pointers.
55 STORAGE_OWNED_MEMORY = 3, // VideoFrame has allocated its own data buffer.
56 STORAGE_SHMEM = 4, // Pixels are backed by Shared Memory.
57 #if defined(OS_LINUX)
58 // TODO(mcasas): Consider turning this type into STORAGE_NATIVE or another
59 // meaningful name and handle it appropriately in all cases.
60 STORAGE_DMABUFS = 5, // Each plane is stored into a DmaBuf.
61 #endif
62 #if defined(VIDEO_HOLE)
63 // Indicates protected media that needs to be directly rendered to hw. It
64 // is, in principle, platform independent, see http://crbug.com/323157 and
65 // https://groups.google.com/a/google.com/d/topic/chrome-gpu/eIM1RwarUmk/discussion
66 STORAGE_HOLE = 6,
67 #endif
69 #if defined(VIDEO_HOLE)
70 STORAGE_LAST = STORAGE_HOLE,
71 #elif defined(OS_LINUX)
72 STORAGE_LAST = STORAGE_DMABUFS,
73 #else
74 STORAGE_LAST = STORAGE_SHMEM
75 #endif
78 // CB to be called on the mailbox backing this frame when the frame is
79 // destroyed.
80 typedef base::Callback<void(uint32)> ReleaseMailboxCB;
82 // Interface representing client operations on a SyncPoint, i.e. insert one in
83 // the GPU Command Buffer and wait for it.
84 class SyncPointClient {
85 public:
86 SyncPointClient() {}
87 virtual uint32 InsertSyncPoint() = 0;
88 virtual void WaitSyncPoint(uint32 sync_point) = 0;
90 protected:
91 virtual ~SyncPointClient() {}
93 DISALLOW_COPY_AND_ASSIGN(SyncPointClient);
96 // Call prior to CreateFrame to ensure validity of frame configuration. Called
97 // automatically by VideoDecoderConfig::IsValidConfig().
98 static bool IsValidConfig(VideoPixelFormat format,
99 StorageType storage_type,
100 const gfx::Size& coded_size,
101 const gfx::Rect& visible_rect,
102 const gfx::Size& natural_size);
104 // Creates a new YUV frame in system memory with given parameters (|format|
105 // must be YUV). Buffers for the frame are allocated but not initialized. The
106 // caller most not make assumptions about the actual underlying size(s), but
107 // check the returned VideoFrame instead.
108 // TODO(mcasas): implement the RGB version of this factory method.
109 static scoped_refptr<VideoFrame> CreateFrame(VideoPixelFormat format,
110 const gfx::Size& coded_size,
111 const gfx::Rect& visible_rect,
112 const gfx::Size& natural_size,
113 base::TimeDelta timestamp);
115 // Offers the same functionality as CreateFrame, and additionally zeroes out
116 // the initial allocated buffers.
117 static scoped_refptr<VideoFrame> CreateZeroInitializedFrame(
118 VideoPixelFormat format,
119 const gfx::Size& coded_size,
120 const gfx::Rect& visible_rect,
121 const gfx::Size& natural_size,
122 base::TimeDelta timestamp);
124 // Wraps a native texture of the given parameters with a VideoFrame.
125 // The backing of the VideoFrame is held in the mailbox held by
126 // |mailbox_holder|, and |mailbox_holder_release_cb| will be called with
127 // a syncpoint as the argument when the VideoFrame is to be destroyed.
128 static scoped_refptr<VideoFrame> WrapNativeTexture(
129 VideoPixelFormat format,
130 const gpu::MailboxHolder& mailbox_holder,
131 const ReleaseMailboxCB& mailbox_holder_release_cb,
132 const gfx::Size& coded_size,
133 const gfx::Rect& visible_rect,
134 const gfx::Size& natural_size,
135 base::TimeDelta timestamp);
137 // Wraps a set of native textures representing YUV data with a VideoFrame.
138 // |mailbox_holders_release_cb| will be called with a syncpoint as the
139 // argument when the VideoFrame is to be destroyed.
140 static scoped_refptr<VideoFrame> WrapYUV420NativeTextures(
141 const gpu::MailboxHolder& y_mailbox_holder,
142 const gpu::MailboxHolder& u_mailbox_holder,
143 const gpu::MailboxHolder& v_mailbox_holder,
144 const ReleaseMailboxCB& mailbox_holders_release_cb,
145 const gfx::Size& coded_size,
146 const gfx::Rect& visible_rect,
147 const gfx::Size& natural_size,
148 base::TimeDelta timestamp);
150 // Wraps packed image data residing in a memory buffer with a VideoFrame.
151 // The image data resides in |data| and is assumed to be packed tightly in a
152 // buffer of logical dimensions |coded_size| with the appropriate bit depth
153 // and plane count as given by |format|. Returns NULL on failure.
154 static scoped_refptr<VideoFrame> WrapExternalData(
155 VideoPixelFormat format,
156 const gfx::Size& coded_size,
157 const gfx::Rect& visible_rect,
158 const gfx::Size& natural_size,
159 uint8* data,
160 size_t data_size,
161 base::TimeDelta timestamp);
163 // Same as WrapExternalData() with SharedMemoryHandle and its offset.
164 static scoped_refptr<VideoFrame> WrapExternalSharedMemory(
165 VideoPixelFormat format,
166 const gfx::Size& coded_size,
167 const gfx::Rect& visible_rect,
168 const gfx::Size& natural_size,
169 uint8* data,
170 size_t data_size,
171 base::SharedMemoryHandle handle,
172 size_t shared_memory_offset,
173 base::TimeDelta timestamp);
175 // Wraps external YUV data of the given parameters with a VideoFrame.
176 // The returned VideoFrame does not own the data passed in.
177 static scoped_refptr<VideoFrame> WrapExternalYuvData(
178 VideoPixelFormat format,
179 const gfx::Size& coded_size,
180 const gfx::Rect& visible_rect,
181 const gfx::Size& natural_size,
182 int32 y_stride,
183 int32 u_stride,
184 int32 v_stride,
185 uint8* y_data,
186 uint8* u_data,
187 uint8* v_data,
188 base::TimeDelta timestamp);
190 #if defined(OS_LINUX)
191 // Wraps provided dmabufs
192 // (https://www.kernel.org/doc/Documentation/dma-buf-sharing.txt) with a
193 // VideoFrame. The dmabuf fds are dup()ed on creation, so that the VideoFrame
194 // retains a reference to them, and are automatically close()d on destruction,
195 // dropping the reference. The caller may safely close() its reference after
196 // calling WrapExternalDmabufs().
197 // The image data is only accessible via dmabuf fds, which are usually passed
198 // directly to a hardware device and/or to another process, or can also be
199 // mapped via mmap() for CPU access.
200 // Returns NULL on failure.
201 static scoped_refptr<VideoFrame> WrapExternalDmabufs(
202 VideoPixelFormat format,
203 const gfx::Size& coded_size,
204 const gfx::Rect& visible_rect,
205 const gfx::Size& natural_size,
206 const std::vector<int>& dmabuf_fds,
207 base::TimeDelta timestamp);
208 #endif
210 #if defined(OS_MACOSX)
211 // Wraps a provided CVPixelBuffer with a VideoFrame. The pixel buffer is
212 // retained for the lifetime of the VideoFrame and released upon destruction.
213 // The image data is only accessible via the pixel buffer, which could be
214 // backed by an IOSurface from another process. All the attributes of the
215 // VideoFrame are derived from the pixel buffer, with the exception of the
216 // timestamp. If information is missing or is incompatible (for example, a
217 // pixel format that has no VideoFrame match), NULL is returned.
218 // http://crbug.com/401308
219 static scoped_refptr<VideoFrame> WrapCVPixelBuffer(
220 CVPixelBufferRef cv_pixel_buffer,
221 base::TimeDelta timestamp);
222 #endif
224 // Wraps |frame|. |visible_rect| must be a sub rect within
225 // frame->visible_rect().
226 static scoped_refptr<VideoFrame> WrapVideoFrame(
227 const scoped_refptr<VideoFrame>& frame,
228 const gfx::Rect& visible_rect,
229 const gfx::Size& natural_size);
231 // Creates a frame which indicates end-of-stream.
232 static scoped_refptr<VideoFrame> CreateEOSFrame();
234 // Allocates YV12 frame based on |size|, and sets its data to the YUV(y,u,v).
235 static scoped_refptr<VideoFrame> CreateColorFrame(
236 const gfx::Size& size,
237 uint8 y, uint8 u, uint8 v,
238 base::TimeDelta timestamp);
240 // Allocates YV12 frame based on |size|, and sets its data to the YUV
241 // equivalent of RGB(0,0,0).
242 static scoped_refptr<VideoFrame> CreateBlackFrame(const gfx::Size& size);
244 // Allocates YV12A frame based on |size|, and sets its data to the YUVA
245 // equivalent of RGBA(0,0,0,0).
246 static scoped_refptr<VideoFrame> CreateTransparentFrame(
247 const gfx::Size& size);
249 #if defined(VIDEO_HOLE)
250 // Allocates a hole frame.
251 static scoped_refptr<VideoFrame> CreateHoleFrame(const gfx::Size& size);
252 #endif // defined(VIDEO_HOLE)
254 static size_t NumPlanes(VideoPixelFormat format);
256 // Returns the required allocation size for a (tightly packed) frame of the
257 // given coded size and format.
258 static size_t AllocationSize(VideoPixelFormat format,
259 const gfx::Size& coded_size);
261 // Returns the plane gfx::Size (in bytes) for a plane of the given coded size
262 // and format.
263 static gfx::Size PlaneSize(VideoPixelFormat format,
264 size_t plane,
265 const gfx::Size& coded_size);
267 // Returns horizontal bits per pixel for given |plane| and |format|.
268 static int PlaneHorizontalBitsPerPixel(VideoPixelFormat format, size_t plane);
270 // Returns bits per pixel for given |plane| and |format|.
271 static int PlaneBitsPerPixel(VideoPixelFormat format, size_t plane);
273 // Returns the number of bytes per row for the given plane, format, and width.
274 // The width may be aligned to format requirements.
275 static size_t RowBytes(size_t plane, VideoPixelFormat format, int width);
277 // Returns the number of rows for the given plane, format, and height.
278 // The height may be aligned to format requirements.
279 static size_t Rows(size_t plane, VideoPixelFormat format, int height);
281 // Returns the number of columns for the given plane, format, and width.
282 // The width may be aligned to format requirements.
283 static size_t Columns(size_t plane, VideoPixelFormat format, int width);
285 // Used to keep a running hash of seen frames. Expects an initialized MD5
286 // context. Calls MD5Update with the context and the contents of the frame.
287 static void HashFrameForTesting(base::MD5Context* context,
288 const scoped_refptr<VideoFrame>& frame);
290 // Returns true if |frame| is accessible and mapped in the VideoFrame memory
291 // space. If false, clients should refrain from accessing data(),
292 // visible_data() etc.
293 bool IsMappable() const;
295 // Returns true if |frame| has textures with any StorageType and should not be
296 // accessed via data(), visible_data() etc.
297 bool HasTextures() const;
299 VideoPixelFormat format() const { return format_; }
300 StorageType storage_type() const { return storage_type_; }
302 const gfx::Size& coded_size() const { return coded_size_; }
303 const gfx::Rect& visible_rect() const { return visible_rect_; }
304 const gfx::Size& natural_size() const { return natural_size_; }
306 int stride(size_t plane) const;
308 // Returns the number of bytes per row and number of rows for a given plane.
310 // As opposed to stride(), row_bytes() refers to the bytes representing
311 // frame data scanlines (coded_size.width() pixels, without stride padding).
312 int row_bytes(size_t plane) const;
313 int rows(size_t plane) const;
315 // Returns pointer to the buffer for a given plane, if this is an
316 // IsMappable() frame type. The memory is owned by VideoFrame object and must
317 // not be freed by the caller.
318 const uint8* data(size_t plane) const;
319 uint8* data(size_t plane);
321 // Returns pointer to the data in the visible region of the frame, for
322 // IsMappable() storage types. The returned pointer is offsetted into the
323 // plane buffer specified by visible_rect().origin(). Memory is owned by
324 // VideoFrame object and must not be freed by the caller.
325 const uint8* visible_data(size_t plane) const;
326 uint8* visible_data(size_t plane);
328 // Returns a mailbox holder for a given texture.
329 // Only valid to call if this is a NATIVE_TEXTURE frame. Before using the
330 // mailbox, the caller must wait for the included sync point.
331 const gpu::MailboxHolder& mailbox_holder(size_t texture_index) const;
333 // Returns the shared-memory handle, if present
334 base::SharedMemoryHandle shared_memory_handle() const;
336 // Returns the offset into the shared memory where the frame data begins.
337 size_t shared_memory_offset() const;
339 #if defined(OS_LINUX)
340 // Returns backing DmaBuf file descriptor for given |plane|, if present, or
341 // -1 if not.
342 // TODO(mcasas): Rename to DmabufFd() to comply with Style Guide.
343 int dmabuf_fd(size_t plane) const;
345 // Duplicates internally the |fds_in|, overwriting the current ones. Returns
346 // false if something goes wrong, and leaves all internal fds closed.
347 bool DuplicateFileDescriptors(const std::vector<int>& fds_in);
348 #endif
350 void AddSharedMemoryHandle(base::SharedMemoryHandle handle);
352 #if defined(OS_MACOSX)
353 // Returns the backing CVPixelBuffer, if present.
354 // TODO(mcasas): Rename to CvPixelBuffer() to comply with Style Guide.
355 CVPixelBufferRef cv_pixel_buffer() const;
356 #endif
358 // Adds a callback to be run when the VideoFrame is about to be destroyed.
359 // The callback may be run from ANY THREAD, and so it is up to the client to
360 // ensure thread safety. Although read-only access to the members of this
361 // VideoFrame is permitted while the callback executes (including
362 // VideoFrameMetadata), clients should not assume the data pointers are
363 // valid.
364 void AddDestructionObserver(const base::Closure& callback);
366 // Returns a dictionary of optional metadata. This contains information
367 // associated with the frame that downstream clients might use for frame-level
368 // logging, quality/performance optimizations, signaling, etc.
370 // TODO(miu): Move some of the "extra" members of VideoFrame (below) into
371 // here as a later clean-up step.
372 const VideoFrameMetadata* metadata() const { return &metadata_; }
373 VideoFrameMetadata* metadata() { return &metadata_; }
375 base::TimeDelta timestamp() const { return timestamp_; }
376 void set_timestamp(base::TimeDelta timestamp) {
377 timestamp_ = timestamp;
380 // It uses |client| to insert a new sync point and potentially waits on a
381 // older sync point. The final sync point will be used to release this
382 // VideoFrame.
383 // This method is thread safe. Both blink and compositor threads can call it.
384 void UpdateReleaseSyncPoint(SyncPointClient* client);
386 private:
387 friend class base::RefCountedThreadSafe<VideoFrame>;
389 static scoped_refptr<VideoFrame> WrapExternalStorage(
390 VideoPixelFormat format,
391 StorageType storage_type,
392 const gfx::Size& coded_size,
393 const gfx::Rect& visible_rect,
394 const gfx::Size& natural_size,
395 uint8* data,
396 size_t data_size,
397 base::TimeDelta timestamp,
398 base::SharedMemoryHandle handle,
399 size_t data_offset);
401 // Clients must use the static factory/wrapping methods to create a new frame.
402 VideoFrame(VideoPixelFormat format,
403 StorageType storage_type,
404 const gfx::Size& coded_size,
405 const gfx::Rect& visible_rect,
406 const gfx::Size& natural_size,
407 base::TimeDelta timestamp);
408 VideoFrame(VideoPixelFormat format,
409 StorageType storage_type,
410 const gfx::Size& coded_size,
411 const gfx::Rect& visible_rect,
412 const gfx::Size& natural_size,
413 base::TimeDelta timestamp,
414 base::SharedMemoryHandle handle,
415 size_t shared_memory_offset);
416 VideoFrame(VideoPixelFormat format,
417 StorageType storage_type,
418 const gfx::Size& coded_size,
419 const gfx::Rect& visible_rect,
420 const gfx::Size& natural_size,
421 const gpu::MailboxHolder(&mailbox_holders)[kMaxPlanes],
422 const ReleaseMailboxCB& mailbox_holder_release_cb,
423 base::TimeDelta timestamp);
424 virtual ~VideoFrame();
426 static scoped_refptr<VideoFrame> CreateFrameInternal(
427 VideoPixelFormat format,
428 const gfx::Size& coded_size,
429 const gfx::Rect& visible_rect,
430 const gfx::Size& natural_size,
431 base::TimeDelta timestamp,
432 bool zero_initialize_memory);
434 void AllocateYUV(bool zero_initialize_memory);
436 // Frame format.
437 const VideoPixelFormat format_;
439 // Storage type for the different planes.
440 StorageType storage_type_; // TODO(mcasas): make const
442 // Width and height of the video frame, in pixels. This must include pixel
443 // data for the whole image; i.e. for YUV formats with subsampled chroma
444 // planes, in the case that the visible portion of the image does not line up
445 // on a sample boundary, |coded_size_| must be rounded up appropriately and
446 // the pixel data provided for the odd pixels.
447 const gfx::Size coded_size_;
449 // Width, height, and offsets of the visible portion of the video frame. Must
450 // be a subrect of |coded_size_|. Can be odd with respect to the sample
451 // boundaries, e.g. for formats with subsampled chroma.
452 const gfx::Rect visible_rect_;
454 // Width and height of the visible portion of the video frame
455 // (|visible_rect_.size()|) with aspect ratio taken into account.
456 const gfx::Size natural_size_;
458 // Array of strides for each plane, typically greater or equal to the width
459 // of the surface divided by the horizontal sampling period. Note that
460 // strides can be negative.
461 int32 strides_[kMaxPlanes];
463 // Array of data pointers to each plane.
464 // TODO(mcasas): we don't know on ctor if we own |data_| or not. After
465 // refactoring VideoFrame, change to scoped_ptr<uint8, AlignedFreeDeleter>.
466 uint8* data_[kMaxPlanes];
468 // Native texture mailboxes, if this is a IsTexture() frame.
469 gpu::MailboxHolder mailbox_holders_[kMaxPlanes];
470 ReleaseMailboxCB mailbox_holders_release_cb_;
472 // Shared memory handle and associated offset inside it, if this frame is
473 // a STORAGE_SHMEM one.
474 base::SharedMemoryHandle shared_memory_handle_;
475 size_t shared_memory_offset_;
477 #if defined(OS_LINUX)
478 // Dmabufs for each plane. If set, this frame has DmaBuf backing in some way.
479 base::ScopedFD dmabuf_fds_[kMaxPlanes];
480 #endif
482 #if defined(OS_MACOSX)
483 // CVPixelBuffer, if this frame is wrapping one.
484 base::ScopedCFTypeRef<CVPixelBufferRef> cv_pixel_buffer_;
485 #endif
487 std::vector<base::Closure> done_callbacks_;
489 base::TimeDelta timestamp_;
491 base::Lock release_sync_point_lock_;
492 uint32 release_sync_point_;
494 VideoFrameMetadata metadata_;
496 DISALLOW_IMPLICIT_CONSTRUCTORS(VideoFrame);
499 } // namespace media
501 #endif // MEDIA_BASE_VIDEO_FRAME_H_