Index: third_party/libva/va/va_tpi.c |
diff --git a/third_party/libva/va/va_tpi.c b/third_party/libva/va/va_tpi.c |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e9169fc7fed2dbb2d5a8d15b3b7071f661728fce |
--- /dev/null |
+++ b/third_party/libva/va/va_tpi.c |
@@ -0,0 +1,204 @@ |
+/* |
+ * Copyright (c) 2007 Intel Corporation. All Rights Reserved. |
+ * |
+ * Permission is hereby granted, free of charge, to any person obtaining a |
+ * copy of this software and associated documentation files (the |
+ * "Software"), to deal in the Software without restriction, including |
+ * without limitation the rights to use, copy, modify, merge, publish, |
+ * distribute, sub license, and/or sell copies of the Software, and to |
+ * permit persons to whom the Software is furnished to do so, subject to |
+ * the following conditions: |
+ * |
+ * The above copyright notice and this permission notice (including the |
+ * next paragraph) shall be included in all copies or substantial portions |
+ * of the Software. |
+ * |
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. |
+ * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR |
+ * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
+ * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
+ */ |
+ |
+#define _GNU_SOURCE 1 |
+#include "sysdeps.h" |
+#include "va.h" |
+#include "va_backend.h" |
+#include "va_backend_tpi.h" |
+ |
+#include <assert.h> |
+#include <stdarg.h> |
+#include <stdio.h> |
+#include <stdlib.h> |
+#include <string.h> |
+#include <dlfcn.h> |
+#include <unistd.h> |
+ |
+#define CTX(dpy) (((VADisplayContextP)dpy)->pDriverContext) |
+#define CHECK_DISPLAY(dpy) if( !vaDisplayIsValid(dpy) ) { return VA_STATUS_ERROR_INVALID_DISPLAY; } |
+ |
+/* Wrap a CI (camera imaging) frame as a VA surface to share captured video between camear |
+ * and VA encode. With frame_id, VA driver need to call CI interfaces to get the information |
+ * of the frame, and to determine if the frame can be wrapped as a VA surface |
+ * |
+ * Application should make sure the frame is idle before the frame is passed into VA stack |
+ * and also a vaSyncSurface should be called before application tries to access the frame |
+ * from CI stack |
+ */ |
+VAStatus vaCreateSurfaceFromCIFrame ( |
+ VADisplay dpy, |
+ unsigned long frame_id, |
+ VASurfaceID *surface /* out */ |
+) |
+{ |
+ VADriverContextP ctx; |
+ struct VADriverVTableTPI *tpi; |
+ CHECK_DISPLAY(dpy); |
+ ctx = CTX(dpy); |
+ |
+ tpi = ( struct VADriverVTableTPI *)ctx->vtable_tpi; |
+ if (tpi && tpi->vaCreateSurfaceFromCIFrame) { |
+ return tpi->vaCreateSurfaceFromCIFrame( ctx, frame_id, surface ); |
+ } else |
+ return VA_STATUS_ERROR_UNIMPLEMENTED; |
+ |
+} |
+ |
+/* Wrap a V4L2 buffer as a VA surface, so that V4L2 camera, VA encode |
+ * can share the data without copy |
+ * The VA driver should query the camera device from v4l2_fd to see |
+ * if camera device memory/buffer can be wrapped into a VA surface |
+ * Buffer information is passed in by v4l2_fmt and v4l2_buf structure, |
+ * VA driver also needs do further check if the buffer can meet encode |
+ * hardware requirement, such as dimension, fourcc, stride, etc |
+ * |
+ * Application should make sure the buffer is idle before the frame into VA stack |
+ * and also a vaSyncSurface should be called before application tries to access the frame |
+ * from V4L2 stack |
+ */ |
+VAStatus vaCreateSurfaceFromV4L2Buf( |
+ VADisplay dpy, |
+ int v4l2_fd, /* file descriptor of V4L2 device */ |
+ struct v4l2_format *v4l2_fmt, /* format of V4L2 */ |
+ struct v4l2_buffer *v4l2_buf, /* V4L2 buffer */ |
+ VASurfaceID *surface /* out */ |
+) |
+{ |
+ VADriverContextP ctx; |
+ struct VADriverVTableTPI *tpi; |
+ CHECK_DISPLAY(dpy); |
+ ctx = CTX(dpy); |
+ |
+ tpi = ( struct VADriverVTableTPI *)ctx->vtable_tpi; |
+ if (tpi && tpi->vaCreateSurfaceFromV4L2Buf) { |
+ return tpi->vaCreateSurfaceFromV4L2Buf( ctx, v4l2_fd, v4l2_fmt, v4l2_buf, surface ); |
+ } else |
+ return VA_STATUS_ERROR_UNIMPLEMENTED; |
+} |
+ |
+ |
+/* |
+ * The surfaces could be shared and accessed with extern devices |
+ * which has special requirements, e.g. stride alignment |
+ * This API is used to force libVA video surfaces are allocated |
+ * according to these external requirements |
+ * Special API for V4L2 user pointer support |
+ */ |
+VAStatus vaCreateSurfacesForUserPtr( |
+ VADisplay dpy, |
+ int width, |
+ int height, |
+ int format, |
+ int num_surfaces, |
+ VASurfaceID *surfaces, /* out */ |
+ unsigned size, /* total buffer size need to be allocated */ |
+ unsigned int fourcc, /* expected fourcc */ |
+ unsigned int luma_stride, /* luma stride, could be width aligned with a special value */ |
+ unsigned int chroma_u_stride, /* chroma stride */ |
+ unsigned int chroma_v_stride, |
+ unsigned int luma_offset, /* could be 0 */ |
+ unsigned int chroma_u_offset, /* UV offset from the beginning of the memory */ |
+ unsigned int chroma_v_offset |
+) |
+{ |
+ VADriverContextP ctx; |
+ struct VADriverVTableTPI *tpi; |
+ CHECK_DISPLAY(dpy); |
+ ctx = CTX(dpy); |
+ |
+ tpi = (struct VADriverVTableTPI *)ctx->vtable_tpi; |
+ if (tpi && tpi->vaCreateSurfacesForUserPtr) { |
+ return tpi->vaCreateSurfacesForUserPtr( ctx, width, height, format, num_surfaces, |
+ surfaces,size, fourcc, luma_stride, chroma_u_stride, |
+ chroma_v_stride, luma_offset, chroma_u_offset, chroma_v_offset ); |
+ } else |
+ return VA_STATUS_ERROR_UNIMPLEMENTED; |
+} |
+ |
+/* |
+ * Create surface from the Kernel buffer |
+ */ |
+VAStatus vaCreateSurfaceFromKBuf( |
+ VADisplay dpy, |
+ int width, |
+ int height, |
+ int format, |
+ VASurfaceID *surface, /* out */ |
+ unsigned int kbuf_handle, /* kernel buffer handle*/ |
+ unsigned size, /* kernel buffer size */ |
+ unsigned int kBuf_fourcc, /* expected fourcc */ |
+ unsigned int luma_stride, /* luma stride, could be width aligned with a special value */ |
+ unsigned int chroma_u_stride, /* chroma stride */ |
+ unsigned int chroma_v_stride, |
+ unsigned int luma_offset, /* could be 0 */ |
+ unsigned int chroma_u_offset, /* UV offset from the beginning of the memory */ |
+ unsigned int chroma_v_offset |
+) |
+{ |
+ VADriverContextP ctx; |
+ struct VADriverVTableTPI *tpi; |
+ CHECK_DISPLAY(dpy); |
+ ctx = CTX(dpy); |
+ |
+ tpi = (struct VADriverVTableTPI *)ctx->vtable_tpi; |
+ if (tpi && tpi->vaCreateSurfaceFromKBuf) { |
+ return tpi->vaCreateSurfaceFromKBuf( ctx, width, height, format, surface, kbuf_handle, |
+ size, kBuf_fourcc, luma_stride, chroma_u_stride, |
+ chroma_v_stride, luma_offset, chroma_u_offset, chroma_v_offset ); |
+ } else |
+ return VA_STATUS_ERROR_UNIMPLEMENTED; |
+} |
+ |
+ |
+VAStatus vaPutSurfaceBuf ( |
+ VADisplay dpy, |
+ VASurfaceID surface, |
+ unsigned char* data, |
+ int* data_len, |
+ short srcx, |
+ short srcy, |
+ unsigned short srcw, |
+ unsigned short srch, |
+ short destx, |
+ short desty, |
+ unsigned short destw, |
+ unsigned short desth, |
+ VARectangle *cliprects, /* client supplied clip list */ |
+ unsigned int number_cliprects, /* number of clip rects in the clip list */ |
+ unsigned int flags /* de-interlacing flags */ |
+) |
+{ |
+ VADriverContextP ctx; |
+ struct VADriverVTableTPI *tpi; |
+ CHECK_DISPLAY(dpy); |
+ ctx = CTX(dpy); |
+ |
+ tpi = ( struct VADriverVTableTPI *)ctx->vtable_tpi; |
+ if (tpi && tpi->vaPutSurfaceBuf) { |
+ return tpi->vaPutSurfaceBuf( ctx, surface, data, data_len, srcx, srcy, srcw, srch, |
+ destx, desty, destw, desth, cliprects, number_cliprects, flags ); |
+ } else |
+ return VA_STATUS_ERROR_UNIMPLEMENTED; |
+} |