/* * 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 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(); 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; }