blob: c8b34463c41680895eff7a2c99dcc38fbff97693 [file] [log] [blame]
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -08001/*
Gousemoodhin Nadaf8da58ee2019-01-03 10:44:59 +05302 * Copyright (c) 2012-2019, The Linux Foundation. All rights reserved.
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -08003 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above
10 * copyright notice, this list of conditions and the following
11 * disclaimer in the documentation and/or other materials provided
12 * with the distribution.
13 * * Neither the name of The Linux Foundation nor the names of its
14 * contributors may be used to endorse or promote products derived
15 * from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30#ifndef _QDMETADATA_H
31#define _QDMETADATA_H
32
Arun Kumar K.Rb2771bf2016-10-03 21:38:23 -070033#include <color_metadata.h>
Arun Kumar K.Rb2771bf2016-10-03 21:38:23 -070034
Shuzhen Wangf3529c32014-01-28 17:15:45 -080035#ifdef __cplusplus
36extern "C" {
37#endif
38
Praneeth Paladugu3e3e8f82017-03-07 10:42:20 -080039#define MAX_UBWC_STATS_LENGTH 32
Mohan Pallaka5d814432018-08-01 10:40:13 -070040#define GRAPHICS_METADATA_SIZE 4096
Maheshwar Ajja10690722019-01-30 14:12:45 -080041#define CVP_METADATA_SIZE 1024
Praneeth Paladugu3e3e8f82017-03-07 10:42:20 -080042
Shuzhen Wangf3529c32014-01-28 17:15:45 -080043enum ColorSpace_t{
Shuzhen Wang0d113482014-01-28 16:10:22 -080044 ITU_R_601,
45 ITU_R_601_FR,
46 ITU_R_709,
Arun Kumar K.Rc18263e2016-10-03 21:26:10 -070047 ITU_R_2020,
48 ITU_R_2020_FR,
Shuzhen Wangf3529c32014-01-28 17:15:45 -080049};
Shuzhen Wang0d113482014-01-28 16:10:22 -080050
Dileep Marchya1a7e1f12015-09-25 19:11:57 -070051enum IGC_t {
52 IGC_NotSpecified,
53 IGC_sRGB,
54};
55
Saurabh Shah5daeee52013-01-23 16:52:26 +080056struct HSICData_t {
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -080057 int32_t hue;
58 float saturation;
59 int32_t intensity;
60 float contrast;
Saurabh Shah5daeee52013-01-23 16:52:26 +080061};
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -080062
Ramkumar Radhakrishnan92f3abe2013-06-05 13:52:40 -070063struct BufferDim_t {
64 int32_t sliceWidth;
65 int32_t sliceHeight;
66};
67
Praneeth Paladugu3e3e8f82017-03-07 10:42:20 -080068enum UBWC_Version {
69 UBWC_UNUSED = 0,
70 UBWC_1_0 = 0x1,
71 UBWC_2_0 = 0x2,
Varun Arorad7bb8692018-09-11 15:22:00 -070072 UBWC_3_0 = 0x3,
Gousemoodhin Nadaf8da58ee2019-01-03 10:44:59 +053073 UBWC_4_0 = 0x4,
Praneeth Paladugu3e3e8f82017-03-07 10:42:20 -080074 UBWC_MAX_VERSION = 0xFF,
75};
76
77struct UBWC_2_0_Stats {
78 uint32_t nCRStatsTile32; /**< UBWC Stats info for 32 Byte Tile */
79 uint32_t nCRStatsTile64; /**< UBWC Stats info for 64 Byte Tile */
80 uint32_t nCRStatsTile96; /**< UBWC Stats info for 96 Byte Tile */
81 uint32_t nCRStatsTile128; /**< UBWC Stats info for 128 Byte Tile */
82 uint32_t nCRStatsTile160; /**< UBWC Stats info for 160 Byte Tile */
83 uint32_t nCRStatsTile192; /**< UBWC Stats info for 192 Byte Tile */
84 uint32_t nCRStatsTile256; /**< UBWC Stats info for 256 Byte Tile */
85};
86
87struct UBWCStats {
88 enum UBWC_Version version; /* Union depends on this version. */
89 uint8_t bDataValid; /* If [non-zero], CR Stats data is valid.
90 * Consumers may use stats data.
91 * If [zero], CR Stats data is invalid.
92 * Consumers *Shall* not use stats data */
93 union {
94 struct UBWC_2_0_Stats ubwc_stats;
95 uint32_t reserved[MAX_UBWC_STATS_LENGTH]; /* This is for future */
96 };
97};
98
Ray Zhang8ace84d2016-08-08 19:36:03 +080099struct S3DGpuComp_t {
100 int32_t displayId; /* on which display S3D is composed by client */
101 uint32_t s3dMode; /* the S3D format of this layer to be accessed by client */
102};
103
Mohan Pallaka5d814432018-08-01 10:40:13 -0700104typedef struct GraphicsMetadata {
105 uint32_t size;
106 uint32_t data[GRAPHICS_METADATA_SIZE];
107} GraphicsMetadata;
108
Mihir Ganu3d401542019-04-03 11:08:06 -0700109#define VIDEO_HISTOGRAM_STATS_SIZE (4 * 1024)
110/* Frame type bit mask */
111#define QD_SYNC_FRAME (0x1 << 0)
112struct VideoHistogramMetadata {
113 uint32_t stats_info[1024]; /* video stats payload */
114 uint32_t stat_len; /* Payload size in bytes */
115 uint32_t frame_type; /* bit mask to indicate frame type */
116 uint32_t display_width;
117 uint32_t display_height;
118 uint32_t decode_width;
119 uint32_t decode_height;
120 uint32_t reserved[12];
121};
122
Maheshwar Ajja10690722019-01-30 14:12:45 -0800123typedef struct CVPMetadata {
124 uint32_t size; /* payload size in bytes */
125 uint8_t payload[CVP_METADATA_SIZE];
Akshata Sahukaraab1e562019-07-30 13:57:25 -0700126 uint32_t capture_frame_rate;
127 /* Frame rate in Q16 format.
128 Eg: fps = 7.5, then
129 capture_frame_rate = 7 << 16 --> Upper 16 bits to represent 7
130 capture_frame_rate |= 5 -------> Lower 16 bits to represent 5
131
132 If size > 0, framerate is valid
133 If size = 0, invalid data, so ignore all parameters */
134 uint32_t cvp_frame_rate;
Maheshwar Ajja10690722019-01-30 14:12:45 -0800135} CVPMetadata;
136
Saurabh Shah5daeee52013-01-23 16:52:26 +0800137struct MetaData_t {
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -0800138 int32_t operation;
139 int32_t interlaced;
Shuzhen Wangf3529c32014-01-28 17:15:45 -0800140 struct BufferDim_t bufferDim;
feifanz9cc23032016-03-23 18:48:56 +0800141 float refreshrate;
Shuzhen Wangf3529c32014-01-28 17:15:45 -0800142 enum ColorSpace_t colorSpace;
Dileep Marchya1a7e1f12015-09-25 19:11:57 -0700143 enum IGC_t igc;
Arun Kumar K.Rda2f69b2014-09-30 15:45:37 -0700144 /* Gralloc sets PRIV_SECURE_BUFFER flag to inform that the buffers are from
145 * ION_SECURE. which should not be mapped. However, for GPU post proc
146 * feature, GFX needs to map this buffer, in the client context and in SF
147 * context, it should not. Hence to differentiate, add this metadata field
148 * for clients to set, and GPU will to read and know when to map the
149 * SECURE_BUFFER(ION) */
150 int32_t mapSecureBuffer;
Naseer Ahmed3324ff72015-01-21 17:14:44 -0500151 /* The supported formats are defined in gralloc_priv.h to
152 * support legacy code*/
153 uint32_t s3dFormat;
Sushil Chauhane7acc3c2015-06-23 16:22:30 -0700154 /* VENUS output buffer is linear for UBWC Interlaced video */
155 uint32_t linearFormat;
Saurabh Shah95f83682015-10-16 10:30:04 -0700156 /* Set by graphics to indicate that this buffer will be written to but not
157 * swapped out */
Saurabh Shahb8067a42015-11-06 16:52:02 -0800158 uint32_t isSingleBufferMode;
Ray Zhang8ace84d2016-08-08 19:36:03 +0800159 /* Indicate GPU to draw S3D layer on dedicate display device */
160 struct S3DGpuComp_t s3dComp;
Naseer Ahmede8f254d2016-08-02 20:06:40 -0400161
162 /* Set by camera to program the VT Timestamp */
163 uint64_t vtTimeStamp;
Arun Kumar K.Rb2771bf2016-10-03 21:38:23 -0700164 /* Color Aspects + HDR info */
165 ColorMetaData color;
Praneeth Paladugu3e3e8f82017-03-07 10:42:20 -0800166 /* Consumer should read this data as follows based on
167 * Gralloc flag "interlaced" listed above.
168 * [0] : If it is progressive.
169 * [0] : Top field, if it is interlaced.
170 * [1] : Do not read, if it is progressive.
171 * [1] : Bottom field, if it is interlaced.
172 */
173 struct UBWCStats ubwcCRStats[2];
Ashwini Rao6e616962017-11-28 12:12:46 -0800174 /* Set by camera to indicate that this buffer will be used for a High
175 * Performance Video Usecase */
176 uint32_t isVideoPerfMode;
Mohan Pallaka5d814432018-08-01 10:40:13 -0700177 /* Populated and used by adreno during buffer size calculation.
178 * Set only for RGB formats. */
179 GraphicsMetadata graphics_metadata;
Mihir Ganu3d401542019-04-03 11:08:06 -0700180 /* Video hisogram stats populated by video decoder */
181 struct VideoHistogramMetadata video_histogram_stats;
Maheshwar Ajja10690722019-01-30 14:12:45 -0800182 /*
183 * Producer (camera) will set cvp metadata and consumer (video) will
184 * use it. The format of metadata is known to producer and consumer.
185 */
186 CVPMetadata cvpMetadata;
Saurabh Shah5daeee52013-01-23 16:52:26 +0800187};
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -0800188
Shuzhen Wangf3529c32014-01-28 17:15:45 -0800189enum DispParamType {
Mohan Pallaka5d814432018-08-01 10:40:13 -0700190 SET_VT_TIMESTAMP = 0x0001,
191 COLOR_METADATA = 0x0002,
192 PP_PARAM_INTERLACED = 0x0004,
193 SET_VIDEO_PERF_MODE = 0x0008,
194 SET_GRAPHICS_METADATA = 0x0010,
195 SET_UNUSED = 0x0020,
196 SET_UBWC_CR_STATS_INFO = 0x0040,
197 UPDATE_BUFFER_GEOMETRY = 0x0080,
198 UPDATE_REFRESH_RATE = 0x0100,
199 UPDATE_COLOR_SPACE = 0x0200,
200 MAP_SECURE_BUFFER = 0x0400,
201 S3D_FORMAT = 0x0800,
202 LINEAR_FORMAT = 0x1000,
203 SET_IGC = 0x2000,
204 SET_SINGLE_BUFFER_MODE = 0x4000,
205 SET_S3D_COMP = 0x8000,
Maheshwar Ajja10690722019-01-30 14:12:45 -0800206 SET_CVP_METADATA = 0x00010000,
Mihir Ganu3d401542019-04-03 11:08:06 -0700207 SET_VIDEO_HISTOGRAM_STATS = 0x00020000
Shuzhen Wangf3529c32014-01-28 17:15:45 -0800208};
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -0800209
feifanz9cc23032016-03-23 18:48:56 +0800210enum DispFetchParamType {
Mohan Pallaka5d814432018-08-01 10:40:13 -0700211 GET_VT_TIMESTAMP = 0x0001,
212 GET_COLOR_METADATA = 0x0002,
213 GET_PP_PARAM_INTERLACED = 0x0004,
214 GET_VIDEO_PERF_MODE = 0x0008,
215 GET_GRAPHICS_METADATA = 0x0010,
216 GET_UNUSED = 0X0020,
217 GET_UBWC_CR_STATS_INFO = 0x0040,
218 GET_BUFFER_GEOMETRY = 0x0080,
219 GET_REFRESH_RATE = 0x0100,
220 GET_COLOR_SPACE = 0x0200,
221 GET_MAP_SECURE_BUFFER = 0x0400,
222 GET_S3D_FORMAT = 0x0800,
223 GET_LINEAR_FORMAT = 0x1000,
224 GET_IGC = 0x2000,
225 GET_SINGLE_BUFFER_MODE = 0x4000,
226 GET_S3D_COMP = 0x8000,
Maheshwar Ajja10690722019-01-30 14:12:45 -0800227 GET_CVP_METADATA = 0x00010000,
Mihir Ganu3d401542019-04-03 11:08:06 -0700228 GET_VIDEO_HISTOGRAM_STATS = 0x00020000
feifanz9cc23032016-03-23 18:48:56 +0800229};
230
Shuzhen Wangf3529c32014-01-28 17:15:45 -0800231struct private_handle_t;
232int setMetaData(struct private_handle_t *handle, enum DispParamType paramType,
Naseer Ahmed2e6bee12017-04-13 22:45:54 -0400233 void *param);
234int setMetaDataVa(struct MetaData_t* data, enum DispParamType paramType,
235 void *param);
Shuzhen Wangf3529c32014-01-28 17:15:45 -0800236
Naseer Ahmed2e6bee12017-04-13 22:45:54 -0400237int getMetaData(struct private_handle_t *handle,
238 enum DispFetchParamType paramType,
239 void *param);
240int getMetaDataVa(struct MetaData_t* data, enum DispFetchParamType paramType,
241 void *param);
feifanz9cc23032016-03-23 18:48:56 +0800242
243int copyMetaData(struct private_handle_t *src, struct private_handle_t *dst);
Naseer Ahmed2e6bee12017-04-13 22:45:54 -0400244int copyMetaDataVaToHandle(struct MetaData_t *src, struct private_handle_t *dst);
245int copyMetaDataHandleToVa(struct private_handle_t* src, struct MetaData_t *dst);
246int copyMetaDataVaToVa(struct MetaData_t *src, struct MetaData_t *dst);
Ray Zhang8ace84d2016-08-08 19:36:03 +0800247
248int clearMetaData(struct private_handle_t *handle, enum DispParamType paramType);
Naseer Ahmed2e6bee12017-04-13 22:45:54 -0400249int clearMetaDataVa(struct MetaData_t *data, enum DispParamType paramType);
250
251unsigned long getMetaDataSize();
Ray Zhang8ace84d2016-08-08 19:36:03 +0800252
Praveen Chavan5e5679a2018-11-18 11:14:19 -0800253// Map, access metadata and unmap. Used by clients that do not import/free but
254// clone and delete native_handle
255int setMetaDataAndUnmap(struct private_handle_t *handle, enum DispParamType paramType,
256 void *param);
257int getMetaDataAndUnmap(struct private_handle_t *handle,
258 enum DispFetchParamType paramType,
259 void *param);
260
Shuzhen Wangf3529c32014-01-28 17:15:45 -0800261#ifdef __cplusplus
262}
263#endif
Ramkumar Radhakrishnan47573e22012-11-07 11:36:41 -0800264
265#endif /* _QDMETADATA_H */
266