Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2010 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 17 | #ifndef ANDROID_HWUI_PROPERTIES_H |
| 18 | #define ANDROID_HWUI_PROPERTIES_H |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 19 | |
Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 20 | #include <cutils/properties.h> |
| 21 | |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 22 | /** |
| 23 | * This file contains the list of system properties used to configure |
| 24 | * the OpenGLRenderer. |
| 25 | */ |
| 26 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 27 | namespace android { |
| 28 | namespace uirenderer { |
| 29 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 30 | /////////////////////////////////////////////////////////////////////////////// |
| 31 | // Compile-time properties |
| 32 | /////////////////////////////////////////////////////////////////////////////// |
| 33 | |
Romain Guy | 726aeba | 2011-06-01 14:52:00 -0700 | [diff] [blame] | 34 | // If turned on, text is interpreted as glyphs instead of UTF-16 |
| 35 | #define RENDER_TEXT_AS_GLYPHS 1 |
| 36 | |
Romain Guy | 28d8ff6 | 2011-08-22 14:01:34 -0700 | [diff] [blame] | 37 | // Textures used by layers must have dimensions multiples of this number |
| 38 | #define LAYER_SIZE 64 |
| 39 | |
Romain Guy | 8d4aeb7 | 2013-02-12 16:08:55 -0800 | [diff] [blame] | 40 | // Defines the size in bits of the stencil buffer for the framebuffer |
Romain Guy | ada4d53 | 2012-02-02 17:31:16 -0800 | [diff] [blame] | 41 | // Note: Only 1 bit is required for clipping but more bits are required |
Romain Guy | 8d4aeb7 | 2013-02-12 16:08:55 -0800 | [diff] [blame] | 42 | // to properly implement overdraw debugging |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 43 | #define STENCIL_BUFFER_SIZE 8 |
Romain Guy | 530041d | 2012-01-25 18:56:29 -0800 | [diff] [blame] | 44 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 45 | /////////////////////////////////////////////////////////////////////////////// |
| 46 | // Debug properties |
| 47 | /////////////////////////////////////////////////////////////////////////////// |
| 48 | |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 49 | /** |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 50 | * Debug level for app developers. The value is a numeric value defined |
| 51 | * by the DebugLevel enum below. |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 52 | */ |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 53 | #define PROPERTY_DEBUG "debug.hwui.level" |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 54 | |
| 55 | /** |
| 56 | * Debug levels. Debug levels are used as flags. |
| 57 | */ |
| 58 | enum DebugLevel { |
| 59 | kDebugDisabled = 0, |
| 60 | kDebugMemory = 1, |
Romain Guy | 25dc3a7 | 2010-12-10 12:33:05 -0800 | [diff] [blame] | 61 | kDebugCaches = 2, |
Kenny Root | 042f7d6 | 2011-07-13 09:49:43 -0700 | [diff] [blame] | 62 | kDebugMoreCaches = kDebugMemory | kDebugCaches |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 63 | }; |
| 64 | |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 65 | /** |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 66 | * Used to enable/disable layers update debugging. The accepted values are |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 67 | * "true" and "false". The default value is "false". |
| 68 | */ |
| 69 | #define PROPERTY_DEBUG_LAYERS_UPDATES "debug.hwui.show_layers_updates" |
| 70 | |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 71 | /** |
Romain Guy | 627c6fd | 2013-08-21 11:53:18 -0700 | [diff] [blame] | 72 | * Used to enable/disable overdraw debugging. |
| 73 | * |
| 74 | * The accepted values are |
| 75 | * "show", to show overdraw |
| 76 | * "show_deuteranomaly", to show overdraw if you suffer from Deuteranomaly |
| 77 | * "count", to show an overdraw counter |
| 78 | * "false", to disable overdraw debugging |
| 79 | * |
| 80 | * The default value is "false". |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 81 | */ |
Romain Guy | 78dd96d | 2013-05-03 14:24:16 -0700 | [diff] [blame] | 82 | #define PROPERTY_DEBUG_OVERDRAW "debug.hwui.overdraw" |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 83 | |
Romain Guy | 87e2f757 | 2012-09-24 11:37:12 -0700 | [diff] [blame] | 84 | /** |
John Reck | fe5e7b7 | 2014-05-23 17:42:28 -0700 | [diff] [blame] | 85 | * System property used to enable or disable hardware rendering profiling. |
| 86 | * The default value of this property is assumed to be false. |
| 87 | * |
| 88 | * When profiling is enabled, the adb shell dumpsys gfxinfo command will |
| 89 | * output extra information about the time taken to execute by the last |
| 90 | * frames. |
| 91 | * |
| 92 | * Possible values: |
| 93 | * "true", to enable profiling |
| 94 | * "visual_bars", to enable profiling and visualize the results on screen |
| 95 | * "false", to disable profiling |
| 96 | */ |
| 97 | #define PROPERTY_PROFILE "debug.hwui.profile" |
| 98 | #define PROPERTY_PROFILE_VISUALIZE_BARS "visual_bars" |
| 99 | |
| 100 | /** |
Romain Guy | 3ff0bfd | 2013-02-25 14:15:37 -0800 | [diff] [blame] | 101 | * Used to enable/disable non-rectangular clipping debugging. |
| 102 | * |
| 103 | * The accepted values are: |
| 104 | * "highlight", drawing commands clipped by the stencil will |
| 105 | * be colored differently |
| 106 | * "region", renders the clipping region on screen whenever |
| 107 | * the stencil is set |
| 108 | * "hide", don't show the clip |
| 109 | * |
| 110 | * The default value is "hide". |
| 111 | */ |
Romain Guy | 08bca88 | 2013-02-25 16:21:30 -0800 | [diff] [blame] | 112 | #define PROPERTY_DEBUG_STENCIL_CLIP "debug.hwui.show_non_rect_clip" |
Romain Guy | 3ff0bfd | 2013-02-25 14:15:37 -0800 | [diff] [blame] | 113 | |
| 114 | /** |
John Reck | 23d307c | 2014-10-27 12:38:48 -0700 | [diff] [blame] | 115 | * Turn on to draw dirty regions every other frame. |
| 116 | * |
| 117 | * Possible values: |
| 118 | * "true", to enable dirty regions debugging |
| 119 | * "false", to disable dirty regions debugging |
| 120 | */ |
| 121 | #define PROPERTY_DEBUG_SHOW_DIRTY_REGIONS "debug.hwui.show_dirty_regions" |
| 122 | |
| 123 | /** |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 124 | * Disables draw operation deferral if set to "true", forcing draw |
| 125 | * commands to be issued to OpenGL in order, and processed in sequence |
| 126 | * with state-manipulation canvas commands. |
| 127 | */ |
| 128 | #define PROPERTY_DISABLE_DRAW_DEFER "debug.hwui.disable_draw_defer" |
| 129 | |
| 130 | /** |
| 131 | * Used to disable draw operation reordering when deferring draw operations |
| 132 | * Has no effect if PROPERTY_DISABLE_DRAW_DEFER is set to "true" |
| 133 | */ |
| 134 | #define PROPERTY_DISABLE_DRAW_REORDER "debug.hwui.disable_draw_reorder" |
| 135 | |
John Reck | d04794a | 2015-05-08 10:04:36 -0700 | [diff] [blame] | 136 | /** |
| 137 | * Setting this property will enable or disable the dropping of frames with |
| 138 | * empty damage. Default is "true". |
| 139 | */ |
| 140 | #define PROPERTY_SKIP_EMPTY_DAMAGE "debug.hwui.skip_empty_damage" |
| 141 | |
| 142 | /** |
John Reck | 149173d | 2015-08-10 09:52:29 -0700 | [diff] [blame] | 143 | * Controls whether or not HWUI will use the EGL_EXT_buffer_age extension |
| 144 | * to do partial invalidates. Setting this to "false" will fall back to |
| 145 | * using BUFFER_PRESERVED instead |
| 146 | * Default is "true" |
| 147 | */ |
| 148 | #define PROPERTY_USE_BUFFER_AGE "debug.hwui.use_buffer_age" |
| 149 | |
| 150 | /** |
| 151 | * Setting this to "false" will force HWUI to always do full-redraws of the surface. |
| 152 | * This will disable the use of EGL_EXT_buffer_age and BUFFER_PRESERVED. |
| 153 | * Default is "true" |
| 154 | */ |
| 155 | #define PROPERTY_ENABLE_PARTIAL_UPDATES "debug.hwui.enable_partial_updates" |
| 156 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 157 | /////////////////////////////////////////////////////////////////////////////// |
| 158 | // Runtime configuration properties |
| 159 | /////////////////////////////////////////////////////////////////////////////// |
| 160 | |
| 161 | /** |
Romain Guy | 87e2f757 | 2012-09-24 11:37:12 -0700 | [diff] [blame] | 162 | * Used to enable/disable scissor optimization. The accepted values are |
| 163 | * "true" and "false". The default value is "false". |
| 164 | * |
| 165 | * When scissor optimization is enabled, OpenGLRenderer will attempt to |
| 166 | * minimize the use of scissor by selectively enabling and disabling the |
| 167 | * GL scissor test. |
| 168 | * When the optimization is disabled, OpenGLRenderer will keep the GL |
| 169 | * scissor test enabled and change the scissor rect as needed. |
| 170 | * Some GPUs (for instance the SGX 540) perform better when changing |
| 171 | * the scissor rect often than when enabling/disabling the scissor test |
| 172 | * often. |
| 173 | */ |
| 174 | #define PROPERTY_DISABLE_SCISSOR_OPTIMIZATION "ro.hwui.disable_scissor_opt" |
| 175 | |
Chris Craik | c3566d0 | 2013-02-04 16:16:33 -0800 | [diff] [blame] | 176 | /** |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 177 | * Indicates whether PBOs can be used to back pixel buffers. |
Romain Guy | f9f0016 | 2013-05-09 11:50:12 -0700 | [diff] [blame] | 178 | * Accepted values are "true" and "false". Default is true. |
Chris Craik | c3566d0 | 2013-02-04 16:16:33 -0800 | [diff] [blame] | 179 | */ |
Romain Guy | f9f0016 | 2013-05-09 11:50:12 -0700 | [diff] [blame] | 180 | #define PROPERTY_ENABLE_GPU_PIXEL_BUFFERS "ro.hwui.use_gpu_pixel_buffers" |
Chris Craik | c3566d0 | 2013-02-04 16:16:33 -0800 | [diff] [blame] | 181 | |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 182 | // These properties are defined in mega-bytes |
| 183 | #define PROPERTY_TEXTURE_CACHE_SIZE "ro.hwui.texture_cache_size" |
| 184 | #define PROPERTY_LAYER_CACHE_SIZE "ro.hwui.layer_cache_size" |
Romain Guy | 8d4aeb7 | 2013-02-12 16:08:55 -0800 | [diff] [blame] | 185 | #define PROPERTY_RENDER_BUFFER_CACHE_SIZE "ro.hwui.r_buffer_cache_size" |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 186 | #define PROPERTY_GRADIENT_CACHE_SIZE "ro.hwui.gradient_cache_size" |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 187 | #define PROPERTY_PATH_CACHE_SIZE "ro.hwui.path_cache_size" |
Chris Craik | 05f3d6e | 2014-06-02 16:27:04 -0700 | [diff] [blame] | 188 | #define PROPERTY_VERTEX_CACHE_SIZE "ro.hwui.vertex_cache_size" |
Romain Guy | 3b748a4 | 2013-04-17 18:54:38 -0700 | [diff] [blame] | 189 | #define PROPERTY_PATCH_CACHE_SIZE "ro.hwui.patch_cache_size" |
Romain Guy | 1e45aae | 2010-08-13 19:39:53 -0700 | [diff] [blame] | 190 | #define PROPERTY_DROP_SHADOW_CACHE_SIZE "ro.hwui.drop_shadow_cache_size" |
Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 191 | #define PROPERTY_FBO_CACHE_SIZE "ro.hwui.fbo_cache_size" |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 192 | |
Romain Guy | eca0ca2 | 2011-11-04 15:12:29 -0700 | [diff] [blame] | 193 | // These properties are defined in percentage (range 0..1) |
Romain Guy | 115096f | 2013-03-19 11:32:41 -0700 | [diff] [blame] | 194 | #define PROPERTY_TEXTURE_CACHE_FLUSH_RATE "ro.hwui.texture_cache_flushrate" |
Romain Guy | eca0ca2 | 2011-11-04 15:12:29 -0700 | [diff] [blame] | 195 | |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 196 | // These properties are defined in pixels |
Chet Haase | eb32a49 | 2012-08-31 13:54:03 -0700 | [diff] [blame] | 197 | #define PROPERTY_TEXT_SMALL_CACHE_WIDTH "ro.hwui.text_small_cache_width" |
| 198 | #define PROPERTY_TEXT_SMALL_CACHE_HEIGHT "ro.hwui.text_small_cache_height" |
| 199 | #define PROPERTY_TEXT_LARGE_CACHE_WIDTH "ro.hwui.text_large_cache_width" |
| 200 | #define PROPERTY_TEXT_LARGE_CACHE_HEIGHT "ro.hwui.text_large_cache_height" |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 201 | |
Romain Guy | b45c0c9 | 2010-08-26 20:35:23 -0700 | [diff] [blame] | 202 | // Gamma (>= 1.0, <= 10.0) |
Romain Guy | 6e25e38 | 2012-07-18 15:50:29 -0700 | [diff] [blame] | 203 | #define PROPERTY_TEXT_GAMMA "hwui.text_gamma" |
Romain Guy | b45c0c9 | 2010-08-26 20:35:23 -0700 | [diff] [blame] | 204 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 205 | /////////////////////////////////////////////////////////////////////////////// |
| 206 | // Default property values |
| 207 | /////////////////////////////////////////////////////////////////////////////// |
Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 208 | |
Romain Guy | 09b7c91 | 2011-02-02 20:28:09 -0800 | [diff] [blame] | 209 | #define DEFAULT_TEXTURE_CACHE_SIZE 24.0f |
Romain Guy | 65b345f | 2011-07-27 18:51:50 -0700 | [diff] [blame] | 210 | #define DEFAULT_LAYER_CACHE_SIZE 16.0f |
Romain Guy | 8d4aeb7 | 2013-02-12 16:08:55 -0800 | [diff] [blame] | 211 | #define DEFAULT_RENDER_BUFFER_CACHE_SIZE 2.0f |
Chris Craik | 8d34aaf | 2015-05-11 19:18:11 -0700 | [diff] [blame] | 212 | #define DEFAULT_PATH_CACHE_SIZE 4.0f |
Chris Craik | 05f3d6e | 2014-06-02 16:27:04 -0700 | [diff] [blame] | 213 | #define DEFAULT_VERTEX_CACHE_SIZE 1.0f |
Chris Craik | 11718bc | 2015-09-22 11:50:13 -0700 | [diff] [blame] | 214 | #define DEFAULT_PATCH_CACHE_SIZE 128.0f // in kB |
Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 215 | #define DEFAULT_GRADIENT_CACHE_SIZE 0.5f |
| 216 | #define DEFAULT_DROP_SHADOW_CACHE_SIZE 2.0f |
John Reck | e9cd97e | 2014-09-17 14:09:26 -0700 | [diff] [blame] | 217 | #define DEFAULT_FBO_CACHE_SIZE 0 |
Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 218 | |
Romain Guy | eca0ca2 | 2011-11-04 15:12:29 -0700 | [diff] [blame] | 219 | #define DEFAULT_TEXTURE_CACHE_FLUSH_RATE 0.6f |
| 220 | |
Romain Guy | b45c0c9 | 2010-08-26 20:35:23 -0700 | [diff] [blame] | 221 | #define DEFAULT_TEXT_GAMMA 1.4f |
Romain Guy | b45c0c9 | 2010-08-26 20:35:23 -0700 | [diff] [blame] | 222 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 223 | /////////////////////////////////////////////////////////////////////////////// |
| 224 | // Misc |
| 225 | /////////////////////////////////////////////////////////////////////////////// |
| 226 | |
| 227 | // Converts a number of mega-bytes into bytes |
| 228 | #define MB(s) s * 1024 * 1024 |
Romain Guy | 3b748a4 | 2013-04-17 18:54:38 -0700 | [diff] [blame] | 229 | // Converts a number of kilo-bytes into bytes |
| 230 | #define KB(s) s * 1024 |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 231 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 232 | enum class ProfileType { |
| 233 | None, |
| 234 | Console, |
| 235 | Bars |
| 236 | }; |
| 237 | |
| 238 | enum class OverdrawColorSet { |
| 239 | Default = 0, |
| 240 | Deuteranomaly |
| 241 | }; |
| 242 | |
| 243 | enum class StencilClipDebug { |
| 244 | Hide, |
| 245 | ShowHighlight, |
| 246 | ShowRegion |
| 247 | }; |
| 248 | |
| 249 | /** |
| 250 | * Renderthread-only singleton which manages several static rendering properties. Most of these |
| 251 | * are driven by system properties which are queried once at initialization, and again if init() |
| 252 | * is called. |
| 253 | */ |
| 254 | class Properties { |
| 255 | public: |
| 256 | static bool load(); |
| 257 | |
| 258 | static bool drawDeferDisabled; |
| 259 | static bool drawReorderDisabled; |
| 260 | static bool debugLayersUpdates; |
| 261 | static bool debugOverdraw; |
| 262 | static bool showDirtyRegions; |
John Reck | d04794a | 2015-05-08 10:04:36 -0700 | [diff] [blame] | 263 | // TODO: Remove after stabilization period |
| 264 | static bool skipEmptyFrames; |
John Reck | 149173d | 2015-08-10 09:52:29 -0700 | [diff] [blame] | 265 | static bool useBufferAge; |
| 266 | static bool enablePartialUpdates; |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 267 | |
Chris Craik | c08820f | 2015-09-22 14:22:29 -0700 | [diff] [blame] | 268 | static float textGamma; |
| 269 | |
Chris Craik | 9fded23 | 2015-11-11 16:42:34 -0800 | [diff] [blame^] | 270 | static int layerPoolSize; |
| 271 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 272 | static DebugLevel debugLevel; |
| 273 | static OverdrawColorSet overdrawColorSet; |
| 274 | static StencilClipDebug debugStencilClip; |
| 275 | |
| 276 | // Override the value for a subset of properties in this class |
| 277 | static void overrideProperty(const char* name, const char* value); |
| 278 | |
| 279 | static float overrideLightRadius; |
| 280 | static float overrideLightPosY; |
| 281 | static float overrideLightPosZ; |
| 282 | static float overrideAmbientRatio; |
| 283 | static int overrideAmbientShadowStrength; |
| 284 | static int overrideSpotShadowStrength; |
| 285 | |
| 286 | static ProfileType getProfileType(); |
| 287 | |
| 288 | private: |
| 289 | static ProfileType sProfileType; |
| 290 | static bool sDisableProfileBars; |
| 291 | |
| 292 | }; // class Caches |
| 293 | |
| 294 | }; // namespace uirenderer |
| 295 | }; // namespace android |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 296 | |
Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 297 | #endif // ANDROID_HWUI_PROPERTIES_H |