From 2f2fe4afafa384554f05626ea12427f6722c1aa4 Mon Sep 17 00:00:00 2001 From: Yi-Yo Chiang Date: Wed, 31 Mar 2021 20:39:22 +0800 Subject: [PATCH] fs_mgr: SkipMountingPartitions() support glob patterns Enhance skip_mount.cfg to be able to specify glob patterns. Bug: 184132970 Test: GSI Boot test Change-Id: I8e6528e4aff6ea176aa028c3c55d6cedaff3e181 --- fs_mgr/fs_mgr_fstab.cpp | 33 ++++++++++++++++++++++----------- 1 file changed, 22 insertions(+), 11 deletions(-) diff --git a/fs_mgr/fs_mgr_fstab.cpp b/fs_mgr/fs_mgr_fstab.cpp index 796a39abf..31ef3b58f 100644 --- a/fs_mgr/fs_mgr_fstab.cpp +++ b/fs_mgr/fs_mgr_fstab.cpp @@ -17,6 +17,7 @@ #include #include #include +#include #include #include #include @@ -767,21 +768,31 @@ bool SkipMountingPartitions(Fstab* fstab, bool verbose) { return true; } - for (const auto& skip_mount_point : Split(skip_config, "\n")) { - if (skip_mount_point.empty()) { + std::vector skip_mount_patterns; + for (const auto& line : Split(skip_config, "\n")) { + if (line.empty() || StartsWith(line, "#")) { continue; } - auto it = std::remove_if(fstab->begin(), fstab->end(), - [&skip_mount_point](const auto& entry) { - return entry.mount_point == skip_mount_point; - }); - if (it == fstab->end()) continue; - fstab->erase(it, fstab->end()); - if (verbose) { - LINFO << "Skip mounting partition: " << skip_mount_point; - } + skip_mount_patterns.push_back(line); } + // Returns false if mount_point matches any of the skip mount patterns, so that the FstabEntry + // would be partitioned to the second group. + auto glob_pattern_mismatch = [&skip_mount_patterns](const FstabEntry& entry) -> bool { + for (const auto& pattern : skip_mount_patterns) { + if (!fnmatch(pattern.c_str(), entry.mount_point.c_str(), 0 /* flags */)) { + return false; + } + } + return true; + }; + auto remove_from = std::stable_partition(fstab->begin(), fstab->end(), glob_pattern_mismatch); + if (verbose) { + for (auto it = remove_from; it != fstab->end(); ++it) { + LINFO << "Skip mounting mountpoint: " << it->mount_point; + } + } + fstab->erase(remove_from, fstab->end()); return true; } #endif