7e07c53aab
This is needed so "adb remount" can avoid writing to /data during a checkpoint. Bug: 157540389 Test: manual test Change-Id: I33a691da3b99343acfc1e8ddf68a14504c3bfbe1 Merged-In: I33a691da3b99343acfc1e8ddf68a14504c3bfbe1
195 lines
7.5 KiB
Text
195 lines
7.5 KiB
Text
/*
|
|
* Copyright (C) 2017 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package android.os;
|
|
|
|
import android.os.incremental.IncrementalFileSystemControlParcel;
|
|
import android.os.IVoldListener;
|
|
import android.os.IVoldMountCallback;
|
|
import android.os.IVoldTaskListener;
|
|
|
|
/** {@hide} */
|
|
interface IVold {
|
|
void setListener(IVoldListener listener);
|
|
|
|
void abortFuse();
|
|
void monitor();
|
|
void reset();
|
|
void shutdown();
|
|
|
|
void onUserAdded(int userId, int userSerial);
|
|
void onUserRemoved(int userId);
|
|
void onUserStarted(int userId);
|
|
void onUserStopped(int userId);
|
|
|
|
void addAppIds(in @utf8InCpp String[] packageNames, in int[] appIds);
|
|
void addSandboxIds(in int[] appIds, in @utf8InCpp String[] sandboxIds);
|
|
|
|
void onSecureKeyguardStateChanged(boolean isShowing);
|
|
|
|
void partition(@utf8InCpp String diskId, int partitionType, int ratio);
|
|
void forgetPartition(@utf8InCpp String partGuid, @utf8InCpp String fsUuid);
|
|
|
|
void mount(@utf8InCpp String volId, int mountFlags, int mountUserId,
|
|
@nullable IVoldMountCallback callback);
|
|
void unmount(@utf8InCpp String volId);
|
|
void format(@utf8InCpp String volId, @utf8InCpp String fsType);
|
|
void benchmark(@utf8InCpp String volId, IVoldTaskListener listener);
|
|
void checkEncryption(@utf8InCpp String volId);
|
|
|
|
void moveStorage(@utf8InCpp String fromVolId, @utf8InCpp String toVolId,
|
|
IVoldTaskListener listener);
|
|
|
|
void remountUid(int uid, int remountMode);
|
|
void remountAppStorageDirs(int uid, int pid, in @utf8InCpp String[] packageNames);
|
|
|
|
void setupAppDir(@utf8InCpp String path, int appUid);
|
|
void fixupAppDir(@utf8InCpp String path, int appUid);
|
|
|
|
@utf8InCpp String createObb(@utf8InCpp String sourcePath, @utf8InCpp String sourceKey,
|
|
int ownerGid);
|
|
void destroyObb(@utf8InCpp String volId);
|
|
|
|
void fstrim(int fstrimFlags, IVoldTaskListener listener);
|
|
void runIdleMaint(IVoldTaskListener listener);
|
|
void abortIdleMaint(IVoldTaskListener listener);
|
|
|
|
FileDescriptor mountAppFuse(int uid, int mountId);
|
|
void unmountAppFuse(int uid, int mountId);
|
|
|
|
void fdeCheckPassword(@utf8InCpp String password);
|
|
void fdeRestart();
|
|
int fdeComplete();
|
|
void fdeEnable(int passwordType, @utf8InCpp String password, int encryptionFlags);
|
|
void fdeChangePassword(int passwordType, @utf8InCpp String password);
|
|
void fdeVerifyPassword(@utf8InCpp String password);
|
|
@utf8InCpp String fdeGetField(@utf8InCpp String key);
|
|
void fdeSetField(@utf8InCpp String key, @utf8InCpp String value);
|
|
int fdeGetPasswordType();
|
|
@utf8InCpp String fdeGetPassword();
|
|
void fdeClearPassword();
|
|
|
|
void fbeEnable();
|
|
|
|
void mountDefaultEncrypted();
|
|
void initUser0();
|
|
boolean isConvertibleToFbe();
|
|
void mountFstab(@utf8InCpp String blkDevice, @utf8InCpp String mountPoint);
|
|
void encryptFstab(@utf8InCpp String blkDevice, @utf8InCpp String mountPoint);
|
|
|
|
void createUserKey(int userId, int userSerial, boolean ephemeral);
|
|
void destroyUserKey(int userId);
|
|
|
|
void addUserKeyAuth(int userId, int userSerial, @utf8InCpp String token,
|
|
@utf8InCpp String secret);
|
|
void clearUserKeyAuth(int userId, int userSerial, @utf8InCpp String token,
|
|
@utf8InCpp String secret);
|
|
void fixateNewestUserKeyAuth(int userId);
|
|
|
|
void unlockUserKey(int userId, int userSerial, @utf8InCpp String token,
|
|
@utf8InCpp String secret);
|
|
void lockUserKey(int userId);
|
|
|
|
void prepareUserStorage(@nullable @utf8InCpp String uuid, int userId, int userSerial,
|
|
int storageFlags);
|
|
void destroyUserStorage(@nullable @utf8InCpp String uuid, int userId, int storageFlags);
|
|
|
|
void prepareSandboxForApp(in @utf8InCpp String packageName, int appId,
|
|
in @utf8InCpp String sandboxId, int userId);
|
|
void destroySandboxForApp(in @utf8InCpp String packageName,
|
|
in @utf8InCpp String sandboxId, int userId);
|
|
|
|
void startCheckpoint(int retry);
|
|
boolean needsCheckpoint();
|
|
boolean needsRollback();
|
|
boolean isCheckpointing();
|
|
void abortChanges(in @utf8InCpp String device, boolean retry);
|
|
void commitChanges();
|
|
void prepareCheckpoint();
|
|
void restoreCheckpoint(@utf8InCpp String device);
|
|
void restoreCheckpointPart(@utf8InCpp String device, int count);
|
|
void markBootAttempt();
|
|
boolean supportsCheckpoint();
|
|
boolean supportsBlockCheckpoint();
|
|
boolean supportsFileCheckpoint();
|
|
void resetCheckpoint();
|
|
|
|
@utf8InCpp String createStubVolume(@utf8InCpp String sourcePath,
|
|
@utf8InCpp String mountPath, @utf8InCpp String fsType,
|
|
@utf8InCpp String fsUuid, @utf8InCpp String fsLabel, int flags);
|
|
void destroyStubVolume(@utf8InCpp String volId);
|
|
|
|
FileDescriptor openAppFuseFile(int uid, int mountId, int fileId, int flags);
|
|
|
|
boolean incFsEnabled();
|
|
IncrementalFileSystemControlParcel mountIncFs(@utf8InCpp String backingPath, @utf8InCpp String targetDir, int flags);
|
|
void unmountIncFs(@utf8InCpp String dir);
|
|
void setIncFsMountOptions(in IncrementalFileSystemControlParcel control, boolean enableReadLogs);
|
|
void bindMount(@utf8InCpp String sourceDir, @utf8InCpp String targetDir);
|
|
|
|
const int ENCRYPTION_FLAG_NO_UI = 4;
|
|
|
|
const int ENCRYPTION_STATE_NONE = 1;
|
|
const int ENCRYPTION_STATE_OK = 0;
|
|
const int ENCRYPTION_STATE_ERROR_UNKNOWN = -1;
|
|
const int ENCRYPTION_STATE_ERROR_INCOMPLETE = -2;
|
|
const int ENCRYPTION_STATE_ERROR_INCONSISTENT = -3;
|
|
const int ENCRYPTION_STATE_ERROR_CORRUPT = -4;
|
|
|
|
const int FSTRIM_FLAG_DEEP_TRIM = 1;
|
|
|
|
const int MOUNT_FLAG_PRIMARY = 1;
|
|
const int MOUNT_FLAG_VISIBLE = 2;
|
|
|
|
const int PARTITION_TYPE_PUBLIC = 0;
|
|
const int PARTITION_TYPE_PRIVATE = 1;
|
|
const int PARTITION_TYPE_MIXED = 2;
|
|
|
|
const int PASSWORD_TYPE_PASSWORD = 0;
|
|
const int PASSWORD_TYPE_DEFAULT = 1;
|
|
const int PASSWORD_TYPE_PATTERN = 2;
|
|
const int PASSWORD_TYPE_PIN = 3;
|
|
|
|
const int STORAGE_FLAG_DE = 1;
|
|
const int STORAGE_FLAG_CE = 2;
|
|
|
|
const int REMOUNT_MODE_NONE = 0;
|
|
const int REMOUNT_MODE_DEFAULT = 1;
|
|
const int REMOUNT_MODE_READ = 2;
|
|
const int REMOUNT_MODE_WRITE = 3;
|
|
const int REMOUNT_MODE_LEGACY = 4;
|
|
const int REMOUNT_MODE_INSTALLER = 5;
|
|
const int REMOUNT_MODE_FULL = 6;
|
|
const int REMOUNT_MODE_PASS_THROUGH = 7;
|
|
const int REMOUNT_MODE_ANDROID_WRITABLE = 8;
|
|
|
|
const int VOLUME_STATE_UNMOUNTED = 0;
|
|
const int VOLUME_STATE_CHECKING = 1;
|
|
const int VOLUME_STATE_MOUNTED = 2;
|
|
const int VOLUME_STATE_MOUNTED_READ_ONLY = 3;
|
|
const int VOLUME_STATE_FORMATTING = 4;
|
|
const int VOLUME_STATE_EJECTING = 5;
|
|
const int VOLUME_STATE_UNMOUNTABLE = 6;
|
|
const int VOLUME_STATE_REMOVED = 7;
|
|
const int VOLUME_STATE_BAD_REMOVAL = 8;
|
|
|
|
const int VOLUME_TYPE_PUBLIC = 0;
|
|
const int VOLUME_TYPE_PRIVATE = 1;
|
|
const int VOLUME_TYPE_EMULATED = 2;
|
|
const int VOLUME_TYPE_ASEC = 3;
|
|
const int VOLUME_TYPE_OBB = 4;
|
|
const int VOLUME_TYPE_STUB = 5;
|
|
}
|