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