blob: 4216771515e7cb9ba53db8346f638a4dbae0290d [file] [log] [blame]
rnlee81d32602021-07-27 13:24:07 -07001/*
2 * Copyright (C) 2021 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
Alec Mouri9b133ca2023-11-14 19:00:01 +000017#include <common/FlagManager.h>
rnlee81d32602021-07-27 13:24:07 -070018
19#include <SurfaceFlingerProperties.sysprop.h>
20#include <android-base/parsebool.h>
21#include <android-base/parseint.h>
Leon Scroggins IIIa37ca992022-02-02 18:08:20 -050022#include <android-base/properties.h>
rnlee81d32602021-07-27 13:24:07 -070023#include <android-base/stringprintf.h>
24#include <log/log.h>
Leon Scroggins IIIa37ca992022-02-02 18:08:20 -050025#include <renderengine/RenderEngine.h>
rnlee81d32602021-07-27 13:24:07 -070026#include <server_configurable_flags/get_flags.h>
27#include <cinttypes>
28
Matt Buckleyffc31d12024-02-28 16:51:28 +000029#include <android_os.h>
Ady Abrahamd6d80162023-10-23 12:57:41 -070030#include <com_android_graphics_surfaceflinger_flags.h>
Ady Abraham354ccde2024-03-21 10:40:28 -070031#include <com_android_server_display_feature_flags.h>
Ady Abrahamd6d80162023-10-23 12:57:41 -070032
rnlee81d32602021-07-27 13:24:07 -070033namespace android {
Ady Abrahamd6d80162023-10-23 12:57:41 -070034using namespace com::android::graphics::surfaceflinger;
35
rnlee81d32602021-07-27 13:24:07 -070036static constexpr const char* kExperimentNamespace = "surface_flinger_native_boot";
rnlee81d32602021-07-27 13:24:07 -070037
Ady Abraham53b0c492023-10-23 11:47:14 -070038std::unique_ptr<FlagManager> FlagManager::mInstance;
39std::once_flag FlagManager::mOnce;
40
41FlagManager::FlagManager(ConstructorTag) {}
rnlee81d32602021-07-27 13:24:07 -070042FlagManager::~FlagManager() = default;
43
rnlee81d32602021-07-27 13:24:07 -070044namespace {
Ady Abrahamc589dc42023-10-26 16:20:53 -070045std::optional<bool> parseBool(const char* str) {
rnlee81d32602021-07-27 13:24:07 -070046 base::ParseBoolResult parseResult = base::ParseBool(str);
47 switch (parseResult) {
48 case base::ParseBoolResult::kTrue:
49 return std::make_optional(true);
50 case base::ParseBoolResult::kFalse:
51 return std::make_optional(false);
52 case base::ParseBoolResult::kError:
53 return std::nullopt;
54 }
55}
Ady Abrahamc589dc42023-10-26 16:20:53 -070056
Ady Abrahamd6d80162023-10-23 12:57:41 -070057bool getFlagValue(std::function<bool()> getter, std::optional<bool> overrideValue) {
58 if (overrideValue.has_value()) {
59 return *overrideValue;
60 }
61
62 return getter();
63}
64
rnlee81d32602021-07-27 13:24:07 -070065} // namespace
66
Ady Abrahamc589dc42023-10-26 16:20:53 -070067const FlagManager& FlagManager::getInstance() {
68 return getMutableInstance();
rnlee81d32602021-07-27 13:24:07 -070069}
70
Ady Abrahamc589dc42023-10-26 16:20:53 -070071FlagManager& FlagManager::getMutableInstance() {
72 std::call_once(mOnce, [&] {
73 LOG_ALWAYS_FATAL_IF(mInstance, "Instance already created");
74 mInstance = std::make_unique<FlagManager>(ConstructorTag{});
75 });
76
77 return *mInstance;
78}
79
80void FlagManager::markBootCompleted() {
81 mBootCompleted = true;
82}
83
Ady Abrahamd6d80162023-10-23 12:57:41 -070084void FlagManager::setUnitTestMode() {
85 mUnitTestMode = true;
86
87 // Also set boot completed as we don't really care about it in unit testing
88 mBootCompleted = true;
89}
90
Ady Abrahamb6041f62023-11-03 12:14:26 -070091void FlagManager::dumpFlag(std::string& result, bool readonly, const char* name,
92 std::function<bool()> getter) const {
93 if (readonly || mBootCompleted) {
94 base::StringAppendF(&result, "%s: %s\n", name, getter() ? "true" : "false");
95 } else {
96 base::StringAppendF(&result, "%s: in progress (still booting)\n", name);
97 }
98}
99
Ady Abrahamc589dc42023-10-26 16:20:53 -0700100void FlagManager::dump(std::string& result) const {
Ady Abrahamb6041f62023-11-03 12:14:26 -0700101#define DUMP_FLAG_INTERVAL(name, readonly) \
102 dumpFlag(result, (readonly), #name, std::bind(&FlagManager::name, this))
103#define DUMP_SERVER_FLAG(name) DUMP_FLAG_INTERVAL(name, false)
104#define DUMP_READ_ONLY_FLAG(name) DUMP_FLAG_INTERVAL(name, true)
Ady Abrahamc589dc42023-10-26 16:20:53 -0700105
106 base::StringAppendF(&result, "FlagManager values: \n");
Ady Abrahamc589dc42023-10-26 16:20:53 -0700107
Ady Abrahamb6041f62023-11-03 12:14:26 -0700108 /// Legacy server flags ///
109 DUMP_SERVER_FLAG(use_adpf_cpu_hint);
110 DUMP_SERVER_FLAG(use_skia_tracing);
111
112 /// Trunk stable server flags ///
Sally Qide329f22023-09-26 16:21:39 -0700113 DUMP_SERVER_FLAG(refresh_rate_overlay_on_external_display);
Xiang Wang05cb7642024-03-12 17:27:05 -0700114 DUMP_SERVER_FLAG(adpf_gpu_sf);
Matt Buckleyffc31d12024-02-28 16:51:28 +0000115 DUMP_SERVER_FLAG(adpf_use_fmq_channel);
Ady Abrahamb6041f62023-11-03 12:14:26 -0700116
117 /// Trunk stable readonly flags ///
118 DUMP_READ_ONLY_FLAG(connected_display);
119 DUMP_READ_ONLY_FLAG(enable_small_area_detection);
Rachel Lee52f0abe2024-03-14 18:34:04 -0700120 DUMP_READ_ONLY_FLAG(frame_rate_category_mrr);
Ady Abrahamb6041f62023-11-03 12:14:26 -0700121 DUMP_READ_ONLY_FLAG(misc1);
122 DUMP_READ_ONLY_FLAG(vrr_config);
123 DUMP_READ_ONLY_FLAG(hotplug2);
124 DUMP_READ_ONLY_FLAG(hdcp_level_hal);
125 DUMP_READ_ONLY_FLAG(multithreaded_present);
Sally Qif5721252023-11-17 11:14:53 -0800126 DUMP_READ_ONLY_FLAG(add_sf_skipped_frames_to_trace);
Jerry Chang04eb8e02023-11-15 08:06:07 +0000127 DUMP_READ_ONLY_FLAG(use_known_refresh_rate_for_fps_consistency);
Sally Qi4e20d7b2023-12-18 18:23:51 -0800128 DUMP_READ_ONLY_FLAG(cache_when_source_crop_layer_only_moved);
Ady Abraham3f84c502023-11-30 18:18:06 -0800129 DUMP_READ_ONLY_FLAG(enable_fro_dependent_features);
Chavi Weingarten18fa7c62023-11-28 21:16:03 +0000130 DUMP_READ_ONLY_FLAG(display_protected);
Alec Mourif97df4d2023-09-06 02:10:05 +0000131 DUMP_READ_ONLY_FLAG(fp16_client_target);
Andy Yu8c2703d2023-11-03 11:22:46 -0700132 DUMP_READ_ONLY_FLAG(game_default_frame_rate);
Manali Bhutiyani96f866c2023-11-09 18:09:44 +0000133 DUMP_READ_ONLY_FLAG(enable_layer_command_batching);
Alec Mouri9892aac2023-12-11 21:16:59 +0000134 DUMP_READ_ONLY_FLAG(screenshot_fence_preservation);
Leon Scroggins III696bf932024-01-24 15:21:05 -0500135 DUMP_READ_ONLY_FLAG(vulkan_renderengine);
Leon Scroggins IIIdf8166e2024-01-25 15:50:56 -0500136 DUMP_READ_ONLY_FLAG(renderable_buffer_usage);
Vishnu Nairdf59f472024-05-17 16:51:33 +0000137 DUMP_READ_ONLY_FLAG(vrr_bugfix_24q4);
Leon Scroggins III48a60cc2024-01-31 12:41:33 -0500138 DUMP_READ_ONLY_FLAG(restore_blur_step);
Ady Abrahambf554892024-02-14 18:18:21 +0000139 DUMP_READ_ONLY_FLAG(dont_skip_on_early_ro);
Eason Chiu45099662023-10-23 08:55:48 +0800140 DUMP_READ_ONLY_FLAG(protected_if_client);
Melody Hsu793f8362024-01-08 20:00:35 +0000141 DUMP_READ_ONLY_FLAG(ce_fence_promise);
Ady Abraham354ccde2024-03-21 10:40:28 -0700142 DUMP_READ_ONLY_FLAG(idle_screen_refresh_rate_timeout);
Nolan Scobie576e77f2024-03-26 10:59:59 -0400143 DUMP_READ_ONLY_FLAG(graphite_renderengine);
Ady Abrahambb1ad762024-03-27 18:31:28 -0700144 DUMP_READ_ONLY_FLAG(latch_unsignaled_with_auto_refresh_changed);
Ady Abrahamb3347582024-04-03 01:01:51 +0000145 DUMP_READ_ONLY_FLAG(deprecate_vsync_sf);
ramindani8470d762024-04-10 15:18:43 -0700146 DUMP_READ_ONLY_FLAG(allow_n_vsyncs_in_targeter);
Vishnu Nair491827d2024-04-29 23:43:26 +0000147 DUMP_READ_ONLY_FLAG(detached_mirror);
Ady Abraham14beed72024-05-15 17:16:45 -0700148 DUMP_READ_ONLY_FLAG(commit_not_composited);
Alec Mouri1818c182024-05-13 18:25:11 +0000149 DUMP_READ_ONLY_FLAG(local_tonemap_screenshots);
Vishnu Nair9e0017e2024-05-22 19:02:44 +0000150 DUMP_READ_ONLY_FLAG(override_trusted_overlay);
Leon Scroggins IIIa3ba7fa2024-05-22 16:34:52 -0400151 DUMP_READ_ONLY_FLAG(flush_buffer_slots_to_uncache);
Nolan Scobie4a466642024-05-23 16:22:22 -0400152 DUMP_READ_ONLY_FLAG(force_compile_graphite_renderengine);
Melody Hsu8c42cf12024-06-05 00:07:03 +0000153 DUMP_READ_ONLY_FLAG(single_hop_screenshot);
Ady Abrahambb1ad762024-03-27 18:31:28 -0700154
Ady Abrahamb6041f62023-11-03 12:14:26 -0700155#undef DUMP_READ_ONLY_FLAG
156#undef DUMP_SERVER_FLAG
157#undef DUMP_FLAG_INTERVAL
Ady Abrahamc589dc42023-10-26 16:20:53 -0700158}
159
160std::optional<bool> FlagManager::getBoolProperty(const char* property) const {
161 return parseBool(base::GetProperty(property, "").c_str());
162}
163
164bool FlagManager::getServerConfigurableFlag(const char* experimentFlagName) const {
165 const auto value = server_configurable_flags::GetServerConfigurableFlag(kExperimentNamespace,
166 experimentFlagName, "");
167 const auto res = parseBool(value.c_str());
168 return res.has_value() && res.value();
169}
170
Ady Abrahamd6d80162023-10-23 12:57:41 -0700171#define FLAG_MANAGER_LEGACY_SERVER_FLAG(name, syspropOverride, serverFlagName) \
Ady Abrahamc589dc42023-10-26 16:20:53 -0700172 bool FlagManager::name() const { \
173 LOG_ALWAYS_FATAL_IF(!mBootCompleted, \
174 "Can't read %s before boot completed as it is server writable", \
175 __func__); \
176 const auto debugOverride = getBoolProperty(syspropOverride); \
177 if (debugOverride.has_value()) return debugOverride.value(); \
178 return getServerConfigurableFlag(serverFlagName); \
rnlee81d32602021-07-27 13:24:07 -0700179 }
rnlee81d32602021-07-27 13:24:07 -0700180
Matt Buckleyffc31d12024-02-28 16:51:28 +0000181#define FLAG_MANAGER_FLAG_INTERNAL(name, syspropOverride, checkForBootCompleted, owner) \
Ady Abrahamd6d80162023-10-23 12:57:41 -0700182 bool FlagManager::name() const { \
183 if (checkForBootCompleted) { \
184 LOG_ALWAYS_FATAL_IF(!mBootCompleted, \
185 "Can't read %s before boot completed as it is server writable", \
186 __func__); \
187 } \
Leon Scroggins IIId8e36f32023-11-22 14:40:36 -0500188 static const std::optional<bool> debugOverride = getBoolProperty(syspropOverride); \
Matt Buckleyffc31d12024-02-28 16:51:28 +0000189 static const bool value = getFlagValue([] { return owner ::name(); }, debugOverride); \
Ady Abrahamd6d80162023-10-23 12:57:41 -0700190 if (mUnitTestMode) { \
191 /* \
Leon Scroggins IIId8e36f32023-11-22 14:40:36 -0500192 * When testing, we don't want to rely on the cached `value` or the debugOverride. \
Ady Abrahamd6d80162023-10-23 12:57:41 -0700193 */ \
Matt Buckleyffc31d12024-02-28 16:51:28 +0000194 return owner ::name(); \
Ady Abrahamd6d80162023-10-23 12:57:41 -0700195 } \
196 return value; \
197 }
Matt Buckleyd23c7962021-09-21 20:43:00 +0000198
Ady Abrahamd6d80162023-10-23 12:57:41 -0700199#define FLAG_MANAGER_SERVER_FLAG(name, syspropOverride) \
Matt Buckleyffc31d12024-02-28 16:51:28 +0000200 FLAG_MANAGER_FLAG_INTERNAL(name, syspropOverride, true, flags)
Ady Abrahamd6d80162023-10-23 12:57:41 -0700201
202#define FLAG_MANAGER_READ_ONLY_FLAG(name, syspropOverride) \
Matt Buckleyffc31d12024-02-28 16:51:28 +0000203 FLAG_MANAGER_FLAG_INTERNAL(name, syspropOverride, false, flags)
204
205#define FLAG_MANAGER_SERVER_FLAG_IMPORTED(name, syspropOverride, owner) \
206 FLAG_MANAGER_FLAG_INTERNAL(name, syspropOverride, true, owner)
Ady Abrahamd6d80162023-10-23 12:57:41 -0700207
Ady Abraham354ccde2024-03-21 10:40:28 -0700208#define FLAG_MANAGER_READ_ONLY_FLAG_IMPORTED(name, syspropOverride, owner) \
209 FLAG_MANAGER_FLAG_INTERNAL(name, syspropOverride, false, owner)
210
Ady Abrahamd6d80162023-10-23 12:57:41 -0700211/// Legacy server flags ///
212FLAG_MANAGER_LEGACY_SERVER_FLAG(test_flag, "", "")
213FLAG_MANAGER_LEGACY_SERVER_FLAG(use_adpf_cpu_hint, "debug.sf.enable_adpf_cpu_hint",
214 "AdpfFeature__adpf_cpu_hint")
215FLAG_MANAGER_LEGACY_SERVER_FLAG(use_skia_tracing, PROPERTY_SKIA_ATRACE_ENABLED,
216 "SkiaTracingFeature__use_skia_tracing")
217
218/// Trunk stable readonly flags ///
219FLAG_MANAGER_READ_ONLY_FLAG(connected_display, "")
220FLAG_MANAGER_READ_ONLY_FLAG(enable_small_area_detection, "")
Rachel Lee52f0abe2024-03-14 18:34:04 -0700221FLAG_MANAGER_READ_ONLY_FLAG(frame_rate_category_mrr, "debug.sf.frame_rate_category_mrr")
Ady Abrahamd6d80162023-10-23 12:57:41 -0700222FLAG_MANAGER_READ_ONLY_FLAG(misc1, "")
223FLAG_MANAGER_READ_ONLY_FLAG(vrr_config, "debug.sf.enable_vrr_config")
Brian Johnson8c144002023-10-30 15:47:44 -0700224FLAG_MANAGER_READ_ONLY_FLAG(hotplug2, "")
Brian Johnson4f095462023-10-31 10:12:55 -0700225FLAG_MANAGER_READ_ONLY_FLAG(hdcp_level_hal, "")
Leon Scroggins IIIb315af52023-11-02 10:03:23 -0400226FLAG_MANAGER_READ_ONLY_FLAG(multithreaded_present, "debug.sf.multithreaded_present")
Sally Qif5721252023-11-17 11:14:53 -0800227FLAG_MANAGER_READ_ONLY_FLAG(add_sf_skipped_frames_to_trace, "")
Jerry Chang04eb8e02023-11-15 08:06:07 +0000228FLAG_MANAGER_READ_ONLY_FLAG(use_known_refresh_rate_for_fps_consistency, "")
Sally Qi4e20d7b2023-12-18 18:23:51 -0800229FLAG_MANAGER_READ_ONLY_FLAG(cache_when_source_crop_layer_only_moved,
Sally Qi567cf842023-11-14 15:25:29 -0800230 "debug.sf.cache_source_crop_only_moved")
Ady Abraham3f84c502023-11-30 18:18:06 -0800231FLAG_MANAGER_READ_ONLY_FLAG(enable_fro_dependent_features, "")
Chavi Weingarten18fa7c62023-11-28 21:16:03 +0000232FLAG_MANAGER_READ_ONLY_FLAG(display_protected, "")
Alec Mourif97df4d2023-09-06 02:10:05 +0000233FLAG_MANAGER_READ_ONLY_FLAG(fp16_client_target, "debug.sf.fp16_client_target")
Andy Yu8c2703d2023-11-03 11:22:46 -0700234FLAG_MANAGER_READ_ONLY_FLAG(game_default_frame_rate, "")
Manali Bhutiyani71fa6fd2024-03-15 19:32:20 +0000235FLAG_MANAGER_READ_ONLY_FLAG(enable_layer_command_batching, "debug.sf.enable_layer_command_batching")
Alec Mouri9892aac2023-12-11 21:16:59 +0000236FLAG_MANAGER_READ_ONLY_FLAG(screenshot_fence_preservation, "debug.sf.screenshot_fence_preservation")
Leon Scroggins III696bf932024-01-24 15:21:05 -0500237FLAG_MANAGER_READ_ONLY_FLAG(vulkan_renderengine, "debug.renderengine.vulkan")
Leon Scroggins IIIdf8166e2024-01-25 15:50:56 -0500238FLAG_MANAGER_READ_ONLY_FLAG(renderable_buffer_usage, "")
Leon Scroggins III48a60cc2024-01-31 12:41:33 -0500239FLAG_MANAGER_READ_ONLY_FLAG(restore_blur_step, "debug.renderengine.restore_blur_step")
Ady Abrahambf554892024-02-14 18:18:21 +0000240FLAG_MANAGER_READ_ONLY_FLAG(dont_skip_on_early_ro, "")
Eason Chiu45099662023-10-23 08:55:48 +0800241FLAG_MANAGER_READ_ONLY_FLAG(protected_if_client, "")
Vishnu Nairdf59f472024-05-17 16:51:33 +0000242FLAG_MANAGER_READ_ONLY_FLAG(vrr_bugfix_24q4, "");
Melody Hsu793f8362024-01-08 20:00:35 +0000243FLAG_MANAGER_READ_ONLY_FLAG(ce_fence_promise, "");
Nolan Scobie576e77f2024-03-26 10:59:59 -0400244FLAG_MANAGER_READ_ONLY_FLAG(graphite_renderengine, "debug.renderengine.graphite")
Ady Abrahambb1ad762024-03-27 18:31:28 -0700245FLAG_MANAGER_READ_ONLY_FLAG(latch_unsignaled_with_auto_refresh_changed, "");
Ady Abrahamb3347582024-04-03 01:01:51 +0000246FLAG_MANAGER_READ_ONLY_FLAG(deprecate_vsync_sf, "");
ramindani8470d762024-04-10 15:18:43 -0700247FLAG_MANAGER_READ_ONLY_FLAG(allow_n_vsyncs_in_targeter, "");
Vishnu Nair491827d2024-04-29 23:43:26 +0000248FLAG_MANAGER_READ_ONLY_FLAG(detached_mirror, "");
Ady Abraham14beed72024-05-15 17:16:45 -0700249FLAG_MANAGER_READ_ONLY_FLAG(commit_not_composited, "");
Alec Mouri1818c182024-05-13 18:25:11 +0000250FLAG_MANAGER_READ_ONLY_FLAG(local_tonemap_screenshots, "debug.sf.local_tonemap_screenshots");
Vishnu Nair9e0017e2024-05-22 19:02:44 +0000251FLAG_MANAGER_READ_ONLY_FLAG(override_trusted_overlay, "");
Leon Scroggins IIIa3ba7fa2024-05-22 16:34:52 -0400252FLAG_MANAGER_READ_ONLY_FLAG(flush_buffer_slots_to_uncache, "");
Nolan Scobie4a466642024-05-23 16:22:22 -0400253FLAG_MANAGER_READ_ONLY_FLAG(force_compile_graphite_renderengine, "");
Melody Hsu8c42cf12024-06-05 00:07:03 +0000254FLAG_MANAGER_READ_ONLY_FLAG(single_hop_screenshot, "");
Ady Abrahamd6d80162023-10-23 12:57:41 -0700255
256/// Trunk stable server flags ///
Sally Qide329f22023-09-26 16:21:39 -0700257FLAG_MANAGER_SERVER_FLAG(refresh_rate_overlay_on_external_display, "")
Xiang Wang05cb7642024-03-12 17:27:05 -0700258FLAG_MANAGER_SERVER_FLAG(adpf_gpu_sf, "")
Ady Abrahamd6d80162023-10-23 12:57:41 -0700259
Matt Buckleyffc31d12024-02-28 16:51:28 +0000260/// Trunk stable server flags from outside SurfaceFlinger ///
261FLAG_MANAGER_SERVER_FLAG_IMPORTED(adpf_use_fmq_channel, "", android::os)
262
Ady Abraham354ccde2024-03-21 10:40:28 -0700263/// Trunk stable readonly flags from outside SurfaceFlinger ///
264FLAG_MANAGER_READ_ONLY_FLAG_IMPORTED(idle_screen_refresh_rate_timeout, "",
265 com::android::server::display::feature::flags)
Xiang Wang154fc042024-04-02 14:17:53 -0700266FLAG_MANAGER_READ_ONLY_FLAG_IMPORTED(adpf_use_fmq_channel_fixed, "", android::os)
Ady Abraham354ccde2024-03-21 10:40:28 -0700267
rnlee81d32602021-07-27 13:24:07 -0700268} // namespace android