From 0a0f4b163a5fba68a656fd55cfaa6bca6ce69436 Mon Sep 17 00:00:00 2001 From: Hung-ying Tyan Date: Fri, 3 Jul 2020 14:26:59 +0800 Subject: [PATCH] Remove SkipMountingPartitions from vendor libfstab SkipMountingPartitions() should only be called from a system process as the config file is in /system_ext. Remove it from the vendor variant of libfstab. Bug: 158301941 Test: build hardware/interfaces/boot/1.1/default/boot_control and check symbol Change-Id: I834183a623c0711dd79b89486fc3fc80f9710801 Merged-In: I834183a623c0711dd79b89486fc3fc80f9710801 (cherry picked from e7cb09d2264a9071425a45bd76d4e6be45607d5f) --- fs_mgr/Android.bp | 8 ++++++++ fs_mgr/fs_mgr_fstab.cpp | 6 ++++++ 2 files changed, 14 insertions(+) diff --git a/fs_mgr/Android.bp b/fs_mgr/Android.bp index cd6459989..ac784b249 100644 --- a/fs_mgr/Android.bp +++ b/fs_mgr/Android.bp @@ -149,6 +149,14 @@ cc_library_static { darwin: { enabled: false, }, + vendor: { + cflags: [ + // Skipping entries in fstab should only be done in a system + // process as the config file is in /system_ext. + // Remove the op from the vendor variant. + "-DNO_SKIP_MOUNT", + ], + }, }, export_include_dirs: ["include_fstab"], header_libs: [ diff --git a/fs_mgr/fs_mgr_fstab.cpp b/fs_mgr/fs_mgr_fstab.cpp index fa4ac3904..8a2207870 100644 --- a/fs_mgr/fs_mgr_fstab.cpp +++ b/fs_mgr/fs_mgr_fstab.cpp @@ -690,7 +690,9 @@ bool ReadFstabFromFile(const std::string& path, Fstab* fstab) { TransformFstabForDsu(fstab, Split(lp_names, ",")); } +#ifndef NO_SKIP_MOUNT SkipMountingPartitions(fstab); +#endif EnableMandatoryFlags(fstab); return true; @@ -720,11 +722,14 @@ bool ReadFstabFromDt(Fstab* fstab, bool log) { return false; } +#ifndef NO_SKIP_MOUNT SkipMountingPartitions(fstab); +#endif return true; } +#ifndef NO_SKIP_MOUNT // For GSI to skip mounting /product and /system_ext, until there are well-defined interfaces // between them and /system. Otherwise, the GSI flashed on /system might not be able to work with // device-specific /product and /system_ext. skip_mount.cfg belongs to system_ext partition because @@ -756,6 +761,7 @@ bool SkipMountingPartitions(Fstab* fstab) { return true; } +#endif // Loads the fstab file and combines with fstab entries passed in from device tree. bool ReadDefaultFstab(Fstab* fstab) {