1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
|
/*
* Copyright (c) 2011 Intel Corporation. All Rights Reserved.
* Copyright (c) Imagination Technologies Limited, UK
*
* 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.
*
* Authors:
* Waldo Bastian <waldo.bastian@intel.com>
*/
#ifndef _PSB_SURFACE_H_
#define _PSB_SURFACE_H_
#include <va/va.h>
#include "psb_buffer.h"
//#include "xf86mm.h"
/* MSVDX specific */
typedef enum {
STRIDE_352 = 0,
STRIDE_720 = 1,
STRIDE_1280 = 2,
STRIDE_1920 = 3,
STRIDE_512 = 4,
STRIDE_1024 = 5,
STRIDE_2048 = 6,
STRIDE_4096 = 7,
STRIDE_NA,
STRIDE_UNDEFINED,
} psb_surface_stride_t;
typedef struct psb_surface_s *psb_surface_p;
struct psb_surface_s {
struct psb_buffer_s buf;
struct psb_buffer_s *in_loop_buf;
struct psb_buffer_s *ref_buf;
psb_surface_stride_t stride_mode;
int stride;
unsigned int luma_offset;
unsigned int chroma_offset;
/* Used to store driver private data, e.g. decoder specific intermediate status data
* extra_info[0-3]: used for decode
* extra_info[4]: surface fourcc
* extra_info[5]: surface skippeded or not for encode, rotate info for decode
* extra_info[6]: mfld protected surface
*/
int extra_info[8];
int size;
unsigned int bc_buffer;
};
/*
* Create surface
*/
VAStatus psb_surface_create(psb_driver_data_p driver_data,
int width, int height, int fourcc, int protected,
psb_surface_p psb_surface /* out */
);
VAStatus psb_surface_create_for_userptr(
psb_driver_data_p driver_data,
int width, int height,
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,
psb_surface_p psb_surface /* out */
);
VAStatus psb_surface_create_from_kbuf(
psb_driver_data_p driver_data,
int width, int height,
unsigned size, /* total buffer size need to be allocated */
unsigned int fourcc, /* expected fourcc */
int kbuf_handle, /*kernel handle */
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,
psb_surface_p psb_surface /* out */
);
VAStatus psb_surface_create_camera(psb_driver_data_p driver_data,
int width, int height, int stride, int size,
psb_surface_p psb_surface, /* out */
int is_v4l2,
unsigned int id_or_ofs
);
/* id_or_ofs: it is frame ID or frame offset in camear device memory
* for CI frame: it it always frame offset currently
* for v4l2 buf: it is offset used in V4L2 buffer mmap
* user_ptr: virtual address of user buffer.
*/
VAStatus psb_surface_create_camera_from_ub(psb_driver_data_p driver_data,
int width, int height, int stride, int size,
psb_surface_p psb_surface, /* out */
int is_v4l2,
unsigned int id_or_ofs,
const unsigned long *user_ptr);
/*
* Temporarily map surface and set all chroma values of surface to 'chroma'
*/
VAStatus psb_surface_set_chroma(psb_surface_p psb_surface, int chroma);
/*
* Destroy surface
*/
void psb_surface_destroy(psb_surface_p psb_surface);
/*
* Wait for surface to become idle
*/
VAStatus psb_surface_sync(psb_surface_p psb_surface);
/*
* Return surface status
*/
VAStatus psb_surface_query_status(psb_surface_p psb_surface, VASurfaceStatus *status);
/*
* Set current displaying surface info to kernel
*/
int psb_surface_set_displaying(psb_driver_data_p driver_data,
int width, int height,
psb_surface_p psb_surface);
#endif /* _PSB_SURFACE_H_ */
|