• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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