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 | |
John Reck | 938e884 | 2017-08-24 13:41:59 -0700 | [diff] [blame] | 20 | #include <cutils/compiler.h> |
Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 21 | |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 22 | /** |
Chris Craik | 5e00c7c | 2016-07-06 16:10:09 -0700 | [diff] [blame] | 23 | * This file contains the list of system properties used to configure libhwui. |
Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 24 | */ |
| 25 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 26 | namespace android { |
| 27 | namespace uirenderer { |
| 28 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 29 | /////////////////////////////////////////////////////////////////////////////// |
| 30 | // Compile-time properties |
| 31 | /////////////////////////////////////////////////////////////////////////////// |
| 32 | |
Romain Guy | 28d8ff6 | 2011-08-22 14:01:34 -0700 | [diff] [blame] | 33 | // Textures used by layers must have dimensions multiples of this number |
| 34 | #define LAYER_SIZE 64 |
| 35 | |
Romain Guy | 8d4aeb7 | 2013-02-12 16:08:55 -0800 | [diff] [blame] | 36 | // Defines the size in bits of the stencil buffer for the framebuffer |
Romain Guy | ada4d53 | 2012-02-02 17:31:16 -0800 | [diff] [blame] | 37 | // 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] | 38 | // to properly implement overdraw debugging |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 39 | #define STENCIL_BUFFER_SIZE 8 |
Romain Guy | 530041d | 2012-01-25 18:56:29 -0800 | [diff] [blame] | 40 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 41 | /////////////////////////////////////////////////////////////////////////////// |
| 42 | // Debug properties |
| 43 | /////////////////////////////////////////////////////////////////////////////// |
| 44 | |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 45 | /** |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 46 | * Debug level for app developers. The value is a numeric value defined |
| 47 | * by the DebugLevel enum below. |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 48 | */ |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 49 | #define PROPERTY_DEBUG "debug.hwui.level" |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 50 | |
| 51 | /** |
| 52 | * Debug levels. Debug levels are used as flags. |
| 53 | */ |
| 54 | enum DebugLevel { |
| 55 | kDebugDisabled = 0, |
| 56 | kDebugMemory = 1, |
Romain Guy | 25dc3a7 | 2010-12-10 12:33:05 -0800 | [diff] [blame] | 57 | kDebugCaches = 2, |
Kenny Root | 042f7d6 | 2011-07-13 09:49:43 -0700 | [diff] [blame] | 58 | kDebugMoreCaches = kDebugMemory | kDebugCaches |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 59 | }; |
| 60 | |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 61 | /** |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 62 | * Used to enable/disable layers update debugging. The accepted values are |
Romain Guy | 4ff0cf4 | 2012-08-06 14:51:10 -0700 | [diff] [blame] | 63 | * "true" and "false". The default value is "false". |
| 64 | */ |
| 65 | #define PROPERTY_DEBUG_LAYERS_UPDATES "debug.hwui.show_layers_updates" |
| 66 | |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 67 | /** |
Romain Guy | 627c6fd | 2013-08-21 11:53:18 -0700 | [diff] [blame] | 68 | * Used to enable/disable overdraw debugging. |
| 69 | * |
| 70 | * The accepted values are |
| 71 | * "show", to show overdraw |
| 72 | * "show_deuteranomaly", to show overdraw if you suffer from Deuteranomaly |
| 73 | * "count", to show an overdraw counter |
| 74 | * "false", to disable overdraw debugging |
| 75 | * |
| 76 | * The default value is "false". |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 77 | */ |
Romain Guy | 78dd96d | 2013-05-03 14:24:16 -0700 | [diff] [blame] | 78 | #define PROPERTY_DEBUG_OVERDRAW "debug.hwui.overdraw" |
Romain Guy | 7c450aa | 2012-09-21 19:15:00 -0700 | [diff] [blame] | 79 | |
Romain Guy | 87e2f757 | 2012-09-24 11:37:12 -0700 | [diff] [blame] | 80 | /** |
John Reck | fe5e7b7 | 2014-05-23 17:42:28 -0700 | [diff] [blame] | 81 | * System property used to enable or disable hardware rendering profiling. |
| 82 | * The default value of this property is assumed to be false. |
| 83 | * |
| 84 | * When profiling is enabled, the adb shell dumpsys gfxinfo command will |
| 85 | * output extra information about the time taken to execute by the last |
| 86 | * frames. |
| 87 | * |
| 88 | * Possible values: |
| 89 | * "true", to enable profiling |
| 90 | * "visual_bars", to enable profiling and visualize the results on screen |
| 91 | * "false", to disable profiling |
| 92 | */ |
| 93 | #define PROPERTY_PROFILE "debug.hwui.profile" |
| 94 | #define PROPERTY_PROFILE_VISUALIZE_BARS "visual_bars" |
| 95 | |
| 96 | /** |
John Reck | 23d307c | 2014-10-27 12:38:48 -0700 | [diff] [blame] | 97 | * Turn on to draw dirty regions every other frame. |
| 98 | * |
| 99 | * Possible values: |
| 100 | * "true", to enable dirty regions debugging |
| 101 | * "false", to disable dirty regions debugging |
| 102 | */ |
| 103 | #define PROPERTY_DEBUG_SHOW_DIRTY_REGIONS "debug.hwui.show_dirty_regions" |
| 104 | |
| 105 | /** |
John Reck | d04794a | 2015-05-08 10:04:36 -0700 | [diff] [blame] | 106 | * Setting this property will enable or disable the dropping of frames with |
| 107 | * empty damage. Default is "true". |
| 108 | */ |
| 109 | #define PROPERTY_SKIP_EMPTY_DAMAGE "debug.hwui.skip_empty_damage" |
| 110 | |
| 111 | /** |
John Reck | 149173d | 2015-08-10 09:52:29 -0700 | [diff] [blame] | 112 | * Controls whether or not HWUI will use the EGL_EXT_buffer_age extension |
| 113 | * to do partial invalidates. Setting this to "false" will fall back to |
| 114 | * using BUFFER_PRESERVED instead |
| 115 | * Default is "true" |
| 116 | */ |
| 117 | #define PROPERTY_USE_BUFFER_AGE "debug.hwui.use_buffer_age" |
| 118 | |
| 119 | /** |
| 120 | * Setting this to "false" will force HWUI to always do full-redraws of the surface. |
| 121 | * This will disable the use of EGL_EXT_buffer_age and BUFFER_PRESERVED. |
| 122 | * Default is "true" |
| 123 | */ |
ryang | 647bc13 | 2016-09-26 15:57:38 -0400 | [diff] [blame] | 124 | #define PROPERTY_ENABLE_PARTIAL_UPDATES "debug.hwui.use_partial_updates" |
John Reck | 149173d | 2015-08-10 09:52:29 -0700 | [diff] [blame] | 125 | |
John Reck | c7cd9cf | 2016-03-28 10:38:19 -0700 | [diff] [blame] | 126 | #define PROPERTY_FILTER_TEST_OVERHEAD "debug.hwui.filter_test_overhead" |
| 127 | |
Stan Iliev | 03de074 | 2016-07-07 12:35:54 -0400 | [diff] [blame] | 128 | /** |
John Reck | 8dc02f9 | 2017-07-17 09:55:02 -0700 | [diff] [blame] | 129 | * Indicates whether PBOs can be used to back pixel buffers. |
| 130 | * Accepted values are "true" and "false". Default is true. |
| 131 | */ |
| 132 | #define PROPERTY_ENABLE_GPU_PIXEL_BUFFERS "debug.hwui.use_gpu_pixel_buffers" |
| 133 | |
| 134 | /** |
Stan Iliev | 03de074 | 2016-07-07 12:35:54 -0400 | [diff] [blame] | 135 | * Allows to set rendering pipeline mode to OpenGL (default), Skia OpenGL |
| 136 | * or Vulkan. |
| 137 | */ |
Derek Sollenberger | 4badfe6 | 2017-02-14 11:38:06 -0500 | [diff] [blame] | 138 | #define PROPERTY_RENDERER "debug.hwui.renderer" |
Stan Iliev | 03de074 | 2016-07-07 12:35:54 -0400 | [diff] [blame] | 139 | |
Stan Iliev | e9d0012 | 2017-09-19 12:07:10 -0400 | [diff] [blame] | 140 | /** |
| 141 | * Allows to collect a recording of Skia drawing commands. |
| 142 | */ |
| 143 | #define PROPERTY_CAPTURE_SKP_ENABLED "debug.hwui.capture_skp_enabled" |
| 144 | |
Stan Iliev | e9d0012 | 2017-09-19 12:07:10 -0400 | [diff] [blame] | 145 | /** |
Stan Iliev | 02daab6 | 2018-06-29 15:16:11 -0400 | [diff] [blame] | 146 | * Allows to record Skia drawing commands with systrace. |
| 147 | */ |
| 148 | #define PROPERTY_SKIA_ATRACE_ENABLED "debug.hwui.skia_atrace_enabled" |
| 149 | |
| 150 | /** |
Stan Iliev | e9d0012 | 2017-09-19 12:07:10 -0400 | [diff] [blame] | 151 | * Defines how many frames in a sequence to capture. |
| 152 | */ |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 153 | #define PROPERTY_CAPTURE_SKP_FRAMES "debug.hwui.capture_skp_frames" |
Stan Iliev | e9d0012 | 2017-09-19 12:07:10 -0400 | [diff] [blame] | 154 | |
| 155 | /** |
| 156 | * File name and location, where a SKP recording will be saved. |
| 157 | */ |
| 158 | #define PROPERTY_CAPTURE_SKP_FILENAME "debug.hwui.skp_filename" |
| 159 | |
Lingfeng Yang | 3a9f223 | 2018-01-24 10:40:18 -0800 | [diff] [blame] | 160 | /** |
| 161 | * Property for whether this is running in the emulator. |
| 162 | */ |
Roman Kiryanov | d6a9f425 | 2021-03-10 16:57:41 -0800 | [diff] [blame] | 163 | #define PROPERTY_IS_EMULATOR "ro.boot.qemu" |
Lingfeng Yang | 3a9f223 | 2018-01-24 10:40:18 -0800 | [diff] [blame] | 164 | |
Adlai Holler | 5636cde | 2021-03-25 16:53:56 +0000 | [diff] [blame] | 165 | /** |
| 166 | * Turns on the Skia GPU option "reduceOpsTaskSplitting" which improves GPU |
| 167 | * efficiency but may increase VRAM consumption. Default is "false". |
| 168 | */ |
| 169 | #define PROPERTY_REDUCE_OPS_TASK_SPLITTING "renderthread.skia.reduceopstasksplitting" |
| 170 | |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 171 | /////////////////////////////////////////////////////////////////////////////// |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 172 | // Misc |
| 173 | /////////////////////////////////////////////////////////////////////////////// |
| 174 | |
| 175 | // Converts a number of mega-bytes into bytes |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 176 | #define MB(s) ((s)*1024 * 1024) |
Romain Guy | 3b748a4 | 2013-04-17 18:54:38 -0700 | [diff] [blame] | 177 | // Converts a number of kilo-bytes into bytes |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 178 | #define KB(s) ((s)*1024) |
Romain Guy | cf51a41 | 2013-04-08 19:40:31 -0700 | [diff] [blame] | 179 | |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 180 | enum class ProfileType { None, Console, Bars }; |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 181 | |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 182 | enum class OverdrawColorSet { Default = 0, Deuteranomaly }; |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 183 | |
John Reck | 18f442e | 2018-04-09 16:56:34 -0700 | [diff] [blame] | 184 | enum class RenderPipelineType { SkiaGL, SkiaVulkan, NotInitialized = 128 }; |
Stan Iliev | 03de074 | 2016-07-07 12:35:54 -0400 | [diff] [blame] | 185 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 186 | /** |
| 187 | * Renderthread-only singleton which manages several static rendering properties. Most of these |
| 188 | * are driven by system properties which are queried once at initialization, and again if init() |
| 189 | * is called. |
| 190 | */ |
| 191 | class Properties { |
| 192 | public: |
| 193 | static bool load(); |
| 194 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 195 | static bool debugLayersUpdates; |
| 196 | static bool debugOverdraw; |
| 197 | static bool showDirtyRegions; |
John Reck | d04794a | 2015-05-08 10:04:36 -0700 | [diff] [blame] | 198 | // TODO: Remove after stabilization period |
| 199 | static bool skipEmptyFrames; |
John Reck | 149173d | 2015-08-10 09:52:29 -0700 | [diff] [blame] | 200 | static bool useBufferAge; |
| 201 | static bool enablePartialUpdates; |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 202 | |
John Reck | 8dc02f9 | 2017-07-17 09:55:02 -0700 | [diff] [blame] | 203 | // TODO: Move somewhere else? |
| 204 | static constexpr float textGamma = 1.45f; |
Chris Craik | 9fded23 | 2015-11-11 16:42:34 -0800 | [diff] [blame] | 205 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 206 | static DebugLevel debugLevel; |
| 207 | static OverdrawColorSet overdrawColorSet; |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 208 | |
| 209 | // Override the value for a subset of properties in this class |
| 210 | static void overrideProperty(const char* name, const char* value); |
| 211 | |
| 212 | static float overrideLightRadius; |
| 213 | static float overrideLightPosY; |
| 214 | static float overrideLightPosZ; |
| 215 | static float overrideAmbientRatio; |
| 216 | static int overrideAmbientShadowStrength; |
| 217 | static int overrideSpotShadowStrength; |
| 218 | |
| 219 | static ProfileType getProfileType(); |
Derek Sollenberger | 3fedf5a | 2020-02-21 13:07:28 -0500 | [diff] [blame] | 220 | static RenderPipelineType peekRenderPipelineType(); |
| 221 | static RenderPipelineType getRenderPipelineType(); |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 222 | |
Derek Sollenberger | 3fedf5a | 2020-02-21 13:07:28 -0500 | [diff] [blame] | 223 | static bool enableHighContrastText; |
John Reck | 938e884 | 2017-08-24 13:41:59 -0700 | [diff] [blame] | 224 | |
John Reck | 682573c | 2015-10-30 10:37:35 -0700 | [diff] [blame] | 225 | // Should be used only by test apps |
| 226 | static bool waitForGpuCompletion; |
John Reck | f148076 | 2016-07-03 18:28:25 -0700 | [diff] [blame] | 227 | static bool forceDrawFrame; |
John Reck | 682573c | 2015-10-30 10:37:35 -0700 | [diff] [blame] | 228 | |
John Reck | c7cd9cf | 2016-03-28 10:38:19 -0700 | [diff] [blame] | 229 | // Should only be set by automated tests to try and filter out |
| 230 | // any overhead they add |
| 231 | static bool filterOutTestOverhead; |
| 232 | |
John Reck | a896306 | 2017-06-14 10:47:50 -0700 | [diff] [blame] | 233 | // Workaround a device lockup in edge cases by switching to async mode |
| 234 | // instead of the default vsync (b/38372997). Only system_server should hit this. |
| 235 | // Any existing RenderProxy & Surface combination will be unaffected, only things |
| 236 | // created after changing this. |
| 237 | static bool disableVsync; |
| 238 | |
Stan Iliev | e9d0012 | 2017-09-19 12:07:10 -0400 | [diff] [blame] | 239 | static bool skpCaptureEnabled; |
| 240 | |
John Reck | 9f51644 | 2017-09-25 10:27:21 -0700 | [diff] [blame] | 241 | // For experimentation b/68769804 |
Derek Sollenberger | 3fedf5a | 2020-02-21 13:07:28 -0500 | [diff] [blame] | 242 | static bool enableRTAnimations; |
John Reck | 9f51644 | 2017-09-25 10:27:21 -0700 | [diff] [blame] | 243 | |
John Reck | 113ddd9 | 2017-11-09 16:21:21 -0800 | [diff] [blame] | 244 | // Used for testing only to change the render pipeline. |
Alec Mouri | aa3e498 | 2020-12-14 14:47:57 -0800 | [diff] [blame] | 245 | static void overrideRenderPipelineType(RenderPipelineType, bool inUnitTest = false); |
Greg Daniel | 98c78da | 2017-01-04 14:45:56 -0500 | [diff] [blame] | 246 | |
Lingfeng Yang | 3a9f223 | 2018-01-24 10:40:18 -0800 | [diff] [blame] | 247 | static bool runningInEmulator; |
| 248 | |
Derek Sollenberger | 3fedf5a | 2020-02-21 13:07:28 -0500 | [diff] [blame] | 249 | static bool debuggingEnabled; |
| 250 | static bool isolatedProcess; |
John Reck | 6afa009 | 2018-03-01 17:28:35 -0800 | [diff] [blame] | 251 | |
Derek Sollenberger | 3fedf5a | 2020-02-21 13:07:28 -0500 | [diff] [blame] | 252 | static int contextPriority; |
Jorim Jaggi | 767e25e | 2018-04-04 23:07:35 +0200 | [diff] [blame] | 253 | |
John Reck | f42ff76 | 2020-08-06 13:53:22 -0700 | [diff] [blame] | 254 | static float defaultSdrWhitePoint; |
| 255 | |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 256 | private: |
| 257 | static ProfileType sProfileType; |
| 258 | static bool sDisableProfileBars; |
Stan Iliev | 03de074 | 2016-07-07 12:35:54 -0400 | [diff] [blame] | 259 | static RenderPipelineType sRenderPipelineType; |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 260 | }; // class Caches |
Chris Craik | 2507c34 | 2015-05-04 14:36:49 -0700 | [diff] [blame] | 261 | |
Chris Blume | 7b8a808 | 2018-11-30 15:51:58 -0800 | [diff] [blame] | 262 | } // namespace uirenderer |
| 263 | } // namespace android |
Romain Guy | e190aa6 | 2010-11-10 19:01:29 -0800 | [diff] [blame] | 264 | |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 265 | #endif // ANDROID_HWUI_PROPERTIES_H |