From 1ff45ac5f56f5c906434f264017e636914b7162c Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Tue, 9 Mar 2021 04:08:16 -0800 Subject: [PATCH] Proper pattern matching Fix #3998 --- native/jni/magiskboot/pattern.cpp | 43 +++++++++++++++++-------------- 1 file changed, 23 insertions(+), 20 deletions(-) diff --git a/native/jni/magiskboot/pattern.cpp b/native/jni/magiskboot/pattern.cpp index a56d16762..df0cdc0ac 100644 --- a/native/jni/magiskboot/pattern.cpp +++ b/native/jni/magiskboot/pattern.cpp @@ -1,44 +1,47 @@ #include -#include #include #include "magiskboot.hpp" -#define CHECKED_MATCH(p) else if (strncmp(s + skip, p, sizeof(p) - 1) == 0) skip += (sizeof(p) - 1) +#define MATCH(p) else if (strncmp(s + skip, p, sizeof(p) - 1) == 0) skip += (sizeof(p) - 1) -static int check_verity_pattern(const char *s) { +static int skip_verity_pattern(const char *s) { int skip = s[0] == ','; if (0) {} - CHECKED_MATCH("verifyatboot"); - CHECKED_MATCH("verify"); - CHECKED_MATCH("avb_keys"); - CHECKED_MATCH("avb"); - CHECKED_MATCH("support_scfs"); - CHECKED_MATCH("fsverity"); + MATCH("verifyatboot"); + MATCH("verify"); + MATCH("avb_keys"); + MATCH("avb"); + MATCH("support_scfs"); + MATCH("fsverity"); else return -1; if (s[skip] == '=') { - while (s[skip] != '\0' && s[skip] != ' ' && s[skip] != '\n' && s[skip] != ',') + while (!strchr(" \n,", s[skip])) ++skip; } return skip; } -#undef CHECKED_MATCH -#define CHECKED_MATCH(p) else if (strncmp(s, p, sizeof(p) - 1) == 0) return (sizeof(p) - 1) +static int skip_encryption_pattern(const char *s) { + int skip = s[0] == ','; -static int check_encryption_pattern(const char *s) { if (0) {} - CHECKED_MATCH("forceencrypt"); - CHECKED_MATCH("forcefdeorfbe"); - CHECKED_MATCH("fileencryption"); + MATCH("forceencrypt"); + MATCH("forcefdeorfbe"); + MATCH("fileencryption"); else return -1; + + if (s[skip] == '=') { + while (!strchr(" \n,", s[skip])) + ++skip; + } + return skip; } -static uint32_t remove_pattern(void *buf, uint32_t size, int(*pattern_skip)(const char *)) { - auto src = static_cast(buf); +static uint32_t remove_pattern(char *src, uint32_t size, int(*pattern_skip)(const char *)) { int orig_sz = size; int write = 0; for (int read = 0; read < orig_sz;) { @@ -55,9 +58,9 @@ static uint32_t remove_pattern(void *buf, uint32_t size, int(*pattern_skip)(cons } uint32_t patch_verity(void *buf, uint32_t size) { - return remove_pattern(buf, size, check_verity_pattern); + return remove_pattern(static_cast(buf), size, skip_verity_pattern); } uint32_t patch_encryption(void *buf, uint32_t size) { - return remove_pattern(buf, size, check_encryption_pattern); + return remove_pattern(static_cast(buf), size, skip_encryption_pattern); }