xref: /aosp_15_r20/system/vold/model/EmulatedVolume.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_EMULATED_VOLUME_H
18*f40fafd4SAndroid Build Coastguard Worker #define ANDROID_VOLD_EMULATED_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 emulated on top of private storage.
29*f40fafd4SAndroid Build Coastguard Worker  *
30*f40fafd4SAndroid Build Coastguard Worker  * Knows how to spawn a sdcardfs daemon to synthesize permissions.  ObbVolume
31*f40fafd4SAndroid Build Coastguard Worker  * can be stacked above it.
32*f40fafd4SAndroid Build Coastguard Worker  *
33*f40fafd4SAndroid Build Coastguard Worker  * This volume is always multi-user aware, but is only binds itself to
34*f40fafd4SAndroid Build Coastguard Worker  * users when its primary storage.  This volume should never be presented
35*f40fafd4SAndroid Build Coastguard Worker  * as secondary storage, since we're strongly encouraging developers to
36*f40fafd4SAndroid Build Coastguard Worker  * store data local to their app.
37*f40fafd4SAndroid Build Coastguard Worker  */
38*f40fafd4SAndroid Build Coastguard Worker class EmulatedVolume : public VolumeBase {
39*f40fafd4SAndroid Build Coastguard Worker   public:
40*f40fafd4SAndroid Build Coastguard Worker     explicit EmulatedVolume(const std::string& rawPath, int userId);
41*f40fafd4SAndroid Build Coastguard Worker     EmulatedVolume(const std::string& rawPath, dev_t device, const std::string& fsUuid, int userId);
42*f40fafd4SAndroid Build Coastguard Worker     virtual ~EmulatedVolume();
43*f40fafd4SAndroid Build Coastguard Worker     std::string getRootPath() const override;
isFuseMounted()44*f40fafd4SAndroid Build Coastguard Worker     bool isFuseMounted() const { return mFuseMounted; }
45*f40fafd4SAndroid Build Coastguard Worker 
46*f40fafd4SAndroid Build Coastguard Worker   protected:
47*f40fafd4SAndroid Build Coastguard Worker     status_t doMount() override;
48*f40fafd4SAndroid Build Coastguard Worker     status_t doUnmount() override;
49*f40fafd4SAndroid Build Coastguard Worker 
50*f40fafd4SAndroid Build Coastguard Worker   private:
51*f40fafd4SAndroid Build Coastguard Worker     status_t unmountSdcardFs();
52*f40fafd4SAndroid Build Coastguard Worker     status_t mountFuseBindMounts();
53*f40fafd4SAndroid Build Coastguard Worker     status_t unmountFuseBindMounts();
54*f40fafd4SAndroid Build Coastguard Worker 
55*f40fafd4SAndroid Build Coastguard Worker     status_t bindMountVolume(const EmulatedVolume& vol, std::list<std::string>& pathsToUnmount);
56*f40fafd4SAndroid Build Coastguard Worker 
57*f40fafd4SAndroid Build Coastguard Worker     std::string getLabel() const;
58*f40fafd4SAndroid Build Coastguard Worker     std::string mRawPath;
59*f40fafd4SAndroid Build Coastguard Worker     std::string mLabel;
60*f40fafd4SAndroid Build Coastguard Worker 
61*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsDefault;
62*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsRead;
63*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsWrite;
64*f40fafd4SAndroid Build Coastguard Worker     std::string mSdcardFsFull;
65*f40fafd4SAndroid Build Coastguard Worker 
66*f40fafd4SAndroid Build Coastguard Worker     /* Whether we mounted FUSE for this volume */
67*f40fafd4SAndroid Build Coastguard Worker     bool mFuseMounted;
68*f40fafd4SAndroid Build Coastguard Worker 
69*f40fafd4SAndroid Build Coastguard Worker     /* Whether to use sdcardfs for this volume */
70*f40fafd4SAndroid Build Coastguard Worker     bool mUseSdcardFs;
71*f40fafd4SAndroid Build Coastguard Worker 
72*f40fafd4SAndroid Build Coastguard Worker     /* Whether to use app data isolation is enabled tor this volume */
73*f40fafd4SAndroid Build Coastguard Worker     bool mAppDataIsolationEnabled;
74*f40fafd4SAndroid Build Coastguard Worker 
75*f40fafd4SAndroid Build Coastguard Worker     /* Location of bind mount for another profile that shares storage with us */
76*f40fafd4SAndroid Build Coastguard Worker     std::string mSharedStorageMountPath = "";
77*f40fafd4SAndroid Build Coastguard Worker 
78*f40fafd4SAndroid Build Coastguard Worker     DISALLOW_COPY_AND_ASSIGN(EmulatedVolume);
79*f40fafd4SAndroid Build Coastguard Worker };
80*f40fafd4SAndroid Build Coastguard Worker 
81*f40fafd4SAndroid Build Coastguard Worker }  // namespace vold
82*f40fafd4SAndroid Build Coastguard Worker }  // namespace android
83*f40fafd4SAndroid Build Coastguard Worker 
84*f40fafd4SAndroid Build Coastguard Worker #endif
85