blob: 91c01725aaca514753194c61c1e3a5b235366373 [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
Jeff Sharkey814e9d32017-09-13 11:49:44 -060019import android.os.IVoldListener;
Jeff Sharkey52f7a912017-09-15 12:57:44 -060020import android.os.IVoldTaskListener;
Jeff Sharkey814e9d32017-09-13 11:49:44 -060021
Jeff Sharkey068c6be2017-09-06 13:47:40 -060022/** {@hide} */
23interface IVold {
Jeff Sharkey814e9d32017-09-13 11:49:44 -060024 void setListener(IVoldListener listener);
25
Jeff Sharkeycbe69fc2017-09-15 16:50:28 -060026 void monitor();
Jeff Sharkey068c6be2017-09-06 13:47:40 -060027 void reset();
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060028 void shutdown();
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060029
30 void onUserAdded(int userId, int userSerial);
31 void onUserRemoved(int userId);
Sudheer Shanka5fceb482019-04-29 10:46:35 -070032 void onUserStarted(int userId);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060033 void onUserStopped(int userId);
34
Sudheer Shankad484aa92018-07-31 10:07:34 -070035 void addAppIds(in @utf8InCpp String[] packageNames, in int[] appIds);
36 void addSandboxIds(in int[] appIds, in @utf8InCpp String[] sandboxIds);
37
Jeff Sharkey401b2602017-12-14 22:15:20 -070038 void onSecureKeyguardStateChanged(boolean isShowing);
39
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060040 void partition(@utf8InCpp String diskId, int partitionType, int ratio);
Jeff Sharkey3ce18252017-10-24 11:08:45 -060041 void forgetPartition(@utf8InCpp String partGuid, @utf8InCpp String fsUuid);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060042
Zim3623a212019-07-19 16:46:53 +010043 FileDescriptor mount(@utf8InCpp String volId, int mountFlags, int mountUserId);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060044 void unmount(@utf8InCpp String volId);
45 void format(@utf8InCpp String volId, @utf8InCpp String fsType);
Jeff Sharkey52f7a912017-09-15 12:57:44 -060046 void benchmark(@utf8InCpp String volId, IVoldTaskListener listener);
Jeff Sharkey2048a282017-06-15 09:59:43 -060047 void checkEncryption(@utf8InCpp String volId);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060048
Jeff Sharkey52f7a912017-09-15 12:57:44 -060049 void moveStorage(@utf8InCpp String fromVolId, @utf8InCpp String toVolId,
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070050 IVoldTaskListener listener);
Jeff Sharkey9462bdd2017-09-07 15:27:28 -060051
52 void remountUid(int uid, int remountMode);
53
54 void mkdirs(@utf8InCpp String path);
55
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070056 @utf8InCpp String createObb(@utf8InCpp String sourcePath, @utf8InCpp String sourceKey,
57 int ownerGid);
Jeff Sharkey11c2d382017-09-11 10:32:01 -060058 void destroyObb(@utf8InCpp String volId);
59
Jeff Sharkey52f7a912017-09-15 12:57:44 -060060 void fstrim(int fstrimFlags, IVoldTaskListener listener);
Jin Qiana370c142017-10-17 15:41:45 -070061 void runIdleMaint(IVoldTaskListener listener);
62 void abortIdleMaint(IVoldTaskListener listener);
Jeff Sharkey11c2d382017-09-11 10:32:01 -060063
Risan8f6198d2018-10-26 20:56:45 -060064 FileDescriptor mountAppFuse(int uid, int mountId);
65 void unmountAppFuse(int uid, int mountId);
Jeff Sharkey11c2d382017-09-11 10:32:01 -060066
Jeff Sharkey83b559c2017-09-12 16:30:52 -060067 void fdeCheckPassword(@utf8InCpp String password);
68 void fdeRestart();
69 int fdeComplete();
70 void fdeEnable(int passwordType, @utf8InCpp String password, int encryptionFlags);
71 void fdeChangePassword(int passwordType, @utf8InCpp String password);
72 void fdeVerifyPassword(@utf8InCpp String password);
73 @utf8InCpp String fdeGetField(@utf8InCpp String key);
74 void fdeSetField(@utf8InCpp String key, @utf8InCpp String value);
75 int fdeGetPasswordType();
76 @utf8InCpp String fdeGetPassword();
77 void fdeClearPassword();
78
79 void fbeEnable();
80
81 void mountDefaultEncrypted();
82 void initUser0();
83 boolean isConvertibleToFbe();
Paul Lawrence236e5e82019-06-25 14:44:33 -070084 void mountFstab(@utf8InCpp String blkDevice, @utf8InCpp String mountPoint);
85 void encryptFstab(@utf8InCpp String blkDevice, @utf8InCpp String mountPoint);
Jeff Sharkey83b559c2017-09-12 16:30:52 -060086
87 void createUserKey(int userId, int userSerial, boolean ephemeral);
88 void destroyUserKey(int userId);
89
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070090 void addUserKeyAuth(int userId, int userSerial, @utf8InCpp String token,
91 @utf8InCpp String secret);
Jeff Sharkey83b559c2017-09-12 16:30:52 -060092 void fixateNewestUserKeyAuth(int userId);
93
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070094 void unlockUserKey(int userId, int userSerial, @utf8InCpp String token,
95 @utf8InCpp String secret);
Jeff Sharkey83b559c2017-09-12 16:30:52 -060096 void lockUserKey(int userId);
97
Paul Crowleyedf7a4e2018-09-18 15:14:18 -070098 void prepareUserStorage(@nullable @utf8InCpp String uuid, int userId, int userSerial,
99 int storageFlags);
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600100 void destroyUserStorage(@nullable @utf8InCpp String uuid, int userId, int storageFlags);
101
Sudheer Shankafa6a1742018-10-04 16:26:22 -0700102 void prepareSandboxForApp(in @utf8InCpp String packageName, int appId,
103 in @utf8InCpp String sandboxId, int userId);
Sudheer Shanka69bc40f2018-10-25 11:06:55 -0700104 void destroySandboxForApp(in @utf8InCpp String packageName,
Sudheer Shankafa6a1742018-10-04 16:26:22 -0700105 in @utf8InCpp String sandboxId, int userId);
Sudheer Shankac7562092018-08-24 10:20:56 -0700106
Daniel Rosenberge334aab2018-10-10 18:52:04 -0700107 void startCheckpoint(int retry);
Daniel Rosenberg4f684712018-08-28 01:58:49 -0700108 boolean needsCheckpoint();
Daniel Rosenbergd3992492018-10-02 17:40:44 -0700109 boolean needsRollback();
Daniel Rosenberga59e4392019-03-20 17:02:47 -0700110 void abortChanges(in @utf8InCpp String device, boolean retry);
Daniel Rosenberge334aab2018-10-10 18:52:04 -0700111 void commitChanges();
112 void prepareCheckpoint();
113 void restoreCheckpoint(@utf8InCpp String device);
Daniel Rosenbergdda59812019-03-06 17:45:17 -0800114 void restoreCheckpointPart(@utf8InCpp String device, int count);
Daniel Rosenberge334aab2018-10-10 18:52:04 -0700115 void markBootAttempt();
Daniel Rosenberg9b667fb2019-01-22 17:27:25 -0800116 boolean supportsCheckpoint();
Paul Lawrencec5c79c52019-03-18 13:36:40 -0700117 boolean supportsBlockCheckpoint();
118 boolean supportsFileCheckpoint();
Nikita Ioffea5798fc2019-10-11 16:38:21 +0100119 void resetCheckpoint();
Daniel Rosenberg4f684712018-08-28 01:58:49 -0700120
Risan8c9f3322018-10-29 08:52:56 +0900121 @utf8InCpp String createStubVolume(@utf8InCpp String sourcePath,
122 @utf8InCpp String mountPath, @utf8InCpp String fsType,
123 @utf8InCpp String fsUuid, @utf8InCpp String fsLabel);
124 void destroyStubVolume(@utf8InCpp String volId);
125
Risan8f6198d2018-10-26 20:56:45 -0600126 FileDescriptor openAppFuseFile(int uid, int mountId, int fileId, int flags);
127
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600128 const int ENCRYPTION_FLAG_NO_UI = 4;
129
130 const int ENCRYPTION_STATE_NONE = 1;
131 const int ENCRYPTION_STATE_OK = 0;
132 const int ENCRYPTION_STATE_ERROR_UNKNOWN = -1;
133 const int ENCRYPTION_STATE_ERROR_INCOMPLETE = -2;
134 const int ENCRYPTION_STATE_ERROR_INCONSISTENT = -3;
135 const int ENCRYPTION_STATE_ERROR_CORRUPT = -4;
136
Jeff Sharkey11c2d382017-09-11 10:32:01 -0600137 const int FSTRIM_FLAG_DEEP_TRIM = 1;
Jeff Sharkey11c2d382017-09-11 10:32:01 -0600138
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600139 const int MOUNT_FLAG_PRIMARY = 1;
140 const int MOUNT_FLAG_VISIBLE = 2;
141
142 const int PARTITION_TYPE_PUBLIC = 0;
143 const int PARTITION_TYPE_PRIVATE = 1;
144 const int PARTITION_TYPE_MIXED = 2;
145
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600146 const int PASSWORD_TYPE_PASSWORD = 0;
147 const int PASSWORD_TYPE_DEFAULT = 1;
Paul Crowleyca08c0a2018-07-03 11:49:00 -0700148 const int PASSWORD_TYPE_PATTERN = 2;
149 const int PASSWORD_TYPE_PIN = 3;
Jeff Sharkey83b559c2017-09-12 16:30:52 -0600150
151 const int STORAGE_FLAG_DE = 1;
152 const int STORAGE_FLAG_CE = 2;
153
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600154 const int REMOUNT_MODE_NONE = 0;
155 const int REMOUNT_MODE_DEFAULT = 1;
156 const int REMOUNT_MODE_READ = 2;
157 const int REMOUNT_MODE_WRITE = 3;
Sudheer Shanka55049012019-01-09 12:15:15 -0800158 const int REMOUNT_MODE_LEGACY = 4;
159 const int REMOUNT_MODE_INSTALLER = 5;
160 const int REMOUNT_MODE_FULL = 6;
Zim981222f2019-09-09 10:24:44 +0100161 const int REMOUNT_MODE_PASS_THROUGH = 7;
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600162
Jeff Sharkey814e9d32017-09-13 11:49:44 -0600163 const int VOLUME_STATE_UNMOUNTED = 0;
164 const int VOLUME_STATE_CHECKING = 1;
165 const int VOLUME_STATE_MOUNTED = 2;
166 const int VOLUME_STATE_MOUNTED_READ_ONLY = 3;
167 const int VOLUME_STATE_FORMATTING = 4;
168 const int VOLUME_STATE_EJECTING = 5;
169 const int VOLUME_STATE_UNMOUNTABLE = 6;
170 const int VOLUME_STATE_REMOVED = 7;
171 const int VOLUME_STATE_BAD_REMOVAL = 8;
Jeff Sharkey9462bdd2017-09-07 15:27:28 -0600172
Jeff Sharkey814e9d32017-09-13 11:49:44 -0600173 const int VOLUME_TYPE_PUBLIC = 0;
174 const int VOLUME_TYPE_PRIVATE = 1;
175 const int VOLUME_TYPE_EMULATED = 2;
176 const int VOLUME_TYPE_ASEC = 3;
177 const int VOLUME_TYPE_OBB = 4;
Risan8c9f3322018-10-29 08:52:56 +0900178 const int VOLUME_TYPE_STUB = 5;
Jeff Sharkey068c6be2017-09-06 13:47:40 -0600179}