1 /* 2 * Copyright (C) 2012 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 17 #pragma once 18 19 #include <stdint.h> 20 #include <sys/types.h> 21 22 #include <set> 23 #include <string> 24 #include <vector> 25 26 std::string fs_mgr_get_slot_suffix(); 27 std::string fs_mgr_get_other_slot_suffix(); 28 29 namespace android { 30 namespace fs_mgr { 31 32 struct FstabEntry { 33 std::string blk_device; 34 std::string logical_partition_name; 35 std::string mount_point; 36 std::string fs_type; 37 unsigned long flags = 0; 38 std::string fs_options; 39 std::string key_loc; 40 std::string key_dir; 41 std::string verity_loc; 42 off64_t length = 0; 43 std::string label; 44 int partnum = -1; 45 int swap_prio = -1; 46 int max_comp_streams = 0; 47 off64_t zram_size = 0; 48 off64_t reserved_size = 0; 49 std::string file_contents_mode; 50 std::string file_names_mode; 51 off64_t erase_blk_size = 0; 52 off64_t logical_blk_size = 0; 53 std::string sysfs_path; 54 std::string vbmeta_partition; 55 std::string zram_loopback_path; 56 uint64_t zram_loopback_size = 512 * 1024 * 1024; // 512MB by default; 57 std::string zram_backing_dev_path; 58 std::string avb_keys; 59 60 struct FsMgrFlags { 61 bool wait : 1; 62 bool check : 1; 63 bool crypt : 1; 64 bool nonremovable : 1; 65 bool vold_managed : 1; 66 bool recovery_only : 1; 67 bool verify : 1; 68 bool force_crypt : 1; 69 bool no_emulated_sd : 1; // No emulated sdcard daemon; sd card is the only external 70 // storage. 71 bool no_trim : 1; 72 bool file_encryption : 1; 73 bool formattable : 1; 74 bool slot_select : 1; 75 bool force_fde_or_fbe : 1; 76 bool late_mount : 1; 77 bool no_fail : 1; 78 bool verify_at_boot : 1; 79 bool quota : 1; 80 bool avb : 1; 81 bool logical : 1; 82 bool checkpoint_blk : 1; 83 bool checkpoint_fs : 1; 84 bool first_stage_mount : 1; 85 bool slot_select_other : 1; 86 bool fs_verity : 1; 87 } fs_mgr_flags = {}; 88 is_encryptableFstabEntry89 bool is_encryptable() const { 90 return fs_mgr_flags.crypt || fs_mgr_flags.force_crypt || fs_mgr_flags.force_fde_or_fbe; 91 } 92 }; 93 94 // An Fstab is a collection of FstabEntry structs. 95 // The entries must be kept in the same order as they were seen in the fstab. 96 // Unless explicitly requested, a lookup on mount point should always return the 1st one. 97 using Fstab = std::vector<FstabEntry>; 98 99 bool ReadFstabFromFile(const std::string& path, Fstab* fstab); 100 bool ReadFstabFromDt(Fstab* fstab, bool log = true); 101 bool ReadDefaultFstab(Fstab* fstab); 102 bool SkipMountingPartitions(Fstab* fstab); 103 104 FstabEntry* GetEntryForMountPoint(Fstab* fstab, const std::string& path); 105 106 // Helper method to build a GSI fstab entry for mounting /system. 107 FstabEntry BuildGsiSystemFstabEntry(); 108 109 std::set<std::string> GetBootDevices(); 110 111 // Return the name of the dm-verity device for the given fstab entry. This does 112 // not check whether the device is valid or exists; it merely returns the 113 // expected name. 114 std::string GetVerityDeviceName(const FstabEntry& entry); 115 116 } // namespace fs_mgr 117 } // namespace android 118