blob: fa086ccb285052a0bcfd4b7d2cdace34c309a46e [file] [log] [blame]
Prabhanjan Kandula96e92342016-03-24 21:03:35 +05301/*
Anjaneya Prasad Musunurib6fe9702018-01-11 13:56:23 +05302 * Copyright (c) 2011-2018, The Linux Foundation. All rights reserved.
Prabhanjan Kandula96e92342016-03-24 21:03:35 +05303 * Not a Contribution
4 *
5 * Copyright (C) 2008 The Android Open Source Project
6 *
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 * http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 */
19
20#ifndef __GRALLOC_PRIV_H__
21#define __GRALLOC_PRIV_H__
22
Soumil Shahd19b9212018-02-02 10:37:24 -080023#include <errno.h>
Dileep Marchya5b4eaed2016-09-22 12:31:11 +053024#include <unistd.h>
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053025#include "gr_priv_handle.h"
26
Uday Kiran Pichika5e656b22018-05-15 18:48:24 +053027#define GRALLOC_PROP_PREFIX "vendor.gralloc."
28#define GRALLOC_PROP(prop_name) GRALLOC_PROP_PREFIX prop_name
29
30#define DISABLE_UBWC_PROP GRALLOC_PROP("disable_ubwc")
Saurabh Dubey937c4e52018-06-26 11:31:18 +053031#define DISABLE_AHARDWAREBUFFER_PROP GRALLOC_PROP("disable_ahardware_buffer")
Uday Kiran Pichika5e656b22018-05-15 18:48:24 +053032#define ENABLE_FB_UBWC_PROP GRALLOC_PROP("enable_fb_ubwc")
33#define MAP_FB_MEMORY_PROP GRALLOC_PROP("map_fb_memory")
Ananda Kishore3c510ff2018-06-17 17:06:52 +053034#define USE_SYSTEM_HEAP_FOR_SENSORS GRALLOC_PROP("use_system_heap_for_sensors")
Uday Kiran Pichika5e656b22018-05-15 18:48:24 +053035
Dileep Marchya5b4eaed2016-09-22 12:31:11 +053036#define ROUND_UP_PAGESIZE(x) roundUpToPageSize(x)
Naseer Ahmede69031e2016-11-22 20:05:16 -050037inline int roundUpToPageSize(int x) {
Naseer Ahmede36f2242017-12-01 15:33:56 -050038 return (x + (getpagesize() - 1)) & ~(getpagesize() - 1);
Dileep Marchya5b4eaed2016-09-22 12:31:11 +053039}
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053040
41/* Gralloc usage bits indicating the type of allocation that should be used */
Naseer Ahmede36f2242017-12-01 15:33:56 -050042/* Refer to BufferUsage in hardware/interfaces/graphics/common/<ver>/types.hal */
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053043
Naseer Ahmede36f2242017-12-01 15:33:56 -050044/* The bits below are in officially defined vendor space
45 * i.e bits 28-31 and 48-63*/
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053046/* Non linear, Universal Bandwidth Compression */
Gurpreet Singh Dhami88ac5e82018-03-28 18:00:50 -040047#define GRALLOC_USAGE_PRIVATE_ALLOC_UBWC (UINT32_C(1) << 28)
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053048
49/* Set this for allocating uncached memory (using O_DSYNC),
50 * cannot be used with noncontiguous heaps */
Gurpreet Singh Dhami88ac5e82018-03-28 18:00:50 -040051#define GRALLOC_USAGE_PRIVATE_UNCACHED (UINT32_C(1) << 29)
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053052
Rohit Kulkarnie6d0a352018-07-11 13:42:28 -070053/* This flag is used to indicate 10 bit format.
54 * When both GRALLOC_USAGE_PRIVATE_ALLOC_UBWC & GRALLOC_USAGE_PRIVATE_10BIT
55 * are set then it will indicate UBWC_TP10 format.
56 * When only GRALLOC_USAGE_PRIVATE_10BIT is set it will indicate linear P010 format.
57 */
58#define GRALLOC_USAGE_PRIVATE_10BIT (UINT32_C(1) << 30)
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053059
60/* This flag is used for SECURE display usecase */
Gurpreet Singh Dhami88ac5e82018-03-28 18:00:50 -040061#define GRALLOC_USAGE_PRIVATE_SECURE_DISPLAY (UINT32_C(1) << 31)
Naseer Ahmede69031e2016-11-22 20:05:16 -050062
Naseer Ahmede36f2242017-12-01 15:33:56 -050063/* This flag is used to indicate video NV21 format */
64#define GRALLOC_USAGE_PRIVATE_VIDEO_NV21_ENCODER 1ULL << 48
Rohit Kulkarnia50206a2017-11-13 15:55:24 -080065
Naseer Ahmede36f2242017-12-01 15:33:56 -050066/* unused legacy flags */
67#define GRALLOC_USAGE_PRIVATE_MM_HEAP 0
68#define GRALLOC_USAGE_PRIVATE_IOMMU_HEAP 0
Naseer Ahmede69031e2016-11-22 20:05:16 -050069
Naseer Ahmede36f2242017-12-01 15:33:56 -050070/* TODO(user): move these to use sanctioned vendor bits
71 * once end to end 64-bit support is available */
72/* This flag is set for WFD usecase */
Gurpreet Singh Dhami88ac5e82018-03-28 18:00:50 -040073#define GRALLOC_USAGE_PRIVATE_WFD (UINT32_C(1) << 21)
Naseer Ahmede69031e2016-11-22 20:05:16 -050074
Rohit Kulkarnie6d0a352018-07-11 13:42:28 -070075/* TODO(user): Remove when clients stop referencing this flag */
Saurabh Dubey81aef932018-06-27 09:41:31 +053076#define GRALLOC_USAGE_PRIVATE_10BIT_TP 0
Naseer Ahmede36f2242017-12-01 15:33:56 -050077
Rohit Kulkarnie6d0a352018-07-11 13:42:28 -070078/* This flag indicates PI format is being used */
79#define GRALLOC_USAGE_PRIVATE_ALLOC_UBWC_PI 1ULL << 49
80
Naseer Ahmede36f2242017-12-01 15:33:56 -050081/* Legacy gralloc1 definitions */
Naseer Ahmede69031e2016-11-22 20:05:16 -050082/* Some clients may still be using the old flags */
Naseer Ahmede36f2242017-12-01 15:33:56 -050083#define GRALLOC1_PRODUCER_USAGE_PRIVATE_ADSP_HEAP GRALLOC_USAGE_PRIVATE_ADSP_HEAP
84#define GRALLOC1_PRODUCER_USAGE_PRIVATE_ALLOC_UBWC GRALLOC_USAGE_PRIVATE_ALLOC_UBWC
85#define GRALLOC1_PRODUCER_USAGE_PRIVATE_UNCACHED GRALLOC_USAGE_PRIVATE_UNCACHED
86#define GRALLOC1_CONSUMER_USAGE_PRIVATE_SECURE_DISPLAY GRALLOC_USAGE_PRIVATE_SECURE_DISPLAY
87#define GRALLOC1_PRODUCER_USAGE_PRIVATE_MM_HEAP GRALLOC_USAGE_PRIVATE_MM_HEAP
88#define GRALLOC1_PRODUCER_USAGE_PRIVATE_10BIT GRALLOC_USAGE_PRIVATE_10BIT
89#define GRALLOC1_PRODUCER_USAGE_PRIVATE_10BIT_TP GRALLOC_USAGE_PRIVATE_10BIT_TP
90#define GRALLOC1_CONSUMER_USAGE_PRIVATE_10BIT_TP GRALLOC_USAGE_PRIVATE_10BIT_TP
91#define GRALLOC1_PRODUCER_USAGE_PRIVATE_VIDEO_NV21_ENCODER GRALLOC_USAGE_PRIVATE_VIDEO_NV21_ENCODER
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053092
93// for PERFORM API :
Prabhanjan Kandula96e92342016-03-24 21:03:35 +053094#define GRALLOC_MODULE_PERFORM_CREATE_HANDLE_FROM_BUFFER 1
95#define GRALLOC_MODULE_PERFORM_GET_STRIDE 2
96#define GRALLOC_MODULE_PERFORM_GET_CUSTOM_STRIDE_FROM_HANDLE 3
97#define GRALLOC_MODULE_PERFORM_GET_CUSTOM_STRIDE_AND_HEIGHT_FROM_HANDLE 4
98#define GRALLOC_MODULE_PERFORM_GET_ATTRIBUTES 5
99#define GRALLOC_MODULE_PERFORM_GET_COLOR_SPACE_FROM_HANDLE 6
100#define GRALLOC_MODULE_PERFORM_GET_YUV_PLANE_INFO 7
101#define GRALLOC_MODULE_PERFORM_GET_MAP_SECURE_BUFFER_INFO 8
102#define GRALLOC_MODULE_PERFORM_GET_UBWC_FLAG 9
103#define GRALLOC_MODULE_PERFORM_GET_RGB_DATA_ADDRESS 10
104#define GRALLOC_MODULE_PERFORM_GET_IGC 11
105#define GRALLOC_MODULE_PERFORM_SET_IGC 12
106#define GRALLOC_MODULE_PERFORM_SET_SINGLE_BUFFER_MODE 13
Naseer Ahmede69031e2016-11-22 20:05:16 -0500107#define GRALLOC1_MODULE_PERFORM_GET_BUFFER_SIZE_AND_DIMENSIONS 14
Ramkumar Radhakrishnan4f12b502017-09-22 17:13:37 -0700108#define GRALLOC1_MODULE_PERFORM_GET_INTERLACE_FLAG 15
Saurabh Dubeyb28b82b2018-05-29 09:46:41 +0530109#define GRALLOC_MODULE_PERFORM_GET_GRAPHICS_METADATA 16
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530110
111// OEM specific HAL formats
112#define HAL_PIXEL_FORMAT_RGBA_5551 6
113#define HAL_PIXEL_FORMAT_RGBA_4444 7
114#define HAL_PIXEL_FORMAT_NV12_ENCODEABLE 0x102
Yahui Wang55563ca2018-01-15 19:50:05 +0800115#define HAL_PIXEL_FORMAT_NV21_ENCODEABLE 0x7FA30C00
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530116#define HAL_PIXEL_FORMAT_YCbCr_420_SP_VENUS 0x7FA30C04
117#define HAL_PIXEL_FORMAT_YCbCr_420_SP_TILED 0x7FA30C03
118#define HAL_PIXEL_FORMAT_YCbCr_420_SP 0x109
119#define HAL_PIXEL_FORMAT_YCrCb_420_SP_ADRENO 0x7FA30C01
120#define HAL_PIXEL_FORMAT_YCrCb_422_SP 0x10B
121#define HAL_PIXEL_FORMAT_R_8 0x10D
122#define HAL_PIXEL_FORMAT_RG_88 0x10E
123#define HAL_PIXEL_FORMAT_YCbCr_444_SP 0x10F
124#define HAL_PIXEL_FORMAT_YCrCb_444_SP 0x110
125#define HAL_PIXEL_FORMAT_YCrCb_422_I 0x111
126#define HAL_PIXEL_FORMAT_BGRX_8888 0x112
127#define HAL_PIXEL_FORMAT_NV21_ZSL 0x113
128#define HAL_PIXEL_FORMAT_YCrCb_420_SP_VENUS 0x114
129#define HAL_PIXEL_FORMAT_BGR_565 0x115
Naseer Ahmedbe5c2ef2017-03-07 10:09:11 -0500130#define HAL_PIXEL_FORMAT_RAW8 0x123
Rajavenu Kyatham6e8c1822018-07-31 10:27:19 +0530131#define HAL_PIXEL_FORMAT_NV12_HEIF 0x116
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530132
133// 10 bit
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530134#define HAL_PIXEL_FORMAT_ARGB_2101010 0x117
135#define HAL_PIXEL_FORMAT_RGBX_1010102 0x118
136#define HAL_PIXEL_FORMAT_XRGB_2101010 0x119
137#define HAL_PIXEL_FORMAT_BGRA_1010102 0x11A
138#define HAL_PIXEL_FORMAT_ABGR_2101010 0x11B
139#define HAL_PIXEL_FORMAT_BGRX_1010102 0x11C
140#define HAL_PIXEL_FORMAT_XBGR_2101010 0x11D
141#define HAL_PIXEL_FORMAT_YCbCr_420_P010 0x11F
Rohit Kulkarni7943ec92016-12-20 18:18:46 -0800142#define HAL_PIXEL_FORMAT_YCbCr_420_P010_UBWC 0x124
Mathew Joseph Karimpanala73082e2017-10-16 18:01:21 +0530143#define HAL_PIXEL_FORMAT_YCbCr_420_P010_VENUS 0x7FA30C0A
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530144
Naseer Ahmede36f2242017-12-01 15:33:56 -0500145#define HAL_PIXEL_FORMAT_CbYCrY_422_I 0x120
146#define HAL_PIXEL_FORMAT_BGR_888 0x121
Camus Wong5c5e6fb2017-03-21 17:02:48 -0400147
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530148#define HAL_PIXEL_FORMAT_INTERLACE 0x180
149
150// v4l2_fourcc('Y', 'U', 'Y', 'L'). 24 bpp YUYV 4:2:2 10 bit per component
151#define HAL_PIXEL_FORMAT_YCbCr_422_I_10BIT 0x4C595559
152
153// v4l2_fourcc('Y', 'B', 'W', 'C'). 10 bit per component. This compressed
154// format reduces the memory access bandwidth
155#define HAL_PIXEL_FORMAT_YCbCr_422_I_10BIT_COMPRESSED 0x43574259
156
157// UBWC aligned Venus format
158#define HAL_PIXEL_FORMAT_YCbCr_420_SP_VENUS_UBWC 0x7FA30C06
Naseer Ahmede36f2242017-12-01 15:33:56 -0500159#define HAL_PIXEL_FORMAT_YCbCr_420_TP10_UBWC 0x7FA30C09
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530160
161// Khronos ASTC formats
162#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_4x4_KHR 0x93B0
163#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_5x4_KHR 0x93B1
164#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_5x5_KHR 0x93B2
165#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_6x5_KHR 0x93B3
166#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_6x6_KHR 0x93B4
167#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_8x5_KHR 0x93B5
168#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_8x6_KHR 0x93B6
169#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_8x8_KHR 0x93B7
170#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_10x5_KHR 0x93B8
171#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_10x6_KHR 0x93B9
172#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_10x8_KHR 0x93BA
173#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_10x10_KHR 0x93BB
174#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_12x10_KHR 0x93BC
175#define HAL_PIXEL_FORMAT_COMPRESSED_RGBA_ASTC_12x12_KHR 0x93BD
176#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_4x4_KHR 0x93D0
177#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_5x4_KHR 0x93D1
178#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_5x5_KHR 0x93D2
179#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_6x5_KHR 0x93D3
180#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_6x6_KHR 0x93D4
181#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_8x5_KHR 0x93D5
182#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_8x6_KHR 0x93D6
183#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_8x8_KHR 0x93D7
184#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_10x5_KHR 0x93D8
185#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_10x6_KHR 0x93D9
186#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_10x8_KHR 0x93DA
187#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_10x10_KHR 0x93DB
188#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_12x10_KHR 0x93DC
189#define HAL_PIXEL_FORMAT_COMPRESSED_SRGB8_ALPHA8_ASTC_12x12_KHR 0x93DD
190
191/* possible values for inverse gamma correction */
192#define HAL_IGC_NOT_SPECIFIED 0
193#define HAL_IGC_s_RGB 1
194
Arun Kumar K.Rc18263e2016-10-03 21:26:10 -0700195/* Color Space: Values maps to ColorSpace_t in qdMetadata.h */
Naseer Ahmede36f2242017-12-01 15:33:56 -0500196#define HAL_CSC_ITU_R_601 0
197#define HAL_CSC_ITU_R_601_FR 1
198#define HAL_CSC_ITU_R_709 2
199#define HAL_CSC_ITU_R_2020 3
200#define HAL_CSC_ITU_R_2020_FR 4
Arun Kumar K.Rc18263e2016-10-03 21:26:10 -0700201
Prabhanjan Kandula96e92342016-03-24 21:03:35 +0530202/* possible formats for 3D content*/
203enum {
204 HAL_NO_3D = 0x0,
205 HAL_3D_SIDE_BY_SIDE_L_R = 0x1,
206 HAL_3D_SIDE_BY_SIDE_R_L = 0x2,
207 HAL_3D_TOP_BOTTOM = 0x4,
208 HAL_3D_IN_SIDE_BY_SIDE_L_R = 0x10000, // unused legacy format
209};
210
211enum { BUFFER_TYPE_UI = 0, BUFFER_TYPE_VIDEO };
212
213#endif // __GRALLOC_PRIV_H__