Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(12)

Side by Side Diff: third_party/libva/va/va_tpi.c

Issue 10375035: Add libva to chromium third_party. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698