blob: 19ce9babee41eb1338ecb445a453a0691f4e69f9 [file] [log] [blame]
Jeff Sharkey068c6be2017-09-06 13:47:40 -06001/*
2 * Copyright (C) 2017 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
17package android.os;
18
Songchun Fanab55cec2019-12-02 10:50:12 -080019import android.os.incremental.IncrementalFileSystemControlParcel;
Jeff Sharkey814e9d32017-09-13 11:49:44 -060020import android.os.IVoldListener;
Zim5048b4b2019-11-19 09:16:03 +000021import android.os.IVoldMountCallback;
Jeff Sharkey52f7a912017-09-15 12:57:44 -060022import android.os.IVoldTaskListener;
Jeff Sharkey814e9d32017-09-13 11:49:44 -060023
Jeff Sharkey068c6be2017-09-06 13:47:40 -060024/** {@hide} */
25interface IVold {
Jeff Sharkey814e9d32017-09-13 11:49:44 -060026 void setListener(IVoldListener listener);
27
Martijn Coenen23c04452020-04-29 07:49:41 +020028 void abortFuse();
Jeff Sharkeycbe69fc2017-09-15 16:50:28 -060029 void monitor();
Jeff Sharkey068c6be2017-09-06 13:47:40 -060030 void reset();
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060031 void shutdown();
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060032
33 void onUserAdded(int userId, int userSerial);
34 void onUserRemoved(int userId);
Sudheer Shanka5fceb482019-04-29 10:46:35 -070035 void onUserStarted(int userId);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060036 void onUserStopped(int userId);
37
Sudheer Shankad484aa92018-07-31 10:07:34 -070038 void addAppIds(in @utf8InCpp String[] packageNames, in int[] appIds);
39 void addSandboxIds(in int[] appIds, in @utf8InCpp String[] sandboxIds);
40
Jeff Sharkey401b2602017-12-14 22:15:20 -070041 void onSecureKeyguardStateChanged(boolean isShowing);
42
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060043 void partition(@utf8InCpp String diskId, int partitionType, int ratio);
Jeff Sharkey3ce18252017-10-24 11:08:45 -060044 void forgetPartition(@utf8InCpp String partGuid, @utf8InCpp String fsUuid);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060045
Zim5048b4b2019-11-19 09:16:03 +000046 void mount(@utf8InCpp String volId, int mountFlags, int mountUserId,
Zim9d1425c2019-11-27 18:15:14 +000047 @nullable IVoldMountCallback callback);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060048 void unmount(@utf8InCpp String volId);
49 void format(@utf8InCpp String volId, @utf8InCpp String fsType);
Jeff Sharkey52f7a912017-09-15 12:57:44 -060050 void benchmark(@utf8InCpp String volId, IVoldTaskListener listener);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060051
Jeff Sharkey52f7a912017-09-15 12:57:44 -060052 void moveStorage(@utf8InCpp String fromVolId, @utf8InCpp String toVolId,
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070053 IVoldTaskListener listener);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060054
55 void remountUid(int uid, int remountMode);
Ricky Wai6b122572020-02-28 16:30:47 +000056 void remountAppStorageDirs(int uid, int pid, in @utf8InCpp String[] packageNames);
Ricky Waia2ca11e2021-01-15 14:03:23 +000057 void unmountAppStorageDirs(int uid, int pid, in @utf8InCpp String[] packageNames);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060058
Martijn Coenen8a68a072020-02-12 15:29:02 +010059 void setupAppDir(@utf8InCpp String path, int appUid);
Martijn Coenen816f4d92020-02-18 15:06:37 +010060 void fixupAppDir(@utf8InCpp String path, int appUid);
Ricky Waibbfb6ea2020-12-03 15:32:52 +000061 void ensureAppDirsCreated(in @utf8InCpp String[] paths, int appUid);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060062
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070063 @utf8InCpp String createObb(@utf8InCpp String sourcePath, @utf8InCpp String sourceKey,
64 int ownerGid);
Jeff Sharkey11c2d382017-09-11 10:32:01 -060065 void destroyObb(@utf8InCpp String volId);
66
Jeff Sharkey52f7a912017-09-15 12:57:44 -060067 void fstrim(int fstrimFlags, IVoldTaskListener listener);
Jin Qiana370c142017-10-17 15:41:45 -070068 void runIdleMaint(IVoldTaskListener listener);
69 void abortIdleMaint(IVoldTaskListener listener);
Jeff Sharkey11c2d382017-09-11 10:32:01 -060070
Risan8f6198d2018-10-26 20:56:45 -060071 FileDescriptor mountAppFuse(int uid, int mountId);
72 void unmountAppFuse(int uid, int mountId);
Jeff Sharkey11c2d382017-09-11 10:32:01 -060073
Jeff Sharkey83b559c2017-09-12 16:30:52 -060074 void fdeCheckPassword(@utf8InCpp String password);
75 void fdeRestart();
76 int fdeComplete();
77 void fdeEnable(int passwordType, @utf8InCpp String password, int encryptionFlags);
78 void fdeChangePassword(int passwordType, @utf8InCpp String password);
79 void fdeVerifyPassword(@utf8InCpp String password);
80 @utf8InCpp String fdeGetField(@utf8InCpp String key);
81 void fdeSetField(@utf8InCpp String key, @utf8InCpp String value);
82 int fdeGetPasswordType();
83 @utf8InCpp String fdeGetPassword();
84 void fdeClearPassword();
85
86 void fbeEnable();
87
88 void mountDefaultEncrypted();
89 void initUser0();
90 boolean isConvertibleToFbe();
Paul Lawrence236e5e82019-06-25 14:44:33 -070091 void mountFstab(@utf8InCpp String blkDevice, @utf8InCpp String mountPoint);
Jaegeuk Kim0c52c712020-12-15 09:00:49 -080092 void encryptFstab(@utf8InCpp String blkDevice, @utf8InCpp String mountPoint, boolean shouldFormat, @utf8InCpp String fsType);
Jeff Sharkey83b559c2017-09-12 16:30:52 -060093
94 void createUserKey(int userId, int userSerial, boolean ephemeral);
95 void destroyUserKey(int userId);
96
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070097 void addUserKeyAuth(int userId, int userSerial, @utf8InCpp String token,
98 @utf8InCpp String secret);
Barani Muthukumaran9ad51ad2019-10-31 22:59:34 -070099 void clearUserKeyAuth(int userId, int userSerial, @utf8InCpp String token,
100 @utf8InCpp String secret);
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600101 void fixateNewestUserKeyAuth(int userId);
102
Paul Crowleyedf7a4e2018-09-18 15:14:18 -0700103 void unlockUserKey(int userId, int userSerial, @utf8InCpp String token,
104 @utf8InCpp String secret);
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600105 void lockUserKey(int userId);
106
Paul Crowleyedf7a4e2018-09-18 15:14:18 -0700107 void prepareUserStorage(@nullable @utf8InCpp String uuid, int userId, int userSerial,
108 int storageFlags);
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600109 void destroyUserStorage(@nullable @utf8InCpp String uuid, int userId, int storageFlags);
110
Sudheer Shankafa6a1742018-10-04 16:26:22 -0700111 void prepareSandboxForApp(in @utf8InCpp String packageName, int appId,
112 in @utf8InCpp String sandboxId, int userId);
Sudheer Shanka69bc40f2018-10-25 11:06:55 -0700113 void destroySandboxForApp(in @utf8InCpp String packageName,
Sudheer Shankafa6a1742018-10-04 16:26:22 -0700114 in @utf8InCpp String sandboxId, int userId);
Sudheer Shankac7562092018-08-24 10:20:56 -0700115
Daniel Rosenberge334aab2018-10-10 18:52:04 -0700116 void startCheckpoint(int retry);
Daniel Rosenberg4f684712018-08-28 01:58:49 -0700117 boolean needsCheckpoint();
Daniel Rosenbergd3992492018-10-02 17:40:44 -0700118 boolean needsRollback();
David Anderson23850d32020-06-10 23:51:17 -0700119 boolean isCheckpointing();
Daniel Rosenberga59e4392019-03-20 17:02:47 -0700120 void abortChanges(in @utf8InCpp String device, boolean retry);
Daniel Rosenberge334aab2018-10-10 18:52:04 -0700121 void commitChanges();
122 void prepareCheckpoint();
123 void restoreCheckpoint(@utf8InCpp String device);
Daniel Rosenbergdda59812019-03-06 17:45:17 -0800124 void restoreCheckpointPart(@utf8InCpp String device, int count);
Daniel Rosenberge334aab2018-10-10 18:52:04 -0700125 void markBootAttempt();
Daniel Rosenberg9b667fb2019-01-22 17:27:25 -0800126 boolean supportsCheckpoint();
Paul Lawrencec5c79c52019-03-18 13:36:40 -0700127 boolean supportsBlockCheckpoint();
128 boolean supportsFileCheckpoint();
Nikita Ioffea5798fc2019-10-11 16:38:21 +0100129 void resetCheckpoint();
Daniel Rosenberg4f684712018-08-28 01:58:49 -0700130
Martijn Coeneneed957f2020-11-12 10:59:13 +0100131 void earlyBootEnded();
Risan8c9f3322018-10-29 08:52:56 +0900132 @utf8InCpp String createStubVolume(@utf8InCpp String sourcePath,
133 @utf8InCpp String mountPath, @utf8InCpp String fsType,
Risan82e90de2020-02-04 16:07:21 +0900134 @utf8InCpp String fsUuid, @utf8InCpp String fsLabel, int flags);
Risan8c9f3322018-10-29 08:52:56 +0900135 void destroyStubVolume(@utf8InCpp String volId);
136
Risan8f6198d2018-10-26 20:56:45 -0600137 FileDescriptor openAppFuseFile(int uid, int mountId, int fileId, int flags);
138
Yurii Zubrytskyi3497cb52020-01-10 11:54:06 -0800139 boolean incFsEnabled();
140 IncrementalFileSystemControlParcel mountIncFs(@utf8InCpp String backingPath, @utf8InCpp String targetDir, int flags);
Songchun Fanab55cec2019-12-02 10:50:12 -0800141 void unmountIncFs(@utf8InCpp String dir);
Alex Buynytskyy91e0bf42020-03-31 14:46:25 -0700142 void setIncFsMountOptions(in IncrementalFileSystemControlParcel control, boolean enableReadLogs);
Songchun Fanab55cec2019-12-02 10:50:12 -0800143 void bindMount(@utf8InCpp String sourceDir, @utf8InCpp String targetDir);
144
Yo Chiang0af25a32020-10-07 14:20:00 +0800145 void destroyDsuMetadataKey(@utf8InCpp String dsuSlot);
146
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600147 const int ENCRYPTION_FLAG_NO_UI = 4;
148
149 const int ENCRYPTION_STATE_NONE = 1;
150 const int ENCRYPTION_STATE_OK = 0;
151 const int ENCRYPTION_STATE_ERROR_UNKNOWN = -1;
152 const int ENCRYPTION_STATE_ERROR_INCOMPLETE = -2;
153 const int ENCRYPTION_STATE_ERROR_INCONSISTENT = -3;
154 const int ENCRYPTION_STATE_ERROR_CORRUPT = -4;
155
Jeff Sharkey11c2d382017-09-11 10:32:01 -0600156 const int FSTRIM_FLAG_DEEP_TRIM = 1;
Jeff Sharkey11c2d382017-09-11 10:32:01 -0600157
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600158 const int MOUNT_FLAG_PRIMARY = 1;
159 const int MOUNT_FLAG_VISIBLE = 2;
160
161 const int PARTITION_TYPE_PUBLIC = 0;
162 const int PARTITION_TYPE_PRIVATE = 1;
163 const int PARTITION_TYPE_MIXED = 2;
164
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600165 const int PASSWORD_TYPE_PASSWORD = 0;
166 const int PASSWORD_TYPE_DEFAULT = 1;
Paul Crowleyca08c0a2018-07-03 11:49:00 -0700167 const int PASSWORD_TYPE_PATTERN = 2;
168 const int PASSWORD_TYPE_PIN = 3;
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600169
170 const int STORAGE_FLAG_DE = 1;
171 const int STORAGE_FLAG_CE = 2;
172
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600173 const int REMOUNT_MODE_NONE = 0;
174 const int REMOUNT_MODE_DEFAULT = 1;
175 const int REMOUNT_MODE_READ = 2;
176 const int REMOUNT_MODE_WRITE = 3;
Sudheer Shanka55049012019-01-09 12:15:15 -0800177 const int REMOUNT_MODE_LEGACY = 4;
178 const int REMOUNT_MODE_INSTALLER = 5;
179 const int REMOUNT_MODE_FULL = 6;
Zim981222f2019-09-09 10:24:44 +0100180 const int REMOUNT_MODE_PASS_THROUGH = 7;
Martijn Coenenb52eb852020-01-08 15:04:21 +0100181 const int REMOUNT_MODE_ANDROID_WRITABLE = 8;
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600182
Jeff Sharkey814e9d32017-09-13 11:49:44 -0600183 const int VOLUME_STATE_UNMOUNTED = 0;
184 const int VOLUME_STATE_CHECKING = 1;
185 const int VOLUME_STATE_MOUNTED = 2;
186 const int VOLUME_STATE_MOUNTED_READ_ONLY = 3;
187 const int VOLUME_STATE_FORMATTING = 4;
188 const int VOLUME_STATE_EJECTING = 5;
189 const int VOLUME_STATE_UNMOUNTABLE = 6;
190 const int VOLUME_STATE_REMOVED = 7;
191 const int VOLUME_STATE_BAD_REMOVAL = 8;
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600192
Jeff Sharkey814e9d32017-09-13 11:49:44 -0600193 const int VOLUME_TYPE_PUBLIC = 0;
194 const int VOLUME_TYPE_PRIVATE = 1;
195 const int VOLUME_TYPE_EMULATED = 2;
196 const int VOLUME_TYPE_ASEC = 3;
197 const int VOLUME_TYPE_OBB = 4;
Risan8c9f3322018-10-29 08:52:56 +0900198 const int VOLUME_TYPE_STUB = 5;
Jeff Sharkey068c6be2017-09-06 13:47:40 -0600199}