blob: 7d055fc628cf974a6f811773d0a8a24ed08d8b8a [file] [log] [blame]
Iliyan Malchev202a77d2012-06-11 14:41:12 -07001/*
2 * Copyright (C) 2008 The Android Open Source Project
Ramkumar Radhakrishnandb89d1f2016-03-07 20:15:52 -08003 * Copyright (c) 2011 - 2016, The Linux Foundation. All rights reserved.
Iliyan Malchev202a77d2012-06-11 14:41:12 -07004 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18#ifndef GR_H_
19#define GR_H_
20
21#include <stdint.h>
Iliyan Malchev202a77d2012-06-11 14:41:12 -070022#include <limits.h>
23#include <sys/cdefs.h>
24#include <hardware/gralloc.h>
25#include <pthread.h>
26#include <errno.h>
Dileep Marchya5b4eaed2016-09-22 12:31:11 +053027#include <unistd.h>
Iliyan Malchev202a77d2012-06-11 14:41:12 -070028
29#include <cutils/native_handle.h>
Naomi Luisa44100c2013-02-08 12:42:03 -080030#include <utils/Singleton.h>
Sushil Chauhan082acd62015-01-14 16:49:29 -080031#include "adreno_utils.h"
Iliyan Malchev202a77d2012-06-11 14:41:12 -070032
33/*****************************************************************************/
34
35struct private_module_t;
36struct private_handle_t;
37
Saurabh Shah8f0ea6f2014-05-19 16:48:53 -070038inline unsigned int roundUpToPageSize(unsigned int x) {
Dileep Marchya5b4eaed2016-09-22 12:31:11 +053039 return (x + (getpagesize()-1)) & ~(getpagesize()-1);
Iliyan Malchev202a77d2012-06-11 14:41:12 -070040}
41
Arun Kumar K.R6c85f052014-01-21 21:47:41 -080042template <class Type>
43inline Type ALIGN(Type x, Type align) {
Iliyan Malchev202a77d2012-06-11 14:41:12 -070044 return (x + align-1) & ~(align-1);
45}
46
47#define FALSE 0
48#define TRUE 1
49
50int mapFrameBufferLocked(struct private_module_t* module);
51int terminateBuffer(gralloc_module_t const* module, private_handle_t* hnd);
Saurabh Shah8f0ea6f2014-05-19 16:48:53 -070052unsigned int getBufferSizeAndDimensions(int width, int height, int format,
53 int usage, int& alignedw, int &alignedh);
54unsigned int getBufferSizeAndDimensions(int width, int height, int format,
55 int& alignedw, int &alignedh);
Iliyan Malchev202a77d2012-06-11 14:41:12 -070056
Manoj Kumar AVM8a220812013-10-10 11:46:06 -070057
58// Attributes include aligned width, aligned height, tileEnabled and size of the buffer
59void getBufferAttributes(int width, int height, int format, int usage,
60 int& alignedw, int &alignedh,
Saurabh Shah8f0ea6f2014-05-19 16:48:53 -070061 int& tileEnabled, unsigned int &size);
Manoj Kumar AVM8a220812013-10-10 11:46:06 -070062
63
64bool isMacroTileEnabled(int format, int usage);
65
Iliyan Malchev202a77d2012-06-11 14:41:12 -070066int decideBufferHandlingMechanism(int format, const char *compositionUsed,
Naseer Ahmed29a26812012-06-14 00:56:20 -070067 int hasBlitEngine, int *needConversion,
68 int *useBufferDirectly);
Iliyan Malchev202a77d2012-06-11 14:41:12 -070069
70// Allocate buffer from width, height, format into a private_handle_t
71// It is the responsibility of the caller to free the buffer
72int alloc_buffer(private_handle_t **pHnd, int w, int h, int format, int usage);
73void free_buffer(private_handle_t *hnd);
Naseer Ahmedb29fdfd2014-04-08 20:23:47 -040074int getYUVPlaneInfo(private_handle_t* pHnd, struct android_ycbcr* ycbcr);
Sushil Chauhanc85b65b2015-04-30 11:05:36 -070075int getRgbDataAddress(private_handle_t* pHnd, void** rgb_data);
Iliyan Malchev202a77d2012-06-11 14:41:12 -070076
Sushil Chauhan65e26302015-01-14 10:48:57 -080077// To query if UBWC is enabled, based on format and usage flags
78bool isUBwcEnabled(int format, int usage);
79
Ramkumar Radhakrishnandb89d1f2016-03-07 20:15:52 -080080// Function to check if the format is an RGB format
Naomi Luiscffc5bd2015-08-28 14:57:31 -070081bool isUncompressedRgbFormat(int format);
82
Iliyan Malchev202a77d2012-06-11 14:41:12 -070083/*****************************************************************************/
84
85class Locker {
86 pthread_mutex_t mutex;
Raj kamal59fea562014-04-01 16:52:19 +053087 pthread_cond_t cond;
Naseer Ahmed29a26812012-06-14 00:56:20 -070088 public:
Iliyan Malchev202a77d2012-06-11 14:41:12 -070089 class Autolock {
90 Locker& locker;
Naseer Ahmed29a26812012-06-14 00:56:20 -070091 public:
Iliyan Malchev202a77d2012-06-11 14:41:12 -070092 inline Autolock(Locker& locker) : locker(locker) { locker.lock(); }
93 inline ~Autolock() { locker.unlock(); }
94 };
Raj kamal59fea562014-04-01 16:52:19 +053095 inline Locker() {
96 pthread_mutex_init(&mutex, 0);
97 pthread_cond_init(&cond, 0);
98 }
99 inline ~Locker() {
100 pthread_mutex_destroy(&mutex);
101 pthread_cond_destroy(&cond);
102 }
Iliyan Malchev202a77d2012-06-11 14:41:12 -0700103 inline void lock() { pthread_mutex_lock(&mutex); }
Raj kamal59fea562014-04-01 16:52:19 +0530104 inline void wait() { pthread_cond_wait(&cond, &mutex); }
Iliyan Malchev202a77d2012-06-11 14:41:12 -0700105 inline void unlock() { pthread_mutex_unlock(&mutex); }
Raj kamal59fea562014-04-01 16:52:19 +0530106 inline void signal() { pthread_cond_signal(&cond); }
Iliyan Malchev202a77d2012-06-11 14:41:12 -0700107};
108
Naomi Luisa44100c2013-02-08 12:42:03 -0800109
110class AdrenoMemInfo : public android::Singleton <AdrenoMemInfo>
111{
112 public:
Naomi Luis01f5c8e2013-02-11 12:46:24 -0800113 AdrenoMemInfo();
Naomi Luisa44100c2013-02-08 12:42:03 -0800114
Naomi Luis01f5c8e2013-02-11 12:46:24 -0800115 ~AdrenoMemInfo();
Naomi Luisa44100c2013-02-08 12:42:03 -0800116
Naomi Luis01f5c8e2013-02-11 12:46:24 -0800117 /*
Sushil Chauhan65e26302015-01-14 10:48:57 -0800118 * Function to compute aligned width and aligned height based on
119 * width, height, format and usage flags.
120 *
121 * @return aligned width, aligned height
122 */
123 void getAlignedWidthAndHeight(int width, int height, int format,
124 int usage, int& aligned_w, int& aligned_h);
125
126 /*
Manoj Kumar AVM8e1aa182015-08-05 19:45:16 -0700127 * Function to compute aligned width and aligned height based on
128 * private handle
129 *
130 * @return aligned width, aligned height
131 */
132 void getAlignedWidthAndHeight(const private_handle_t *hnd, int& aligned_w, int& aligned_h);
133
134 /*
Ramkumar Radhakrishnan473f4082013-11-04 14:29:18 -0800135 * Function to compute the adreno aligned width and aligned height
136 * based on the width and format.
Naomi Luis01f5c8e2013-02-11 12:46:24 -0800137 *
Ramkumar Radhakrishnan473f4082013-11-04 14:29:18 -0800138 * @return aligned width, aligned height
Naomi Luis01f5c8e2013-02-11 12:46:24 -0800139 */
Sushil Chauhan65e26302015-01-14 10:48:57 -0800140 void getGpuAlignedWidthHeight(int width, int height, int format,
Manoj Kumar AVM8a220812013-10-10 11:46:06 -0700141 int tileEnabled, int& alignedw, int &alignedh);
142
143 /*
Ramkumar Radhakrishnanba55eac2016-08-26 22:33:48 -0700144 * Function to compute unaligned width and unaligned height based on
145 * private handle
146 *
147 * @return unaligned width, unaligned height
148 */
149 void getUnalignedWidthAndHeight(const private_handle_t *hnd, int& unaligned_w,
150 int& unaligned_h);
151
152 /*
Manoj Kumar AVM8a220812013-10-10 11:46:06 -0700153 * Function to return whether GPU support MacroTile feature
154 *
155 * @return >0 : supported
156 * 0 : not supported
157 */
158 int isMacroTilingSupportedByGPU();
159
Sushil Chauhan65e26302015-01-14 10:48:57 -0800160 /*
161 * Function to query whether GPU supports UBWC for given HAL format
162 * @return > 0 : supported
163 * 0 : not supported
164 */
165 int isUBWCSupportedByGPU(int format);
166
Sushil Chauhan082acd62015-01-14 16:49:29 -0800167 /*
168 * Function to get the corresponding Adreno format for given HAL format
169 */
170 ADRENOPIXELFORMAT getGpuPixelFormat(int hal_format);
171
Naomi Luisa44100c2013-02-08 12:42:03 -0800172 private:
Mohan Maiyacbeab9e2015-04-20 09:20:44 -0700173 // Overriding flag to disable UBWC alloc for graphics stack
174 int gfx_ubwc_disable;
Naomi Luis01f5c8e2013-02-11 12:46:24 -0800175 // Pointer to the padding library.
176 void *libadreno_utils;
177
Jeykumar Sankaran2ba20512014-02-27 15:21:42 -0800178 // link(s)to adreno surface padding library.
Naomi Luis01f5c8e2013-02-11 12:46:24 -0800179 int (*LINK_adreno_compute_padding) (int width, int bpp,
180 int surface_tile_height,
181 int screen_tile_height,
182 int padding_threshold);
Jeykumar Sankaran2ba20512014-02-27 15:21:42 -0800183
Ramkumar Radhakrishnan473f4082013-11-04 14:29:18 -0800184 void (*LINK_adreno_compute_aligned_width_and_height) (int width,
185 int height,
186 int bpp,
187 int tile_mode,
188 int raster_mode,
189 int padding_threshold,
190 int *aligned_w,
191 int *aligned_h);
Jeykumar Sankaran2ba20512014-02-27 15:21:42 -0800192
Manoj Kumar AVM8a220812013-10-10 11:46:06 -0700193 int (*LINK_adreno_isMacroTilingSupportedByGpu) (void);
Ramkumar Radhakrishnan473f4082013-11-04 14:29:18 -0800194
Jeykumar Sankaran2ba20512014-02-27 15:21:42 -0800195 void(*LINK_adreno_compute_compressedfmt_aligned_width_and_height)(
196 int width,
197 int height,
198 int format,
199 int tile_mode,
200 int raster_mode,
201 int padding_threshold,
202 int *aligned_w,
203 int *aligned_h,
204 int *bpp);
Sushil Chauhan082acd62015-01-14 16:49:29 -0800205
206 int (*LINK_adreno_isUBWCSupportedByGpu) (ADRENOPIXELFORMAT format);
Sushil Chauhan521ce352015-08-28 11:33:30 -0700207
208 unsigned int (*LINK_adreno_get_gpu_pixel_alignment) ();
Naomi Luisa44100c2013-02-08 12:42:03 -0800209};
Ramakant Singhc85ccee2016-04-01 15:25:17 +0530210
211
212class MDPCapabilityInfo : public android::Singleton <MDPCapabilityInfo>
213{
Sushil Chauhan01361412016-04-25 16:36:18 -0700214 int isMacroTileSupported = 0;
215 int isUBwcSupported = 0;
Jeykumar Sankaran9bc1a782015-12-14 18:36:27 -0800216 int isWBUBWCSupported = 0;
Sushil Chauhan01361412016-04-25 16:36:18 -0700217
Ramakant Singhc85ccee2016-04-01 15:25:17 +0530218 public:
219 MDPCapabilityInfo();
220 /*
221 * Function to return whether MDP support MacroTile feature
222 *
223 * @return 1 : supported
224 * 0 : not supported
225 */
Sushil Chauhan01361412016-04-25 16:36:18 -0700226 int isMacroTilingSupportedByMDP() { return isMacroTileSupported; }
227 /*
228 * Function to return whether MDP supports UBWC feature
229 *
230 * @return 1 : supported
231 * 0 : not supported
232 */
233 int isUBwcSupportedByMDP() { return isUBwcSupported; }
Jeykumar Sankaran9bc1a782015-12-14 18:36:27 -0800234 /*
235 * Function to return whether MDP WB block outputs UBWC format
236 *
237 * @return 1 : supported
238 * 0 : not supported
239 */
240 int isWBUBWCSupportedByMDP() { return isWBUBWCSupported; }
Ramakant Singhc85ccee2016-04-01 15:25:17 +0530241};
242
Iliyan Malchev202a77d2012-06-11 14:41:12 -0700243#endif /* GR_H_ */