xref: /aosp_15_r20/system/vold/model/PublicVolume.h (revision f40fafd4c6c2594924d919feffc1a1fd6e3b30f3)
1*f40fafd4SAndroid Build Coastguard Worker /*
2*f40fafd4SAndroid Build Coastguard Worker  * Copyright (C) 2015 The Android Open Source Project
3*f40fafd4SAndroid Build Coastguard Worker  *
4*f40fafd4SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*f40fafd4SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*f40fafd4SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*f40fafd4SAndroid Build Coastguard Worker  *
8*f40fafd4SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*f40fafd4SAndroid Build Coastguard Worker  *
10*f40fafd4SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*f40fafd4SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*f40fafd4SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*f40fafd4SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*f40fafd4SAndroid Build Coastguard Worker  * limitations under the License.
15*f40fafd4SAndroid Build Coastguard Worker  */
16*f40fafd4SAndroid Build Coastguard Worker 
17*f40fafd4SAndroid Build Coastguard Worker #ifndef ANDROID_VOLD_PUBLIC_VOLUME_H
18*f40fafd4SAndroid Build Coastguard Worker #define ANDROID_VOLD_PUBLIC_VOLUME_H
19*f40fafd4SAndroid Build Coastguard Worker 
20*f40fafd4SAndroid Build Coastguard Worker #include "VolumeBase.h"
21*f40fafd4SAndroid Build Coastguard Worker 
22*f40fafd4SAndroid Build Coastguard Worker #include <cutils/multiuser.h>
23*f40fafd4SAndroid Build Coastguard Worker 
24*f40fafd4SAndroid Build Coastguard Worker namespace android {
25*f40fafd4SAndroid Build Coastguard Worker namespace vold {
26*f40fafd4SAndroid Build Coastguard Worker 
27*f40fafd4SAndroid Build Coastguard Worker /*
28*f40fafd4SAndroid Build Coastguard Worker  * Shared storage provided by public (vfat) partition.
29*f40fafd4SAndroid Build Coastguard Worker  *
30*f40fafd4SAndroid Build Coastguard Worker  * Knows how to mount itself and then spawn a sdcardfs daemon to synthesize
31*f40fafd4SAndroid Build Coastguard Worker  * permissions.  AsecVolume and ObbVolume can be stacked above it.
32*f40fafd4SAndroid Build Coastguard Worker  *
33*f40fafd4SAndroid Build Coastguard Worker  * This volume is not inherently multi-user aware, so it has two possible
34*f40fafd4SAndroid Build Coastguard Worker  * modes of operation:
35*f40fafd4SAndroid Build Coastguard Worker  * 1. If primary storage for the device, it only binds itself to the
36*f40fafd4SAndroid Build Coastguard Worker  * owner user.
37*f40fafd4SAndroid Build Coastguard Worker  * 2. If secondary storage, it binds itself for all users, but masks
38*f40fafd4SAndroid Build Coastguard Worker  * away the Android directory for secondary users.
39*f40fafd4SAndroid Build Coastguard Worker  */
40*f40fafd4SAndroid Build Coastguard Worker class PublicVolume : public VolumeBase {
41*f40fafd4SAndroid Build Coastguard Worker   public:
42*f40fafd4SAndroid Build Coastguard Worker     explicit PublicVolume(dev_t device);
43*f40fafd4SAndroid Build Coastguard Worker     virtual ~PublicVolume();
44*f40fafd4SAndroid Build Coastguard Worker 
45*f40fafd4SAndroid Build Coastguard Worker     status_t bindMountForUser(userid_t user_id);
46*f40fafd4SAndroid Build Coastguard Worker 
47*f40fafd4SAndroid Build Coastguard Worker   protected:
48*f40fafd4SAndroid Build Coastguard Worker     status_t doCreate() override;
49*f40fafd4SAndroid Build Coastguard Worker     status_t doDestroy() override;
50*f40fafd4SAndroid Build Coastguard Worker     status_t doMount() override;
51*f40fafd4SAndroid Build Coastguard Worker     status_t doUnmount() override;
52*f40fafd4SAndroid Build Coastguard Worker     status_t doFormat(const std::string& fsType) override;
53*f40fafd4SAndroid Build Coastguard Worker 
54*f40fafd4SAndroid Build Coastguard Worker     status_t readMetadata();
55*f40fafd4SAndroid Build Coastguard Worker     status_t initAsecStage();
56*f40fafd4SAndroid Build Coastguard Worker 
57*f40fafd4SAndroid Build Coastguard Worker   private:
58*f40fafd4SAndroid Build Coastguard Worker     /* Kernel device representing partition */
59*f40fafd4SAndroid Build Coastguard Worker     dev_t mDevice;
60*f40fafd4SAndroid Build Coastguard Worker     /* Block device path */
61*f40fafd4SAndroid Build Coastguard Worker     std::string mDevPath;
62*f40fafd4SAndroid Build Coastguard Worker     /* Mount point of raw partition */
63*f40fafd4SAndroid Build Coastguard Worker     std::string mRawPath;
64*f40fafd4SAndroid Build Coastguard Worker 
65*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsDefault;
66*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsRead;
67*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsWrite;
68*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsFull;
69*f40fafd4SAndroid Build Coastguard Worker 
70*f40fafd4SAndroid Build Coastguard Worker     /* Whether we mounted FUSE for this volume */
71*f40fafd4SAndroid Build Coastguard Worker     bool mFuseMounted;
72*f40fafd4SAndroid Build Coastguard Worker 
73*f40fafd4SAndroid Build Coastguard Worker     /* Whether to use sdcardfs for this volume */
74*f40fafd4SAndroid Build Coastguard Worker     bool mUseSdcardFs;
75*f40fafd4SAndroid Build Coastguard Worker 
76*f40fafd4SAndroid Build Coastguard Worker     /* Filesystem type */
77*f40fafd4SAndroid Build Coastguard Worker     std::string mFsType;
78*f40fafd4SAndroid Build Coastguard Worker     /* Filesystem UUID */
79*f40fafd4SAndroid Build Coastguard Worker     std::string mFsUuid;
80*f40fafd4SAndroid Build Coastguard Worker     /* User-visible filesystem label */
81*f40fafd4SAndroid Build Coastguard Worker     std::string mFsLabel;
82*f40fafd4SAndroid Build Coastguard Worker 
83*f40fafd4SAndroid Build Coastguard Worker     DISALLOW_COPY_AND_ASSIGN(PublicVolume);
84*f40fafd4SAndroid Build Coastguard Worker };
85*f40fafd4SAndroid Build Coastguard Worker 
86*f40fafd4SAndroid Build Coastguard Worker }  // namespace vold
87*f40fafd4SAndroid Build Coastguard Worker }  // namespace android
88*f40fafd4SAndroid Build Coastguard Worker 
89*f40fafd4SAndroid Build Coastguard Worker #endif
90