Merge "[MTE] add device config for permissive mode" am: 0b2cf1d6ec am: 87fa70eee3

Original change: https://android-review.googlesource.com/c/platform/system/core/+/2219637

Change-Id: I502104387cb8697b4be9386604055771b18364d0
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
Florian Mayer 2022-10-03 22:05:41 +00:00 committed by Automerger Merge Worker
commit f631982e65

View file

@ -103,9 +103,15 @@ static bool property_parse_bool(const char* name) {
static bool is_permissive_mte() {
// Environment variable for testing or local use from shell.
char* permissive_env = getenv("MTE_PERMISSIVE");
char process_sysprop_name[512];
async_safe_format_buffer(process_sysprop_name, sizeof(process_sysprop_name),
"persist.device_config.memory_safety_native.permissive.process.%s",
getprogname());
// DO NOT REPLACE this with GetBoolProperty. That uses std::string which allocates, so it is
// not async-safe (and this functiong gets used in a signal handler).
return property_parse_bool("persist.sys.mte.permissive") ||
property_parse_bool("persist.device_config.memory_safety_native.permissive.default") ||
property_parse_bool(process_sysprop_name) ||
(permissive_env && ParseBool(permissive_env) == ParseBoolResult::kTrue);
}