OLD | NEW |
(Empty) | |
| 1 /* |
| 2 * Copyright (c) 2007 Intel Corporation. All Rights Reserved. |
| 3 * |
| 4 * Permission is hereby granted, free of charge, to any person obtaining a |
| 5 * copy of this software and associated documentation files (the |
| 6 * "Software"), to deal in the Software without restriction, including |
| 7 * without limitation the rights to use, copy, modify, merge, publish, |
| 8 * distribute, sub license, and/or sell copies of the Software, and to |
| 9 * permit persons to whom the Software is furnished to do so, subject to |
| 10 * the following conditions: |
| 11 * |
| 12 * The above copyright notice and this permission notice (including the |
| 13 * next paragraph) shall be included in all copies or substantial portions |
| 14 * of the Software. |
| 15 * |
| 16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| 17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. |
| 19 * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR |
| 20 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
| 21 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
| 22 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| 23 */ |
| 24 |
| 25 #define _GNU_SOURCE 1 |
| 26 #include "sysdeps.h" |
| 27 #include "va.h" |
| 28 #include "va_backend.h" |
| 29 #include "va_backend_tpi.h" |
| 30 |
| 31 #include <assert.h> |
| 32 #include <stdarg.h> |
| 33 #include <stdio.h> |
| 34 #include <stdlib.h> |
| 35 #include <string.h> |
| 36 #include <dlfcn.h> |
| 37 #include <unistd.h> |
| 38 |
| 39 #define CTX(dpy) (((VADisplayContextP)dpy)->pDriverContext) |
| 40 #define CHECK_DISPLAY(dpy) if( !vaDisplayIsValid(dpy) ) { return VA_STATUS_ERROR
_INVALID_DISPLAY; } |
| 41 |
| 42 /* Wrap a CI (camera imaging) frame as a VA surface to share captured video betw
een camear |
| 43 * and VA encode. With frame_id, VA driver need to call CI interfaces to get the
information |
| 44 * of the frame, and to determine if the frame can be wrapped as a VA surface |
| 45 * |
| 46 * Application should make sure the frame is idle before the frame is passed int
o VA stack |
| 47 * and also a vaSyncSurface should be called before application tries to access
the frame |
| 48 * from CI stack |
| 49 */ |
| 50 VAStatus vaCreateSurfaceFromCIFrame ( |
| 51 VADisplay dpy, |
| 52 unsigned long frame_id, |
| 53 VASurfaceID *surface /* out */ |
| 54 ) |
| 55 { |
| 56 VADriverContextP ctx; |
| 57 struct VADriverVTableTPI *tpi; |
| 58 CHECK_DISPLAY(dpy); |
| 59 ctx = CTX(dpy); |
| 60 |
| 61 tpi = ( struct VADriverVTableTPI *)ctx->vtable_tpi; |
| 62 if (tpi && tpi->vaCreateSurfaceFromCIFrame) { |
| 63 return tpi->vaCreateSurfaceFromCIFrame( ctx, frame_id, surface ); |
| 64 } else |
| 65 return VA_STATUS_ERROR_UNIMPLEMENTED; |
| 66 |
| 67 } |
| 68 |
| 69 /* Wrap a V4L2 buffer as a VA surface, so that V4L2 camera, VA encode |
| 70 * can share the data without copy |
| 71 * The VA driver should query the camera device from v4l2_fd to see |
| 72 * if camera device memory/buffer can be wrapped into a VA surface |
| 73 * Buffer information is passed in by v4l2_fmt and v4l2_buf structure, |
| 74 * VA driver also needs do further check if the buffer can meet encode |
| 75 * hardware requirement, such as dimension, fourcc, stride, etc |
| 76 * |
| 77 * Application should make sure the buffer is idle before the frame into VA stac
k |
| 78 * and also a vaSyncSurface should be called before application tries to access
the frame |
| 79 * from V4L2 stack |
| 80 */ |
| 81 VAStatus vaCreateSurfaceFromV4L2Buf( |
| 82 VADisplay dpy, |
| 83 int v4l2_fd, /* file descriptor of V4L2 device */ |
| 84 struct v4l2_format *v4l2_fmt, /* format of V4L2 */ |
| 85 struct v4l2_buffer *v4l2_buf, /* V4L2 buffer */ |
| 86 VASurfaceID *surface /* out */ |
| 87 ) |
| 88 { |
| 89 VADriverContextP ctx; |
| 90 struct VADriverVTableTPI *tpi; |
| 91 CHECK_DISPLAY(dpy); |
| 92 ctx = CTX(dpy); |
| 93 |
| 94 tpi = ( struct VADriverVTableTPI *)ctx->vtable_tpi; |
| 95 if (tpi && tpi->vaCreateSurfaceFromV4L2Buf) { |
| 96 return tpi->vaCreateSurfaceFromV4L2Buf( ctx, v4l2_fd, v4l2_fmt, v4l2_buf,
surface ); |
| 97 } else |
| 98 return VA_STATUS_ERROR_UNIMPLEMENTED; |
| 99 } |
| 100 |
| 101 |
| 102 /* |
| 103 * The surfaces could be shared and accessed with extern devices |
| 104 * which has special requirements, e.g. stride alignment |
| 105 * This API is used to force libVA video surfaces are allocated |
| 106 * according to these external requirements |
| 107 * Special API for V4L2 user pointer support |
| 108 */ |
| 109 VAStatus vaCreateSurfacesForUserPtr( |
| 110 VADisplay dpy, |
| 111 int width, |
| 112 int height, |
| 113 int format, |
| 114 int num_surfaces, |
| 115 VASurfaceID *surfaces, /* out */ |
| 116 unsigned size, /* total buffer size need to be allocated */ |
| 117 unsigned int fourcc, /* expected fourcc */ |
| 118 unsigned int luma_stride, /* luma stride, could be width aligned with a spec
ial value */ |
| 119 unsigned int chroma_u_stride, /* chroma stride */ |
| 120 unsigned int chroma_v_stride, |
| 121 unsigned int luma_offset, /* could be 0 */ |
| 122 unsigned int chroma_u_offset, /* UV offset from the beginning of the memory
*/ |
| 123 unsigned int chroma_v_offset |
| 124 ) |
| 125 { |
| 126 VADriverContextP ctx; |
| 127 struct VADriverVTableTPI *tpi; |
| 128 CHECK_DISPLAY(dpy); |
| 129 ctx = CTX(dpy); |
| 130 |
| 131 tpi = (struct VADriverVTableTPI *)ctx->vtable_tpi; |
| 132 if (tpi && tpi->vaCreateSurfacesForUserPtr) { |
| 133 return tpi->vaCreateSurfacesForUserPtr( ctx, width, height, format, num_su
rfaces, |
| 134 surfaces,size, fourcc, luma_stride
, chroma_u_stride, |
| 135 chroma_v_stride, luma_offset, chro
ma_u_offset, chroma_v_offset ); |
| 136 } else |
| 137 return VA_STATUS_ERROR_UNIMPLEMENTED; |
| 138 } |
| 139 |
| 140 /* |
| 141 * Create surface from the Kernel buffer |
| 142 */ |
| 143 VAStatus vaCreateSurfaceFromKBuf( |
| 144 VADisplay dpy, |
| 145 int width, |
| 146 int height, |
| 147 int format, |
| 148 VASurfaceID *surface, /* out */ |
| 149 unsigned int kbuf_handle, /* kernel buffer handle*/ |
| 150 unsigned size, /* kernel buffer size */ |
| 151 unsigned int kBuf_fourcc, /* expected fourcc */ |
| 152 unsigned int luma_stride, /* luma stride, could be width aligned with a spec
ial value */ |
| 153 unsigned int chroma_u_stride, /* chroma stride */ |
| 154 unsigned int chroma_v_stride, |
| 155 unsigned int luma_offset, /* could be 0 */ |
| 156 unsigned int chroma_u_offset, /* UV offset from the beginning of the memory
*/ |
| 157 unsigned int chroma_v_offset |
| 158 ) |
| 159 { |
| 160 VADriverContextP ctx; |
| 161 struct VADriverVTableTPI *tpi; |
| 162 CHECK_DISPLAY(dpy); |
| 163 ctx = CTX(dpy); |
| 164 |
| 165 tpi = (struct VADriverVTableTPI *)ctx->vtable_tpi; |
| 166 if (tpi && tpi->vaCreateSurfaceFromKBuf) { |
| 167 return tpi->vaCreateSurfaceFromKBuf( ctx, width, height, format, surface,
kbuf_handle, |
| 168 size, kBuf_fourcc, luma_stride, ch
roma_u_stride, |
| 169 chroma_v_stride, luma_offset, chro
ma_u_offset, chroma_v_offset ); |
| 170 } else |
| 171 return VA_STATUS_ERROR_UNIMPLEMENTED; |
| 172 } |
| 173 |
| 174 |
| 175 VAStatus vaPutSurfaceBuf ( |
| 176 VADisplay dpy, |
| 177 VASurfaceID surface, |
| 178 unsigned char* data, |
| 179 int* data_len, |
| 180 short srcx, |
| 181 short srcy, |
| 182 unsigned short srcw, |
| 183 unsigned short srch, |
| 184 short destx, |
| 185 short desty, |
| 186 unsigned short destw, |
| 187 unsigned short desth, |
| 188 VARectangle *cliprects, /* client supplied clip list */ |
| 189 unsigned int number_cliprects, /* number of clip rects in the clip list */ |
| 190 unsigned int flags /* de-interlacing flags */ |
| 191 ) |
| 192 { |
| 193 VADriverContextP ctx; |
| 194 struct VADriverVTableTPI *tpi; |
| 195 CHECK_DISPLAY(dpy); |
| 196 ctx = CTX(dpy); |
| 197 |
| 198 tpi = ( struct VADriverVTableTPI *)ctx->vtable_tpi; |
| 199 if (tpi && tpi->vaPutSurfaceBuf) { |
| 200 return tpi->vaPutSurfaceBuf( ctx, surface, data, data_len, srcx, srcy, src
w, srch, |
| 201 destx, desty, destw, desth, cliprects, num
ber_cliprects, flags ); |
| 202 } else |
| 203 return VA_STATUS_ERROR_UNIMPLEMENTED; |
| 204 } |
OLD | NEW |