Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 1 | /* |
Tharaga Balachandran | 576571c | 2020-01-23 18:41:10 -0500 | [diff] [blame] | 2 | * Copyright (c) 2011-2020, The Linux Foundation. All rights reserved. |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [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 __GR_ADRENO_INFO_H__ |
| 31 | #define __GR_ADRENO_INFO_H__ |
| 32 | |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 33 | #include <media/msm_media_info.h> |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 34 | |
Tharaga Balachandran | 576571c | 2020-01-23 18:41:10 -0500 | [diff] [blame] | 35 | #include "gr_utils.h" |
| 36 | |
Naseer Ahmed | e36f224 | 2017-12-01 15:33:56 -0500 | [diff] [blame] | 37 | namespace gralloc { |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 38 | |
| 39 | // Adreno Pixel Formats |
| 40 | typedef enum { |
| 41 | ADRENO_PIXELFORMAT_UNKNOWN = 0, |
Saurabh Shah | 3cc87ed | 2017-10-24 14:09:35 -0700 | [diff] [blame] | 42 | ADRENO_PIXELFORMAT_R16G16B16A16_FLOAT = 10, |
Arun Kumar K.R | b97ca30 | 2017-04-06 15:59:33 -0700 | [diff] [blame] | 43 | ADRENO_PIXELFORMAT_R10G10B10A2_UNORM = 24, // Vertex, Normalized GL_UNSIGNED_INT_10_10_10_2_OES |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 44 | ADRENO_PIXELFORMAT_R8G8B8A8 = 28, |
| 45 | ADRENO_PIXELFORMAT_R8G8B8A8_SRGB = 29, |
Saurabh Dubey | b28b82b | 2018-05-29 09:46:41 +0530 | [diff] [blame] | 46 | ADRENO_PIXELFORMAT_D32_FLOAT = 40, |
| 47 | ADRENO_PIXELFORMAT_D24_UNORM_S8_UINT = 45, |
| 48 | ADRENO_PIXELFORMAT_D16_UNORM = 55, |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 49 | ADRENO_PIXELFORMAT_B5G6R5 = 85, |
| 50 | ADRENO_PIXELFORMAT_B5G5R5A1 = 86, |
Saurabh Dubey | b28b82b | 2018-05-29 09:46:41 +0530 | [diff] [blame] | 51 | ADRENO_PIXELFORMAT_B8G8R8A8_UNORM = 87, |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 52 | ADRENO_PIXELFORMAT_B8G8R8A8 = 90, |
| 53 | ADRENO_PIXELFORMAT_B8G8R8A8_SRGB = 91, |
| 54 | ADRENO_PIXELFORMAT_B8G8R8X8_SRGB = 93, |
| 55 | ADRENO_PIXELFORMAT_NV12 = 103, |
Rohit Kulkarni | 7943ec9 | 2016-12-20 18:18:46 -0800 | [diff] [blame] | 56 | ADRENO_PIXELFORMAT_P010 = 104, |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 57 | ADRENO_PIXELFORMAT_YUY2 = 107, |
| 58 | ADRENO_PIXELFORMAT_B4G4R4A4 = 115, |
| 59 | ADRENO_PIXELFORMAT_NV12_EXT = 506, // NV12 with non-std alignment and offsets |
| 60 | ADRENO_PIXELFORMAT_R8G8B8X8 = 507, // GL_RGB8 (Internal) |
| 61 | ADRENO_PIXELFORMAT_R8G8B8 = 508, // GL_RGB8 |
| 62 | ADRENO_PIXELFORMAT_A1B5G5R5 = 519, // GL_RGB5_A1 |
| 63 | ADRENO_PIXELFORMAT_R8G8B8X8_SRGB = 520, // GL_SRGB8 |
| 64 | ADRENO_PIXELFORMAT_R8G8B8_SRGB = 521, // GL_SRGB8 |
Arun Kumar K.R | b97ca30 | 2017-04-06 15:59:33 -0700 | [diff] [blame] | 65 | ADRENO_PIXELFORMAT_A2B10G10R10_UNORM = 532, |
Naseer Ahmed | e36f224 | 2017-12-01 15:33:56 -0500 | [diff] [blame] | 66 | // Vertex, Normalized GL_UNSIGNED_INT_10_10_10_2_OES |
Arun Kumar K.R | b97ca30 | 2017-04-06 15:59:33 -0700 | [diff] [blame] | 67 | ADRENO_PIXELFORMAT_R10G10B10X2_UNORM = 537, |
Saurabh Dubey | 7f090b7 | 2018-07-05 12:11:46 +0530 | [diff] [blame] | 68 | ADRENO_PIXELFORMAT_D24_UNORM_X8_UINT = 548, |
Saurabh Dubey | b28b82b | 2018-05-29 09:46:41 +0530 | [diff] [blame] | 69 | ADRENO_PIXELFORMAT_D24_UNORM = 549, |
| 70 | ADRENO_PIXELFORMAT_D32_FLOAT_X24S8_UINT = 551, |
| 71 | ADRENO_PIXELFORMAT_S8_UINT = 552, |
Ramkumar Radhakrishnan | 30ea0f0 | 2018-10-11 19:25:10 -0700 | [diff] [blame] | 72 | ADRENO_PIXELFORMAT_ASTC_4X4 = 568, // ASTC Compressed |
| 73 | ADRENO_PIXELFORMAT_ASTC_5X4 = 569, // ASTC Compressed |
| 74 | ADRENO_PIXELFORMAT_ASTC_5X5 = 570, // ASTC Compressed |
| 75 | ADRENO_PIXELFORMAT_ASTC_6X5 = 571, // ASTC Compressed |
| 76 | ADRENO_PIXELFORMAT_ASTC_6X6 = 572, // ASTC Compressed |
| 77 | ADRENO_PIXELFORMAT_ASTC_8X5 = 573, // ASTC Compressed |
| 78 | ADRENO_PIXELFORMAT_ASTC_8X6 = 574, // ASTC Compressed |
| 79 | ADRENO_PIXELFORMAT_ASTC_8X8 = 575, // ASTC Compressed |
| 80 | ADRENO_PIXELFORMAT_ASTC_10X5 = 576, // ASTC Compressed |
| 81 | ADRENO_PIXELFORMAT_ASTC_10X6 = 577, // ASTC Compressed |
| 82 | ADRENO_PIXELFORMAT_ASTC_10X8 = 578, // ASTC Compressed |
| 83 | ADRENO_PIXELFORMAT_ASTC_10X10 = 579, // ASTC Compressed |
| 84 | ADRENO_PIXELFORMAT_ASTC_12X10 = 580, // ASTC Compressed |
| 85 | ADRENO_PIXELFORMAT_ASTC_12X12 = 581, // ASTC Compressed |
| 86 | ADRENO_PIXELFORMAT_ASTC_4X4_SRGB = 582, // ASTC Compressed |
| 87 | ADRENO_PIXELFORMAT_ASTC_5X4_SRGB = 583, // ASTC Compressed |
| 88 | ADRENO_PIXELFORMAT_ASTC_5X5_SRGB = 584, // ASTC Compressed |
| 89 | ADRENO_PIXELFORMAT_ASTC_6X5_SRGB = 585, // ASTC Compressed |
| 90 | ADRENO_PIXELFORMAT_ASTC_6X6_SRGB = 586, // ASTC Compressed |
| 91 | ADRENO_PIXELFORMAT_ASTC_8X5_SRGB = 587, // ASTC Compressed |
| 92 | ADRENO_PIXELFORMAT_ASTC_8X6_SRGB = 588, // ASTC Compressed |
| 93 | ADRENO_PIXELFORMAT_ASTC_8X8_SRGB = 589, // ASTC Compressed |
| 94 | ADRENO_PIXELFORMAT_ASTC_10X5_SRGB = 590, // ASTC Compressed |
| 95 | ADRENO_PIXELFORMAT_ASTC_10X6_SRGB = 591, // ASTC Compressed |
| 96 | ADRENO_PIXELFORMAT_ASTC_10X8_SRGB = 592, // ASTC Compressed |
| 97 | ADRENO_PIXELFORMAT_ASTC_10X10_SRGB = 593, // ASTC Compressed |
| 98 | ADRENO_PIXELFORMAT_ASTC_12X10_SRGB = 594, // ASTC Compressed |
| 99 | ADRENO_PIXELFORMAT_ASTC_12X12_SRGB = 595, // ASTC Compressed |
Naseer Ahmed | e36f224 | 2017-12-01 15:33:56 -0500 | [diff] [blame] | 100 | // Vertex, Normalized GL_UNSIGNED_INT_10_10_10_2_OES |
| 101 | ADRENO_PIXELFORMAT_R5G6B5 = 610, // RGBA version of B5G6R5 |
| 102 | ADRENO_PIXELFORMAT_R5G5B5A1 = 611, // RGBA version of B5G5R5A1 |
| 103 | ADRENO_PIXELFORMAT_R4G4B4A4 = 612, // RGBA version of B4G4R4A4 |
| 104 | ADRENO_PIXELFORMAT_UYVY = 614, // YUV 4:2:2 packed progressive (1 plane) |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 105 | ADRENO_PIXELFORMAT_NV21 = 619, |
| 106 | ADRENO_PIXELFORMAT_Y8U8V8A8 = 620, // YUV 4:4:4 packed (1 plane) |
| 107 | ADRENO_PIXELFORMAT_Y8 = 625, // Single 8-bit luma only channel YUV format |
Saurabh Shah | 3cc87ed | 2017-10-24 14:09:35 -0700 | [diff] [blame] | 108 | ADRENO_PIXELFORMAT_TP10 = 654, // YUV 4:2:0 planar 10 bits/comp (2 planes) |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 109 | } ADRENOPIXELFORMAT; |
| 110 | |
Saurabh Dubey | b28b82b | 2018-05-29 09:46:41 +0530 | [diff] [blame] | 111 | typedef enum { |
| 112 | SURFACE_TILE_MODE_DISABLE = 0x0, // used for linear surface |
| 113 | SURFACE_TILE_MODE_ENABLE = 0x1 // used for tiled surface |
| 114 | } surface_tile_mode_t; |
| 115 | |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 116 | class AdrenoMemInfo { |
| 117 | public: |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 118 | /* |
| 119 | * Function to compute aligned width and aligned height based on |
| 120 | * width, height, format and usage flags. |
| 121 | * |
| 122 | * @return aligned width, aligned height |
| 123 | */ |
| 124 | void GetAlignedWidthAndHeight(int width, int height, int format, int usage, |
| 125 | unsigned int *aligned_w, unsigned int *aligned_h, bool ubwc_enabled, |
| 126 | bool tile_enabled); |
| 127 | |
| 128 | /* |
| 129 | * Function to compute the adreno aligned width and aligned height |
| 130 | * based on the width and format. |
| 131 | * |
| 132 | * @return aligned width, aligned height |
| 133 | */ |
| 134 | void AlignUnCompressedRGB(int width, int height, int format, int tileEnabled, |
| 135 | unsigned int *aligned_w, unsigned int *aligned_h); |
| 136 | |
| 137 | /* |
| 138 | * Function to compute the adreno aligned width and aligned height |
| 139 | * based on the width and format. |
| 140 | * |
| 141 | * @return aligned width, aligned height |
| 142 | */ |
| 143 | void AlignCompressedRGB(int width, int height, int format, unsigned int *aligned_w, |
| 144 | unsigned int *aligned_h); |
| 145 | |
| 146 | /* |
| 147 | * Function to compute the pixel alignment requirement. |
| 148 | * |
| 149 | * @return alignment |
| 150 | */ |
| 151 | uint32_t GetGpuPixelAlignment(); |
| 152 | |
| 153 | /* |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 154 | * Function to query whether GPU supports UBWC for given HAL format |
| 155 | * @return > 0 : supported |
| 156 | * 0 : not supported |
| 157 | */ |
| 158 | bool IsUBWCSupportedByGPU(int format); |
| 159 | |
| 160 | /* |
Saurabh Dubey | 48b757d | 2018-05-24 19:13:53 +0530 | [diff] [blame] | 161 | * Function to check if GPU supports PI or not |
| 162 | */ |
| 163 | bool IsPISupportedByGPU(int format, uint64_t usage); |
| 164 | /* |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 165 | * Function to get the corresponding Adreno format for given HAL format |
| 166 | */ |
| 167 | ADRENOPIXELFORMAT GetGpuPixelFormat(int hal_format); |
| 168 | |
Saurabh Dubey | b28b82b | 2018-05-29 09:46:41 +0530 | [diff] [blame] | 169 | /* |
| 170 | * Function to get graphics metadata blob size |
| 171 | * @return graphics metadata size |
| 172 | */ |
| 173 | uint32_t AdrenoGetMetadataBlobSize(); |
| 174 | |
| 175 | /* |
| 176 | * Function to populate the graphics metadata blob |
| 177 | * @return 1 : Successful |
| 178 | * 2 : Unsuccessful |
| 179 | */ |
| 180 | int AdrenoInitMemoryLayout(void *metadata_blob, int width, int height, int depth, int format, |
| 181 | int num_samples, int isUBWC, uint64_t usage, uint32_t num_planes); |
| 182 | /* |
| 183 | * Function to get buffer size for based on graphcis metadata |
| 184 | * @return buffer size |
| 185 | */ |
| 186 | uint32_t AdrenoGetAlignedGpuBufferSize(void *metadata_blob); |
| 187 | |
| 188 | /* |
| 189 | * Function to check if adreno size calculation APIs are avaliable |
| 190 | * @return true : Avaliable |
| 191 | * false : Unavaliable |
| 192 | */ |
| 193 | bool AdrenoSizeAPIAvaliable(); |
| 194 | |
Tharaga Balachandran | 576571c | 2020-01-23 18:41:10 -0500 | [diff] [blame] | 195 | void AdrenoSetProperties(gralloc::GrallocProperties props); |
| 196 | |
Saurabh Shah | 14c8e5b | 2017-04-07 10:37:23 -0700 | [diff] [blame] | 197 | static AdrenoMemInfo *GetInstance(); |
| 198 | |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 199 | private: |
Saurabh Shah | 5180c2d | 2017-07-26 11:09:27 -0700 | [diff] [blame] | 200 | AdrenoMemInfo(); |
Saurabh Shah | 14c8e5b | 2017-04-07 10:37:23 -0700 | [diff] [blame] | 201 | ~AdrenoMemInfo(); |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 202 | // link(s)to adreno surface padding library. |
| 203 | int (*LINK_adreno_compute_padding)(int width, int bpp, int surface_tile_height, |
| 204 | int screen_tile_height, int padding_threshold) = NULL; |
| 205 | void (*LINK_adreno_compute_aligned_width_and_height)(int width, int height, int bpp, |
| 206 | int tile_mode, int raster_mode, |
| 207 | int padding_threshold, int *aligned_w, |
| 208 | int *aligned_h) = NULL; |
Prabhanjan Kandula | 7783d96 | 2017-04-21 01:38:32 -0700 | [diff] [blame] | 209 | void (*LINK_adreno_compute_fmt_aligned_width_and_height)(int width, int height, int plane_id, |
| 210 | int format, int num_samples, |
| 211 | int tile_mode, int raster_mode, |
| 212 | int padding_threshold, int *aligned_w, |
| 213 | int *aligned_h) = NULL; |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 214 | void (*LINK_adreno_compute_compressedfmt_aligned_width_and_height)( |
| 215 | int width, int height, int format, int tile_mode, int raster_mode, int padding_threshold, |
| 216 | int *aligned_w, int *aligned_h, int *bpp) = NULL; |
| 217 | int (*LINK_adreno_isUBWCSupportedByGpu)(ADRENOPIXELFORMAT format) = NULL; |
| 218 | unsigned int (*LINK_adreno_get_gpu_pixel_alignment)() = NULL; |
| 219 | |
Saurabh Dubey | b28b82b | 2018-05-29 09:46:41 +0530 | [diff] [blame] | 220 | uint32_t (*LINK_adreno_get_metadata_blob_size)() = NULL; |
| 221 | int (*LINK_adreno_init_memory_layout)(void* metadata_blob, int width, int height, int depth, |
| 222 | ADRENOPIXELFORMAT format, int num_samples, surface_tile_mode_t tile_mode, |
| 223 | uint64_t usage, uint32_t num_planes) = NULL; |
| 224 | uint32_t (*LINK_adreno_get_aligned_gpu_buffer_size)(void* metadata_blob) = NULL; |
Saurabh Dubey | 48b757d | 2018-05-24 19:13:53 +0530 | [diff] [blame] | 225 | int (*LINK_adreno_isPISupportedByGpu)(int format, uint64_t usage) = NULL; |
Saurabh Dubey | b28b82b | 2018-05-29 09:46:41 +0530 | [diff] [blame] | 226 | |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 227 | bool gfx_ubwc_disable_ = false; |
Saurabh Dubey | 937c4e5 | 2018-06-26 11:31:18 +0530 | [diff] [blame] | 228 | bool gfx_ahardware_buffer_disable_ = false; |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 229 | void *libadreno_utils_ = NULL; |
Saurabh Shah | 14c8e5b | 2017-04-07 10:37:23 -0700 | [diff] [blame] | 230 | |
| 231 | static AdrenoMemInfo *s_instance; |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 232 | }; |
| 233 | |
Naseer Ahmed | e36f224 | 2017-12-01 15:33:56 -0500 | [diff] [blame] | 234 | } // namespace gralloc |
Prabhanjan Kandula | 96e9234 | 2016-03-24 21:03:35 +0530 | [diff] [blame] | 235 | |
| 236 | #endif // __GR_ADRENO_INFO_H__ |