Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 1 | /* |
feifanz | 9cc2303 | 2016-03-23 18:48:56 +0800 | [diff] [blame] | 2 | * Copyright (c) 2012-2016, The Linux Foundation. All rights reserved. |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 3 | * |
| 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 | |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 33 | #ifdef __cplusplus |
| 34 | extern "C" { |
| 35 | #endif |
| 36 | |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 37 | enum ColorSpace_t{ |
Shuzhen Wang | 0d11348 | 2014-01-28 16:10:22 -0800 | [diff] [blame] | 38 | ITU_R_601, |
| 39 | ITU_R_601_FR, |
| 40 | ITU_R_709, |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 41 | }; |
Shuzhen Wang | 0d11348 | 2014-01-28 16:10:22 -0800 | [diff] [blame] | 42 | |
Dileep Marchya | 1a7e1f1 | 2015-09-25 19:11:57 -0700 | [diff] [blame] | 43 | enum IGC_t { |
| 44 | IGC_NotSpecified, |
| 45 | IGC_sRGB, |
| 46 | }; |
| 47 | |
Saurabh Shah | 5daeee5 | 2013-01-23 16:52:26 +0800 | [diff] [blame] | 48 | struct HSICData_t { |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 49 | int32_t hue; |
| 50 | float saturation; |
| 51 | int32_t intensity; |
| 52 | float contrast; |
Saurabh Shah | 5daeee5 | 2013-01-23 16:52:26 +0800 | [diff] [blame] | 53 | }; |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 54 | |
Ramkumar Radhakrishnan | 92f3abe | 2013-06-05 13:52:40 -0700 | [diff] [blame] | 55 | struct BufferDim_t { |
| 56 | int32_t sliceWidth; |
| 57 | int32_t sliceHeight; |
| 58 | }; |
| 59 | |
Ray Zhang | 8ace84d | 2016-08-08 19:36:03 +0800 | [diff] [blame^] | 60 | struct S3DGpuComp_t { |
| 61 | int32_t displayId; /* on which display S3D is composed by client */ |
| 62 | uint32_t s3dMode; /* the S3D format of this layer to be accessed by client */ |
| 63 | }; |
| 64 | |
Saurabh Shah | 5daeee5 | 2013-01-23 16:52:26 +0800 | [diff] [blame] | 65 | struct MetaData_t { |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 66 | int32_t operation; |
| 67 | int32_t interlaced; |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 68 | struct BufferDim_t bufferDim; |
feifanz | 9cc2303 | 2016-03-23 18:48:56 +0800 | [diff] [blame] | 69 | float refreshrate; |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 70 | enum ColorSpace_t colorSpace; |
Dileep Marchya | 1a7e1f1 | 2015-09-25 19:11:57 -0700 | [diff] [blame] | 71 | enum IGC_t igc; |
Arun Kumar K.R | da2f69b | 2014-09-30 15:45:37 -0700 | [diff] [blame] | 72 | /* Gralloc sets PRIV_SECURE_BUFFER flag to inform that the buffers are from |
| 73 | * ION_SECURE. which should not be mapped. However, for GPU post proc |
| 74 | * feature, GFX needs to map this buffer, in the client context and in SF |
| 75 | * context, it should not. Hence to differentiate, add this metadata field |
| 76 | * for clients to set, and GPU will to read and know when to map the |
| 77 | * SECURE_BUFFER(ION) */ |
| 78 | int32_t mapSecureBuffer; |
Naseer Ahmed | 3324ff7 | 2015-01-21 17:14:44 -0500 | [diff] [blame] | 79 | /* The supported formats are defined in gralloc_priv.h to |
| 80 | * support legacy code*/ |
| 81 | uint32_t s3dFormat; |
Sushil Chauhan | e7acc3c | 2015-06-23 16:22:30 -0700 | [diff] [blame] | 82 | /* VENUS output buffer is linear for UBWC Interlaced video */ |
| 83 | uint32_t linearFormat; |
Saurabh Shah | 95f8368 | 2015-10-16 10:30:04 -0700 | [diff] [blame] | 84 | /* Set by graphics to indicate that this buffer will be written to but not |
| 85 | * swapped out */ |
Saurabh Shah | b8067a4 | 2015-11-06 16:52:02 -0800 | [diff] [blame] | 86 | uint32_t isSingleBufferMode; |
Ray Zhang | 8ace84d | 2016-08-08 19:36:03 +0800 | [diff] [blame^] | 87 | /* Indicate GPU to draw S3D layer on dedicate display device */ |
| 88 | struct S3DGpuComp_t s3dComp; |
Saurabh Shah | 5daeee5 | 2013-01-23 16:52:26 +0800 | [diff] [blame] | 89 | }; |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 90 | |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 91 | enum DispParamType { |
Arun Kumar K.R | a0394ad | 2015-10-27 13:15:51 -0700 | [diff] [blame] | 92 | UNUSED0 = 0x0001, |
| 93 | UNUSED1 = 0x0002, |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 94 | PP_PARAM_INTERLACED = 0x0004, |
Arun Kumar K.R | a0394ad | 2015-10-27 13:15:51 -0700 | [diff] [blame] | 95 | UNUSED2 = 0x0008, |
| 96 | UNUSED3 = 0x0010, |
| 97 | UNUSED4 = 0x0020, |
| 98 | UNUSED5 = 0x0040, |
Ramkumar Radhakrishnan | 92f3abe | 2013-06-05 13:52:40 -0700 | [diff] [blame] | 99 | UPDATE_BUFFER_GEOMETRY = 0x0080, |
Arun Kumar K.R | a727a88 | 2014-08-20 17:14:26 -0700 | [diff] [blame] | 100 | UPDATE_REFRESH_RATE = 0x0100, |
Shuzhen Wang | 0d11348 | 2014-01-28 16:10:22 -0800 | [diff] [blame] | 101 | UPDATE_COLOR_SPACE = 0x0200, |
Arun Kumar K.R | da2f69b | 2014-09-30 15:45:37 -0700 | [diff] [blame] | 102 | MAP_SECURE_BUFFER = 0x400, |
Naseer Ahmed | 3324ff7 | 2015-01-21 17:14:44 -0500 | [diff] [blame] | 103 | S3D_FORMAT = 0x800, |
Sushil Chauhan | e7acc3c | 2015-06-23 16:22:30 -0700 | [diff] [blame] | 104 | LINEAR_FORMAT = 0x1000, |
Dileep Marchya | 1a7e1f1 | 2015-09-25 19:11:57 -0700 | [diff] [blame] | 105 | SET_IGC = 0x2000, |
Saurabh Shah | 95f8368 | 2015-10-16 10:30:04 -0700 | [diff] [blame] | 106 | SET_SINGLE_BUFFER_MODE = 0x4000, |
Ray Zhang | 8ace84d | 2016-08-08 19:36:03 +0800 | [diff] [blame^] | 107 | SET_S3D_COMP = 0x8000, |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 108 | }; |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 109 | |
feifanz | 9cc2303 | 2016-03-23 18:48:56 +0800 | [diff] [blame] | 110 | enum DispFetchParamType { |
| 111 | GET_PP_PARAM_INTERLACED = 0x0004, |
| 112 | GET_BUFFER_GEOMETRY = 0x0080, |
| 113 | GET_REFRESH_RATE = 0x0100, |
| 114 | GET_COLOR_SPACE = 0x0200, |
| 115 | GET_MAP_SECURE_BUFFER = 0x400, |
| 116 | GET_S3D_FORMAT = 0x800, |
| 117 | GET_LINEAR_FORMAT = 0x1000, |
| 118 | GET_IGC = 0x2000, |
| 119 | GET_SINGLE_BUFFER_MODE = 0x4000, |
Ray Zhang | 8ace84d | 2016-08-08 19:36:03 +0800 | [diff] [blame^] | 120 | GET_S3D_COMP = 0x8000, |
feifanz | 9cc2303 | 2016-03-23 18:48:56 +0800 | [diff] [blame] | 121 | }; |
| 122 | |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 123 | struct private_handle_t; |
| 124 | int setMetaData(struct private_handle_t *handle, enum DispParamType paramType, |
| 125 | void *param); |
| 126 | |
feifanz | 9cc2303 | 2016-03-23 18:48:56 +0800 | [diff] [blame] | 127 | int getMetaData(struct private_handle_t *handle, enum DispFetchParamType paramType, |
| 128 | void *param); |
| 129 | |
| 130 | int copyMetaData(struct private_handle_t *src, struct private_handle_t *dst); |
Ray Zhang | 8ace84d | 2016-08-08 19:36:03 +0800 | [diff] [blame^] | 131 | |
| 132 | int clearMetaData(struct private_handle_t *handle, enum DispParamType paramType); |
| 133 | |
Shuzhen Wang | f3529c3 | 2014-01-28 17:15:45 -0800 | [diff] [blame] | 134 | #ifdef __cplusplus |
| 135 | } |
| 136 | #endif |
Ramkumar Radhakrishnan | 47573e2 | 2012-11-07 11:36:41 -0800 | [diff] [blame] | 137 | |
| 138 | #endif /* _QDMETADATA_H */ |
| 139 | |