IMountService.java revision 9756d75ec28844f5ca30fda786a117c1a0ee88da
1/*
2 * Copyright (C) 2010 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.storage;
18
19import android.content.pm.IPackageMoveObserver;
20import android.os.Binder;
21import android.os.IBinder;
22import android.os.IInterface;
23import android.os.Parcel;
24import android.os.RemoteException;
25
26/**
27 * WARNING! Update IMountService.h and IMountService.cpp if you change this
28 * file. In particular, the ordering of the methods below must match the
29 * _TRANSACTION enum in IMountService.cpp
30 *
31 * @hide - Applications should use android.os.storage.StorageManager to access
32 *       storage functions.
33 */
34public interface IMountService extends IInterface {
35    /** Local-side IPC implementation stub class. */
36    public static abstract class Stub extends Binder implements IMountService {
37        private static class Proxy implements IMountService {
38            private final IBinder mRemote;
39
40            Proxy(IBinder remote) {
41                mRemote = remote;
42            }
43
44            public IBinder asBinder() {
45                return mRemote;
46            }
47
48            public String getInterfaceDescriptor() {
49                return DESCRIPTOR;
50            }
51
52            /**
53             * Registers an IMountServiceListener for receiving async
54             * notifications.
55             */
56            public void registerListener(IMountServiceListener listener) throws RemoteException {
57                Parcel _data = Parcel.obtain();
58                Parcel _reply = Parcel.obtain();
59                try {
60                    _data.writeInterfaceToken(DESCRIPTOR);
61                    _data.writeStrongBinder((listener != null ? listener.asBinder() : null));
62                    mRemote.transact(Stub.TRANSACTION_registerListener, _data, _reply, 0);
63                    _reply.readException();
64                } finally {
65                    _reply.recycle();
66                    _data.recycle();
67                }
68            }
69
70            /**
71             * Unregisters an IMountServiceListener
72             */
73            public void unregisterListener(IMountServiceListener listener) throws RemoteException {
74                Parcel _data = Parcel.obtain();
75                Parcel _reply = Parcel.obtain();
76                try {
77                    _data.writeInterfaceToken(DESCRIPTOR);
78                    _data.writeStrongBinder((listener != null ? listener.asBinder() : null));
79                    mRemote.transact(Stub.TRANSACTION_unregisterListener, _data, _reply, 0);
80                    _reply.readException();
81                } finally {
82                    _reply.recycle();
83                    _data.recycle();
84                }
85            }
86
87            /**
88             * Returns true if a USB mass storage host is connected
89             */
90            public boolean isUsbMassStorageConnected() throws RemoteException {
91                Parcel _data = Parcel.obtain();
92                Parcel _reply = Parcel.obtain();
93                boolean _result;
94                try {
95                    _data.writeInterfaceToken(DESCRIPTOR);
96                    mRemote.transact(Stub.TRANSACTION_isUsbMassStorageConnected, _data, _reply, 0);
97                    _reply.readException();
98                    _result = 0 != _reply.readInt();
99                } finally {
100                    _reply.recycle();
101                    _data.recycle();
102                }
103                return _result;
104            }
105
106            /**
107             * Enables / disables USB mass storage. The caller should check
108             * actual status of enabling/disabling USB mass storage via
109             * StorageEventListener.
110             */
111            public void setUsbMassStorageEnabled(boolean enable) throws RemoteException {
112                Parcel _data = Parcel.obtain();
113                Parcel _reply = Parcel.obtain();
114                try {
115                    _data.writeInterfaceToken(DESCRIPTOR);
116                    _data.writeInt((enable ? 1 : 0));
117                    mRemote.transact(Stub.TRANSACTION_setUsbMassStorageEnabled, _data, _reply, 0);
118                    _reply.readException();
119                } finally {
120                    _reply.recycle();
121                    _data.recycle();
122                }
123            }
124
125            /**
126             * Returns true if a USB mass storage host is enabled (media is
127             * shared)
128             */
129            public boolean isUsbMassStorageEnabled() throws RemoteException {
130                Parcel _data = Parcel.obtain();
131                Parcel _reply = Parcel.obtain();
132                boolean _result;
133                try {
134                    _data.writeInterfaceToken(DESCRIPTOR);
135                    mRemote.transact(Stub.TRANSACTION_isUsbMassStorageEnabled, _data, _reply, 0);
136                    _reply.readException();
137                    _result = 0 != _reply.readInt();
138                } finally {
139                    _reply.recycle();
140                    _data.recycle();
141                }
142                return _result;
143            }
144
145            /**
146             * Mount external storage at given mount point. Returns an int
147             * consistent with MountServiceResultCode
148             */
149            public int mountVolume(String mountPoint) throws RemoteException {
150                Parcel _data = Parcel.obtain();
151                Parcel _reply = Parcel.obtain();
152                int _result;
153                try {
154                    _data.writeInterfaceToken(DESCRIPTOR);
155                    _data.writeString(mountPoint);
156                    mRemote.transact(Stub.TRANSACTION_mountVolume, _data, _reply, 0);
157                    _reply.readException();
158                    _result = _reply.readInt();
159                } finally {
160                    _reply.recycle();
161                    _data.recycle();
162                }
163                return _result;
164            }
165
166            /**
167             * Safely unmount external storage at given mount point. The unmount
168             * is an asynchronous operation. Applications should register
169             * StorageEventListener for storage related status changes.
170             */
171            public void unmountVolume(String mountPoint, boolean force, boolean removeEncryption)
172                    throws RemoteException {
173                Parcel _data = Parcel.obtain();
174                Parcel _reply = Parcel.obtain();
175                try {
176                    _data.writeInterfaceToken(DESCRIPTOR);
177                    _data.writeString(mountPoint);
178                    _data.writeInt((force ? 1 : 0));
179                    _data.writeInt((removeEncryption ? 1 : 0));
180                    mRemote.transact(Stub.TRANSACTION_unmountVolume, _data, _reply, 0);
181                    _reply.readException();
182                } finally {
183                    _reply.recycle();
184                    _data.recycle();
185                }
186            }
187
188            /**
189             * Format external storage given a mount point. Returns an int
190             * consistent with MountServiceResultCode
191             */
192            public int formatVolume(String mountPoint) throws RemoteException {
193                Parcel _data = Parcel.obtain();
194                Parcel _reply = Parcel.obtain();
195                int _result;
196                try {
197                    _data.writeInterfaceToken(DESCRIPTOR);
198                    _data.writeString(mountPoint);
199                    mRemote.transact(Stub.TRANSACTION_formatVolume, _data, _reply, 0);
200                    _reply.readException();
201                    _result = _reply.readInt();
202                } finally {
203                    _reply.recycle();
204                    _data.recycle();
205                }
206                return _result;
207            }
208
209            /**
210             * Returns an array of pids with open files on the specified path.
211             */
212            public int[] getStorageUsers(String path) throws RemoteException {
213                Parcel _data = Parcel.obtain();
214                Parcel _reply = Parcel.obtain();
215                int[] _result;
216                try {
217                    _data.writeInterfaceToken(DESCRIPTOR);
218                    _data.writeString(path);
219                    mRemote.transact(Stub.TRANSACTION_getStorageUsers, _data, _reply, 0);
220                    _reply.readException();
221                    _result = _reply.createIntArray();
222                } finally {
223                    _reply.recycle();
224                    _data.recycle();
225                }
226                return _result;
227            }
228
229            /**
230             * Gets the state of a volume via its mountpoint.
231             */
232            public String getVolumeState(String mountPoint) throws RemoteException {
233                Parcel _data = Parcel.obtain();
234                Parcel _reply = Parcel.obtain();
235                String _result;
236                try {
237                    _data.writeInterfaceToken(DESCRIPTOR);
238                    _data.writeString(mountPoint);
239                    mRemote.transact(Stub.TRANSACTION_getVolumeState, _data, _reply, 0);
240                    _reply.readException();
241                    _result = _reply.readString();
242                } finally {
243                    _reply.recycle();
244                    _data.recycle();
245                }
246                return _result;
247            }
248
249            /*
250             * Creates a secure container with the specified parameters. Returns
251             * an int consistent with MountServiceResultCode
252             */
253            public int createSecureContainer(String id, int sizeMb, String fstype, String key,
254                    int ownerUid, boolean external) throws RemoteException {
255                Parcel _data = Parcel.obtain();
256                Parcel _reply = Parcel.obtain();
257                int _result;
258                try {
259                    _data.writeInterfaceToken(DESCRIPTOR);
260                    _data.writeString(id);
261                    _data.writeInt(sizeMb);
262                    _data.writeString(fstype);
263                    _data.writeString(key);
264                    _data.writeInt(ownerUid);
265                    _data.writeInt(external ? 1 : 0);
266                    mRemote.transact(Stub.TRANSACTION_createSecureContainer, _data, _reply, 0);
267                    _reply.readException();
268                    _result = _reply.readInt();
269                } finally {
270                    _reply.recycle();
271                    _data.recycle();
272                }
273                return _result;
274            }
275
276            /*
277             * Destroy a secure container, and free up all resources associated
278             * with it. NOTE: Ensure all references are released prior to
279             * deleting. Returns an int consistent with MountServiceResultCode
280             */
281            public int destroySecureContainer(String id, boolean force) throws RemoteException {
282                Parcel _data = Parcel.obtain();
283                Parcel _reply = Parcel.obtain();
284                int _result;
285                try {
286                    _data.writeInterfaceToken(DESCRIPTOR);
287                    _data.writeString(id);
288                    _data.writeInt((force ? 1 : 0));
289                    mRemote.transact(Stub.TRANSACTION_destroySecureContainer, _data, _reply, 0);
290                    _reply.readException();
291                    _result = _reply.readInt();
292                } finally {
293                    _reply.recycle();
294                    _data.recycle();
295                }
296                return _result;
297            }
298
299            /*
300             * Finalize a container which has just been created and populated.
301             * After finalization, the container is immutable. Returns an int
302             * consistent with MountServiceResultCode
303             */
304            public int finalizeSecureContainer(String id) throws RemoteException {
305                Parcel _data = Parcel.obtain();
306                Parcel _reply = Parcel.obtain();
307                int _result;
308                try {
309                    _data.writeInterfaceToken(DESCRIPTOR);
310                    _data.writeString(id);
311                    mRemote.transact(Stub.TRANSACTION_finalizeSecureContainer, _data, _reply, 0);
312                    _reply.readException();
313                    _result = _reply.readInt();
314                } finally {
315                    _reply.recycle();
316                    _data.recycle();
317                }
318                return _result;
319            }
320
321            /*
322             * Mount a secure container with the specified key and owner UID.
323             * Returns an int consistent with MountServiceResultCode
324             */
325            public int mountSecureContainer(String id, String key, int ownerUid, boolean readOnly)
326                    throws RemoteException {
327                Parcel _data = Parcel.obtain();
328                Parcel _reply = Parcel.obtain();
329                int _result;
330                try {
331                    _data.writeInterfaceToken(DESCRIPTOR);
332                    _data.writeString(id);
333                    _data.writeString(key);
334                    _data.writeInt(ownerUid);
335                    _data.writeInt(readOnly ? 1 : 0);
336                    mRemote.transact(Stub.TRANSACTION_mountSecureContainer, _data, _reply, 0);
337                    _reply.readException();
338                    _result = _reply.readInt();
339                } finally {
340                    _reply.recycle();
341                    _data.recycle();
342                }
343                return _result;
344            }
345
346            /*
347             * Unount a secure container. Returns an int consistent with
348             * MountServiceResultCode
349             */
350            public int unmountSecureContainer(String id, boolean force) throws RemoteException {
351                Parcel _data = Parcel.obtain();
352                Parcel _reply = Parcel.obtain();
353                int _result;
354                try {
355                    _data.writeInterfaceToken(DESCRIPTOR);
356                    _data.writeString(id);
357                    _data.writeInt((force ? 1 : 0));
358                    mRemote.transact(Stub.TRANSACTION_unmountSecureContainer, _data, _reply, 0);
359                    _reply.readException();
360                    _result = _reply.readInt();
361                } finally {
362                    _reply.recycle();
363                    _data.recycle();
364                }
365                return _result;
366            }
367
368            /*
369             * Returns true if the specified container is mounted
370             */
371            public boolean isSecureContainerMounted(String id) throws RemoteException {
372                Parcel _data = Parcel.obtain();
373                Parcel _reply = Parcel.obtain();
374                boolean _result;
375                try {
376                    _data.writeInterfaceToken(DESCRIPTOR);
377                    _data.writeString(id);
378                    mRemote.transact(Stub.TRANSACTION_isSecureContainerMounted, _data, _reply, 0);
379                    _reply.readException();
380                    _result = 0 != _reply.readInt();
381                } finally {
382                    _reply.recycle();
383                    _data.recycle();
384                }
385                return _result;
386            }
387
388            /*
389             * Rename an unmounted secure container. Returns an int consistent
390             * with MountServiceResultCode
391             */
392            public int renameSecureContainer(String oldId, String newId) throws RemoteException {
393                Parcel _data = Parcel.obtain();
394                Parcel _reply = Parcel.obtain();
395                int _result;
396                try {
397                    _data.writeInterfaceToken(DESCRIPTOR);
398                    _data.writeString(oldId);
399                    _data.writeString(newId);
400                    mRemote.transact(Stub.TRANSACTION_renameSecureContainer, _data, _reply, 0);
401                    _reply.readException();
402                    _result = _reply.readInt();
403                } finally {
404                    _reply.recycle();
405                    _data.recycle();
406                }
407                return _result;
408            }
409
410            /*
411             * Returns the filesystem path of a mounted secure container.
412             */
413            public String getSecureContainerPath(String id) throws RemoteException {
414                Parcel _data = Parcel.obtain();
415                Parcel _reply = Parcel.obtain();
416                String _result;
417                try {
418                    _data.writeInterfaceToken(DESCRIPTOR);
419                    _data.writeString(id);
420                    mRemote.transact(Stub.TRANSACTION_getSecureContainerPath, _data, _reply, 0);
421                    _reply.readException();
422                    _result = _reply.readString();
423                } finally {
424                    _reply.recycle();
425                    _data.recycle();
426                }
427                return _result;
428            }
429
430            /**
431             * Gets an Array of currently known secure container IDs
432             */
433            public String[] getSecureContainerList() throws RemoteException {
434                Parcel _data = Parcel.obtain();
435                Parcel _reply = Parcel.obtain();
436                String[] _result;
437                try {
438                    _data.writeInterfaceToken(DESCRIPTOR);
439                    mRemote.transact(Stub.TRANSACTION_getSecureContainerList, _data, _reply, 0);
440                    _reply.readException();
441                    _result = _reply.createStringArray();
442                } finally {
443                    _reply.recycle();
444                    _data.recycle();
445                }
446                return _result;
447            }
448
449            /**
450             * Shuts down the MountService and gracefully unmounts all external
451             * media. Invokes call back once the shutdown is complete.
452             */
453            public void shutdown(IMountShutdownObserver observer)
454                    throws RemoteException {
455                Parcel _data = Parcel.obtain();
456                Parcel _reply = Parcel.obtain();
457                try {
458                    _data.writeInterfaceToken(DESCRIPTOR);
459                    _data.writeStrongBinder((observer != null ? observer.asBinder() : null));
460                    mRemote.transact(Stub.TRANSACTION_shutdown, _data, _reply, 0);
461                    _reply.readException();
462                } finally {
463                    _reply.recycle();
464                    _data.recycle();
465                }
466            }
467
468            /**
469             * Call into MountService by PackageManager to notify that its done
470             * processing the media status update request.
471             */
472            public void finishMediaUpdate() throws RemoteException {
473                Parcel _data = Parcel.obtain();
474                Parcel _reply = Parcel.obtain();
475                try {
476                    _data.writeInterfaceToken(DESCRIPTOR);
477                    mRemote.transact(Stub.TRANSACTION_finishMediaUpdate, _data, _reply, 0);
478                    _reply.readException();
479                } finally {
480                    _reply.recycle();
481                    _data.recycle();
482                }
483            }
484
485            /**
486             * Mounts an Opaque Binary Blob (OBB) with the specified decryption
487             * key and only allows the calling process's UID access to the
488             * contents. MountService will call back to the supplied
489             * IObbActionListener to inform it of the terminal state of the
490             * call.
491             */
492            public void mountObb(String rawPath, String canonicalPath, String key,
493                    IObbActionListener token, int nonce) throws RemoteException {
494                Parcel _data = Parcel.obtain();
495                Parcel _reply = Parcel.obtain();
496                try {
497                    _data.writeInterfaceToken(DESCRIPTOR);
498                    _data.writeString(rawPath);
499                    _data.writeString(canonicalPath);
500                    _data.writeString(key);
501                    _data.writeStrongBinder((token != null ? token.asBinder() : null));
502                    _data.writeInt(nonce);
503                    mRemote.transact(Stub.TRANSACTION_mountObb, _data, _reply, 0);
504                    _reply.readException();
505                } finally {
506                    _reply.recycle();
507                    _data.recycle();
508                }
509            }
510
511            /**
512             * Unmounts an Opaque Binary Blob (OBB). When the force flag is
513             * specified, any program using it will be forcibly killed to
514             * unmount the image. MountService will call back to the supplied
515             * IObbActionListener to inform it of the terminal state of the
516             * call.
517             */
518            public void unmountObb(
519                    String rawPath, boolean force, IObbActionListener token, int nonce)
520                    throws RemoteException {
521                Parcel _data = Parcel.obtain();
522                Parcel _reply = Parcel.obtain();
523                try {
524                    _data.writeInterfaceToken(DESCRIPTOR);
525                    _data.writeString(rawPath);
526                    _data.writeInt((force ? 1 : 0));
527                    _data.writeStrongBinder((token != null ? token.asBinder() : null));
528                    _data.writeInt(nonce);
529                    mRemote.transact(Stub.TRANSACTION_unmountObb, _data, _reply, 0);
530                    _reply.readException();
531                } finally {
532                    _reply.recycle();
533                    _data.recycle();
534                }
535            }
536
537            /**
538             * Checks whether the specified Opaque Binary Blob (OBB) is mounted
539             * somewhere.
540             */
541            public boolean isObbMounted(String rawPath) throws RemoteException {
542                Parcel _data = Parcel.obtain();
543                Parcel _reply = Parcel.obtain();
544                boolean _result;
545                try {
546                    _data.writeInterfaceToken(DESCRIPTOR);
547                    _data.writeString(rawPath);
548                    mRemote.transact(Stub.TRANSACTION_isObbMounted, _data, _reply, 0);
549                    _reply.readException();
550                    _result = 0 != _reply.readInt();
551                } finally {
552                    _reply.recycle();
553                    _data.recycle();
554                }
555                return _result;
556            }
557
558            /**
559             * Gets the path to the mounted Opaque Binary Blob (OBB).
560             */
561            public String getMountedObbPath(String rawPath) throws RemoteException {
562                Parcel _data = Parcel.obtain();
563                Parcel _reply = Parcel.obtain();
564                String _result;
565                try {
566                    _data.writeInterfaceToken(DESCRIPTOR);
567                    _data.writeString(rawPath);
568                    mRemote.transact(Stub.TRANSACTION_getMountedObbPath, _data, _reply, 0);
569                    _reply.readException();
570                    _result = _reply.readString();
571                } finally {
572                    _reply.recycle();
573                    _data.recycle();
574                }
575                return _result;
576            }
577
578            /**
579             * Returns whether the external storage is emulated.
580             */
581            public boolean isExternalStorageEmulated() throws RemoteException {
582                Parcel _data = Parcel.obtain();
583                Parcel _reply = Parcel.obtain();
584                boolean _result;
585                try {
586                    _data.writeInterfaceToken(DESCRIPTOR);
587                    mRemote.transact(Stub.TRANSACTION_isExternalStorageEmulated, _data, _reply, 0);
588                    _reply.readException();
589                    _result = 0 != _reply.readInt();
590                } finally {
591                    _reply.recycle();
592                    _data.recycle();
593                }
594                return _result;
595            }
596
597            public int getEncryptionState() throws RemoteException {
598                Parcel _data = Parcel.obtain();
599                Parcel _reply = Parcel.obtain();
600                int _result;
601                try {
602                    _data.writeInterfaceToken(DESCRIPTOR);
603                    mRemote.transact(Stub.TRANSACTION_getEncryptionState, _data, _reply, 0);
604                    _reply.readException();
605                    _result = _reply.readInt();
606                } finally {
607                    _reply.recycle();
608                    _data.recycle();
609                }
610                return _result;
611            }
612
613            public int decryptStorage(String password) throws RemoteException {
614                Parcel _data = Parcel.obtain();
615                Parcel _reply = Parcel.obtain();
616                int _result;
617                try {
618                    _data.writeInterfaceToken(DESCRIPTOR);
619                    _data.writeString(password);
620                    mRemote.transact(Stub.TRANSACTION_decryptStorage, _data, _reply, 0);
621                    _reply.readException();
622                    _result = _reply.readInt();
623                } finally {
624                    _reply.recycle();
625                    _data.recycle();
626                }
627                return _result;
628            }
629
630            public int encryptStorage(int type, String password) throws RemoteException {
631                Parcel _data = Parcel.obtain();
632                Parcel _reply = Parcel.obtain();
633                int _result;
634                try {
635                    _data.writeInterfaceToken(DESCRIPTOR);
636                    _data.writeInt(type);
637                    _data.writeString(password);
638                    mRemote.transact(Stub.TRANSACTION_encryptStorage, _data, _reply, 0);
639                    _reply.readException();
640                    _result = _reply.readInt();
641                } finally {
642                    _reply.recycle();
643                    _data.recycle();
644                }
645                return _result;
646            }
647
648            public int changeEncryptionPassword(int type, String password) throws RemoteException {
649                Parcel _data = Parcel.obtain();
650                Parcel _reply = Parcel.obtain();
651                int _result;
652                try {
653                    _data.writeInterfaceToken(DESCRIPTOR);
654                    _data.writeInt(type);
655                    _data.writeString(password);
656                    mRemote.transact(Stub.TRANSACTION_changeEncryptionPassword, _data, _reply, 0);
657                    _reply.readException();
658                    _result = _reply.readInt();
659                } finally {
660                    _reply.recycle();
661                    _data.recycle();
662                }
663                return _result;
664            }
665
666            @Override
667            public int verifyEncryptionPassword(String password) throws RemoteException {
668                Parcel _data = Parcel.obtain();
669                Parcel _reply = Parcel.obtain();
670                int _result;
671                try {
672                    _data.writeInterfaceToken(DESCRIPTOR);
673                    _data.writeString(password);
674                    mRemote.transact(Stub.TRANSACTION_verifyEncryptionPassword, _data, _reply, 0);
675                    _reply.readException();
676                    _result = _reply.readInt();
677                } finally {
678                    _reply.recycle();
679                    _data.recycle();
680                }
681                return _result;
682            }
683
684            public int getPasswordType() throws RemoteException {
685                Parcel _data = Parcel.obtain();
686                Parcel _reply = Parcel.obtain();
687                int _result;
688                try {
689                    _data.writeInterfaceToken(DESCRIPTOR);
690                    mRemote.transact(Stub.TRANSACTION_getPasswordType, _data, _reply, 0);
691                    _reply.readException();
692                    _result = _reply.readInt();
693                } finally {
694                    _reply.recycle();
695                    _data.recycle();
696                }
697                return _result;
698            }
699
700            public String getPassword() throws RemoteException {
701                Parcel _data = Parcel.obtain();
702                Parcel _reply = Parcel.obtain();
703                String _result;
704                try {
705                    _data.writeInterfaceToken(DESCRIPTOR);
706                    mRemote.transact(Stub.TRANSACTION_getPassword, _data, _reply, 0);
707                    _reply.readException();
708                    _result = _reply.readString();
709                } finally {
710                    _reply.recycle();
711                    _data.recycle();
712                }
713                return _result;
714            }
715
716            public void clearPassword() throws RemoteException {
717                Parcel _data = Parcel.obtain();
718                Parcel _reply = Parcel.obtain();
719                try {
720                    _data.writeInterfaceToken(DESCRIPTOR);
721                    mRemote.transact(Stub.TRANSACTION_clearPassword, _data, _reply, IBinder.FLAG_ONEWAY);
722                    _reply.readException();
723                } finally {
724                    _reply.recycle();
725                    _data.recycle();
726                }
727            }
728
729            public void setField(String field, String data) throws RemoteException {
730                Parcel _data = Parcel.obtain();
731                Parcel _reply = Parcel.obtain();
732                try {
733                    _data.writeInterfaceToken(DESCRIPTOR);
734                    _data.writeString(field);
735                    _data.writeString(data);
736                    mRemote.transact(Stub.TRANSACTION_setField, _data, _reply, IBinder.FLAG_ONEWAY);
737                    _reply.readException();
738                } finally {
739                    _reply.recycle();
740                    _data.recycle();
741                }
742            }
743
744            public String getField(String field) throws RemoteException {
745                Parcel _data = Parcel.obtain();
746                Parcel _reply = Parcel.obtain();
747                String _result;
748                try {
749                    _data.writeInterfaceToken(DESCRIPTOR);
750                    _data.writeString(field);
751                    mRemote.transact(Stub.TRANSACTION_getField, _data, _reply, 0);
752                    _reply.readException();
753                    _result = _reply.readString();
754                } finally {
755                    _reply.recycle();
756                    _data.recycle();
757                }
758                return _result;
759            }
760
761            public StorageVolume[] getVolumeList(int userId) throws RemoteException {
762                Parcel _data = Parcel.obtain();
763                Parcel _reply = Parcel.obtain();
764                StorageVolume[] _result;
765                try {
766                    _data.writeInterfaceToken(DESCRIPTOR);
767                    _data.writeInt(userId);
768                    mRemote.transact(Stub.TRANSACTION_getVolumeList, _data, _reply, 0);
769                    _reply.readException();
770                    _result = _reply.createTypedArray(StorageVolume.CREATOR);
771                } finally {
772                    _reply.recycle();
773                    _data.recycle();
774                }
775                return _result;
776            }
777
778            /*
779             * Returns the filesystem path of a mounted secure container.
780             */
781            public String getSecureContainerFilesystemPath(String id) throws RemoteException {
782                Parcel _data = Parcel.obtain();
783                Parcel _reply = Parcel.obtain();
784                String _result;
785                try {
786                    _data.writeInterfaceToken(DESCRIPTOR);
787                    _data.writeString(id);
788                    mRemote.transact(Stub.TRANSACTION_getSecureContainerFilesystemPath, _data, _reply, 0);
789                    _reply.readException();
790                    _result = _reply.readString();
791                } finally {
792                    _reply.recycle();
793                    _data.recycle();
794                }
795                return _result;
796            }
797
798            /**
799             * Fix permissions in a container which has just been created and
800             * populated. Returns an int consistent with MountServiceResultCode
801             */
802            public int fixPermissionsSecureContainer(String id, int gid, String filename)
803                    throws RemoteException {
804                Parcel _data = Parcel.obtain();
805                Parcel _reply = Parcel.obtain();
806                int _result;
807                try {
808                    _data.writeInterfaceToken(DESCRIPTOR);
809                    _data.writeString(id);
810                    _data.writeInt(gid);
811                    _data.writeString(filename);
812                    mRemote.transact(Stub.TRANSACTION_fixPermissionsSecureContainer, _data, _reply, 0);
813                    _reply.readException();
814                    _result = _reply.readInt();
815                } finally {
816                    _reply.recycle();
817                    _data.recycle();
818                }
819                return _result;
820            }
821
822            @Override
823            public int mkdirs(String callingPkg, String path) throws RemoteException {
824                Parcel _data = Parcel.obtain();
825                Parcel _reply = Parcel.obtain();
826                int _result;
827                try {
828                    _data.writeInterfaceToken(DESCRIPTOR);
829                    _data.writeString(callingPkg);
830                    _data.writeString(path);
831                    mRemote.transact(Stub.TRANSACTION_mkdirs, _data, _reply, 0);
832                    _reply.readException();
833                    _result = _reply.readInt();
834                } finally {
835                    _reply.recycle();
836                    _data.recycle();
837                }
838                return _result;
839            }
840
841            @Override
842            public int resizeSecureContainer(String id, int sizeMb, String key)
843                    throws RemoteException {
844                Parcel _data = Parcel.obtain();
845                Parcel _reply = Parcel.obtain();
846                int _result;
847                try {
848                    _data.writeInterfaceToken(DESCRIPTOR);
849                    _data.writeString(id);
850                    _data.writeInt(sizeMb);
851                    _data.writeString(key);
852                    mRemote.transact(Stub.TRANSACTION_resizeSecureContainer, _data, _reply, 0);
853                    _reply.readException();
854                    _result = _reply.readInt();
855                } finally {
856                    _reply.recycle();
857                    _data.recycle();
858                }
859                return _result;
860            }
861
862            @Override
863            public long lastMaintenance() throws RemoteException {
864                Parcel _data = Parcel.obtain();
865                Parcel _reply = Parcel.obtain();
866                long _result;
867                try {
868                    _data.writeInterfaceToken(DESCRIPTOR);
869                    mRemote.transact(Stub.TRANSACTION_lastMaintenance, _data, _reply, 0);
870                    _reply.readException();
871                    _result = _reply.readLong();
872                } finally {
873                    _reply.recycle();
874                    _data.recycle();
875                }
876                return _result;
877            }
878
879            @Override
880            public void runMaintenance() throws RemoteException {
881                Parcel _data = Parcel.obtain();
882                Parcel _reply = Parcel.obtain();
883                try {
884                    _data.writeInterfaceToken(DESCRIPTOR);
885                    mRemote.transact(Stub.TRANSACTION_runMaintenance, _data, _reply, 0);
886                    _reply.readException();
887                } finally {
888                    _reply.recycle();
889                    _data.recycle();
890                }
891                return;
892            }
893
894            @Override
895            public void waitForAsecScan() throws RemoteException {
896                Parcel _data = Parcel.obtain();
897                Parcel _reply = Parcel.obtain();
898                try {
899                    _data.writeInterfaceToken(DESCRIPTOR);
900                    mRemote.transact(Stub.TRANSACTION_waitForAsecScan, _data, _reply, 0);
901                    _reply.readException();
902                } finally {
903                    _reply.recycle();
904                    _data.recycle();
905                }
906                return;
907            }
908
909            @Override
910            public DiskInfo[] getDisks() throws RemoteException {
911                Parcel _data = Parcel.obtain();
912                Parcel _reply = Parcel.obtain();
913                DiskInfo[] _result;
914                try {
915                    _data.writeInterfaceToken(DESCRIPTOR);
916                    mRemote.transact(Stub.TRANSACTION_getDisks, _data, _reply, 0);
917                    _reply.readException();
918                    _result = _reply.createTypedArray(DiskInfo.CREATOR);
919                } finally {
920                    _reply.recycle();
921                    _data.recycle();
922                }
923                return _result;
924            }
925
926            @Override
927            public VolumeInfo[] getVolumes(int _flags) throws RemoteException {
928                Parcel _data = Parcel.obtain();
929                Parcel _reply = Parcel.obtain();
930                VolumeInfo[] _result;
931                try {
932                    _data.writeInterfaceToken(DESCRIPTOR);
933                    _data.writeInt(_flags);
934                    mRemote.transact(Stub.TRANSACTION_getVolumes, _data, _reply, 0);
935                    _reply.readException();
936                    _result = _reply.createTypedArray(VolumeInfo.CREATOR);
937                } finally {
938                    _reply.recycle();
939                    _data.recycle();
940                }
941                return _result;
942            }
943
944            @Override
945            public VolumeRecord[] getVolumeRecords(int _flags) throws RemoteException {
946                Parcel _data = Parcel.obtain();
947                Parcel _reply = Parcel.obtain();
948                VolumeRecord[] _result;
949                try {
950                    _data.writeInterfaceToken(DESCRIPTOR);
951                    _data.writeInt(_flags);
952                    mRemote.transact(Stub.TRANSACTION_getVolumeRecords, _data, _reply, 0);
953                    _reply.readException();
954                    _result = _reply.createTypedArray(VolumeRecord.CREATOR);
955                } finally {
956                    _reply.recycle();
957                    _data.recycle();
958                }
959                return _result;
960            }
961
962            @Override
963            public void mount(String volId) throws RemoteException {
964                Parcel _data = Parcel.obtain();
965                Parcel _reply = Parcel.obtain();
966                try {
967                    _data.writeInterfaceToken(DESCRIPTOR);
968                    _data.writeString(volId);
969                    mRemote.transact(Stub.TRANSACTION_mount, _data, _reply, 0);
970                    _reply.readException();
971                } finally {
972                    _reply.recycle();
973                    _data.recycle();
974                }
975            }
976
977            @Override
978            public void unmount(String volId) throws RemoteException {
979                Parcel _data = Parcel.obtain();
980                Parcel _reply = Parcel.obtain();
981                try {
982                    _data.writeInterfaceToken(DESCRIPTOR);
983                    _data.writeString(volId);
984                    mRemote.transact(Stub.TRANSACTION_unmount, _data, _reply, 0);
985                    _reply.readException();
986                } finally {
987                    _reply.recycle();
988                    _data.recycle();
989                }
990            }
991
992            @Override
993            public void format(String volId) throws RemoteException {
994                Parcel _data = Parcel.obtain();
995                Parcel _reply = Parcel.obtain();
996                try {
997                    _data.writeInterfaceToken(DESCRIPTOR);
998                    _data.writeString(volId);
999                    mRemote.transact(Stub.TRANSACTION_format, _data, _reply, 0);
1000                    _reply.readException();
1001                } finally {
1002                    _reply.recycle();
1003                    _data.recycle();
1004                }
1005            }
1006
1007            @Override
1008            public long benchmark(String volId) throws RemoteException {
1009                Parcel _data = Parcel.obtain();
1010                Parcel _reply = Parcel.obtain();
1011                try {
1012                    _data.writeInterfaceToken(DESCRIPTOR);
1013                    _data.writeString(volId);
1014                    mRemote.transact(Stub.TRANSACTION_benchmark, _data, _reply, 0);
1015                    _reply.readException();
1016                    return _reply.readLong();
1017                } finally {
1018                    _reply.recycle();
1019                    _data.recycle();
1020                }
1021            }
1022
1023            @Override
1024            public void partitionPublic(String diskId) throws RemoteException {
1025                Parcel _data = Parcel.obtain();
1026                Parcel _reply = Parcel.obtain();
1027                try {
1028                    _data.writeInterfaceToken(DESCRIPTOR);
1029                    _data.writeString(diskId);
1030                    mRemote.transact(Stub.TRANSACTION_partitionPublic, _data, _reply, 0);
1031                    _reply.readException();
1032                } finally {
1033                    _reply.recycle();
1034                    _data.recycle();
1035                }
1036            }
1037
1038            @Override
1039            public void partitionPrivate(String diskId) throws RemoteException {
1040                Parcel _data = Parcel.obtain();
1041                Parcel _reply = Parcel.obtain();
1042                try {
1043                    _data.writeInterfaceToken(DESCRIPTOR);
1044                    _data.writeString(diskId);
1045                    mRemote.transact(Stub.TRANSACTION_partitionPrivate, _data, _reply, 0);
1046                    _reply.readException();
1047                } finally {
1048                    _reply.recycle();
1049                    _data.recycle();
1050                }
1051            }
1052
1053            @Override
1054            public void partitionMixed(String diskId, int ratio) throws RemoteException {
1055                Parcel _data = Parcel.obtain();
1056                Parcel _reply = Parcel.obtain();
1057                try {
1058                    _data.writeInterfaceToken(DESCRIPTOR);
1059                    _data.writeString(diskId);
1060                    _data.writeInt(ratio);
1061                    mRemote.transact(Stub.TRANSACTION_partitionMixed, _data, _reply, 0);
1062                    _reply.readException();
1063                } finally {
1064                    _reply.recycle();
1065                    _data.recycle();
1066                }
1067            }
1068
1069            @Override
1070            public void setVolumeNickname(String fsUuid, String nickname) throws RemoteException {
1071                Parcel _data = Parcel.obtain();
1072                Parcel _reply = Parcel.obtain();
1073                try {
1074                    _data.writeInterfaceToken(DESCRIPTOR);
1075                    _data.writeString(fsUuid);
1076                    _data.writeString(nickname);
1077                    mRemote.transact(Stub.TRANSACTION_setVolumeNickname, _data, _reply, 0);
1078                    _reply.readException();
1079                } finally {
1080                    _reply.recycle();
1081                    _data.recycle();
1082                }
1083            }
1084
1085            @Override
1086            public void setVolumeUserFlags(String fsUuid, int flags, int mask) throws RemoteException {
1087                Parcel _data = Parcel.obtain();
1088                Parcel _reply = Parcel.obtain();
1089                try {
1090                    _data.writeInterfaceToken(DESCRIPTOR);
1091                    _data.writeString(fsUuid);
1092                    _data.writeInt(flags);
1093                    _data.writeInt(mask);
1094                    mRemote.transact(Stub.TRANSACTION_setVolumeUserFlags, _data, _reply, 0);
1095                    _reply.readException();
1096                } finally {
1097                    _reply.recycle();
1098                    _data.recycle();
1099                }
1100            }
1101
1102            @Override
1103            public void forgetVolume(String fsUuid) throws RemoteException {
1104                Parcel _data = Parcel.obtain();
1105                Parcel _reply = Parcel.obtain();
1106                try {
1107                    _data.writeInterfaceToken(DESCRIPTOR);
1108                    _data.writeString(fsUuid);
1109                    mRemote.transact(Stub.TRANSACTION_forgetVolume, _data, _reply, 0);
1110                    _reply.readException();
1111                } finally {
1112                    _reply.recycle();
1113                    _data.recycle();
1114                }
1115            }
1116
1117            @Override
1118            public void forgetAllVolumes() throws RemoteException {
1119                Parcel _data = Parcel.obtain();
1120                Parcel _reply = Parcel.obtain();
1121                try {
1122                    _data.writeInterfaceToken(DESCRIPTOR);
1123                    mRemote.transact(Stub.TRANSACTION_forgetAllVolumes, _data, _reply, 0);
1124                    _reply.readException();
1125                } finally {
1126                    _reply.recycle();
1127                    _data.recycle();
1128                }
1129            }
1130
1131            @Override
1132            public String getPrimaryStorageUuid() throws RemoteException {
1133                Parcel _data = Parcel.obtain();
1134                Parcel _reply = Parcel.obtain();
1135                String _result;
1136                try {
1137                    _data.writeInterfaceToken(DESCRIPTOR);
1138                    mRemote.transact(Stub.TRANSACTION_getPrimaryStorageUuid, _data, _reply, 0);
1139                    _reply.readException();
1140                    _result = _reply.readString();
1141                } finally {
1142                    _reply.recycle();
1143                    _data.recycle();
1144                }
1145                return _result;
1146            }
1147
1148            @Override
1149            public void setPrimaryStorageUuid(String volumeUuid, IPackageMoveObserver callback)
1150                    throws RemoteException {
1151                Parcel _data = Parcel.obtain();
1152                Parcel _reply = Parcel.obtain();
1153                try {
1154                    _data.writeInterfaceToken(DESCRIPTOR);
1155                    _data.writeString(volumeUuid);
1156                    _data.writeStrongBinder((callback != null ? callback.asBinder() : null));
1157                    mRemote.transact(Stub.TRANSACTION_setPrimaryStorageUuid, _data, _reply, 0);
1158                    _reply.readException();
1159                } finally {
1160                    _reply.recycle();
1161                    _data.recycle();
1162                }
1163            }
1164        }
1165
1166        private static final String DESCRIPTOR = "IMountService";
1167
1168        static final int TRANSACTION_registerListener = IBinder.FIRST_CALL_TRANSACTION + 0;
1169
1170        static final int TRANSACTION_unregisterListener = IBinder.FIRST_CALL_TRANSACTION + 1;
1171
1172        static final int TRANSACTION_isUsbMassStorageConnected = IBinder.FIRST_CALL_TRANSACTION + 2;
1173
1174        static final int TRANSACTION_setUsbMassStorageEnabled = IBinder.FIRST_CALL_TRANSACTION + 3;
1175
1176        static final int TRANSACTION_isUsbMassStorageEnabled = IBinder.FIRST_CALL_TRANSACTION + 4;
1177
1178        static final int TRANSACTION_mountVolume = IBinder.FIRST_CALL_TRANSACTION + 5;
1179
1180        static final int TRANSACTION_unmountVolume = IBinder.FIRST_CALL_TRANSACTION + 6;
1181
1182        static final int TRANSACTION_formatVolume = IBinder.FIRST_CALL_TRANSACTION + 7;
1183
1184        static final int TRANSACTION_getStorageUsers = IBinder.FIRST_CALL_TRANSACTION + 8;
1185
1186        static final int TRANSACTION_getVolumeState = IBinder.FIRST_CALL_TRANSACTION + 9;
1187
1188        static final int TRANSACTION_createSecureContainer = IBinder.FIRST_CALL_TRANSACTION + 10;
1189
1190        static final int TRANSACTION_finalizeSecureContainer = IBinder.FIRST_CALL_TRANSACTION + 11;
1191
1192        static final int TRANSACTION_destroySecureContainer = IBinder.FIRST_CALL_TRANSACTION + 12;
1193
1194        static final int TRANSACTION_mountSecureContainer = IBinder.FIRST_CALL_TRANSACTION + 13;
1195
1196        static final int TRANSACTION_unmountSecureContainer = IBinder.FIRST_CALL_TRANSACTION + 14;
1197
1198        static final int TRANSACTION_isSecureContainerMounted = IBinder.FIRST_CALL_TRANSACTION + 15;
1199
1200        static final int TRANSACTION_renameSecureContainer = IBinder.FIRST_CALL_TRANSACTION + 16;
1201
1202        static final int TRANSACTION_getSecureContainerPath = IBinder.FIRST_CALL_TRANSACTION + 17;
1203
1204        static final int TRANSACTION_getSecureContainerList = IBinder.FIRST_CALL_TRANSACTION + 18;
1205
1206        static final int TRANSACTION_shutdown = IBinder.FIRST_CALL_TRANSACTION + 19;
1207
1208        static final int TRANSACTION_finishMediaUpdate = IBinder.FIRST_CALL_TRANSACTION + 20;
1209
1210        static final int TRANSACTION_mountObb = IBinder.FIRST_CALL_TRANSACTION + 21;
1211
1212        static final int TRANSACTION_unmountObb = IBinder.FIRST_CALL_TRANSACTION + 22;
1213
1214        static final int TRANSACTION_isObbMounted = IBinder.FIRST_CALL_TRANSACTION + 23;
1215
1216        static final int TRANSACTION_getMountedObbPath = IBinder.FIRST_CALL_TRANSACTION + 24;
1217
1218        static final int TRANSACTION_isExternalStorageEmulated = IBinder.FIRST_CALL_TRANSACTION + 25;
1219
1220        static final int TRANSACTION_decryptStorage = IBinder.FIRST_CALL_TRANSACTION + 26;
1221
1222        static final int TRANSACTION_encryptStorage = IBinder.FIRST_CALL_TRANSACTION + 27;
1223
1224        static final int TRANSACTION_changeEncryptionPassword = IBinder.FIRST_CALL_TRANSACTION + 28;
1225
1226        static final int TRANSACTION_getVolumeList = IBinder.FIRST_CALL_TRANSACTION + 29;
1227
1228        static final int TRANSACTION_getSecureContainerFilesystemPath = IBinder.FIRST_CALL_TRANSACTION + 30;
1229
1230        static final int TRANSACTION_getEncryptionState = IBinder.FIRST_CALL_TRANSACTION + 31;
1231
1232        static final int TRANSACTION_verifyEncryptionPassword = IBinder.FIRST_CALL_TRANSACTION + 32;
1233
1234        static final int TRANSACTION_fixPermissionsSecureContainer = IBinder.FIRST_CALL_TRANSACTION + 33;
1235
1236        static final int TRANSACTION_mkdirs = IBinder.FIRST_CALL_TRANSACTION + 34;
1237
1238        static final int TRANSACTION_getPasswordType = IBinder.FIRST_CALL_TRANSACTION + 35;
1239
1240        static final int TRANSACTION_getPassword = IBinder.FIRST_CALL_TRANSACTION + 36;
1241
1242        static final int TRANSACTION_clearPassword = IBinder.FIRST_CALL_TRANSACTION + 37;
1243
1244        static final int TRANSACTION_setField = IBinder.FIRST_CALL_TRANSACTION + 38;
1245
1246        static final int TRANSACTION_getField = IBinder.FIRST_CALL_TRANSACTION + 39;
1247
1248        static final int TRANSACTION_resizeSecureContainer = IBinder.FIRST_CALL_TRANSACTION + 40;
1249
1250        static final int TRANSACTION_lastMaintenance = IBinder.FIRST_CALL_TRANSACTION + 41;
1251
1252        static final int TRANSACTION_runMaintenance = IBinder.FIRST_CALL_TRANSACTION + 42;
1253
1254        static final int TRANSACTION_waitForAsecScan = IBinder.FIRST_CALL_TRANSACTION + 43;
1255
1256        static final int TRANSACTION_getDisks = IBinder.FIRST_CALL_TRANSACTION + 44;
1257        static final int TRANSACTION_getVolumes = IBinder.FIRST_CALL_TRANSACTION + 45;
1258        static final int TRANSACTION_getVolumeRecords = IBinder.FIRST_CALL_TRANSACTION + 46;
1259
1260        static final int TRANSACTION_mount = IBinder.FIRST_CALL_TRANSACTION + 47;
1261        static final int TRANSACTION_unmount = IBinder.FIRST_CALL_TRANSACTION + 48;
1262        static final int TRANSACTION_format = IBinder.FIRST_CALL_TRANSACTION + 49;
1263
1264        static final int TRANSACTION_partitionPublic = IBinder.FIRST_CALL_TRANSACTION + 50;
1265        static final int TRANSACTION_partitionPrivate = IBinder.FIRST_CALL_TRANSACTION + 51;
1266        static final int TRANSACTION_partitionMixed = IBinder.FIRST_CALL_TRANSACTION + 52;
1267
1268        static final int TRANSACTION_setVolumeNickname = IBinder.FIRST_CALL_TRANSACTION + 53;
1269        static final int TRANSACTION_setVolumeUserFlags = IBinder.FIRST_CALL_TRANSACTION + 54;
1270        static final int TRANSACTION_forgetVolume = IBinder.FIRST_CALL_TRANSACTION + 55;
1271        static final int TRANSACTION_forgetAllVolumes = IBinder.FIRST_CALL_TRANSACTION + 56;
1272
1273        static final int TRANSACTION_getPrimaryStorageUuid = IBinder.FIRST_CALL_TRANSACTION + 57;
1274        static final int TRANSACTION_setPrimaryStorageUuid = IBinder.FIRST_CALL_TRANSACTION + 58;
1275
1276        static final int TRANSACTION_benchmark = IBinder.FIRST_CALL_TRANSACTION + 59;
1277
1278        /**
1279         * Cast an IBinder object into an IMountService interface, generating a
1280         * proxy if needed.
1281         */
1282        public static IMountService asInterface(IBinder obj) {
1283            if (obj == null) {
1284                return null;
1285            }
1286            IInterface iin = obj.queryLocalInterface(DESCRIPTOR);
1287            if (iin != null && iin instanceof IMountService) {
1288                return (IMountService) iin;
1289            }
1290            return new IMountService.Stub.Proxy(obj);
1291        }
1292
1293        /** Construct the stub at attach it to the interface. */
1294        public Stub() {
1295            attachInterface(this, DESCRIPTOR);
1296        }
1297
1298        public IBinder asBinder() {
1299            return this;
1300        }
1301
1302        @Override
1303        public boolean onTransact(int code, Parcel data, Parcel reply,
1304                int flags) throws RemoteException {
1305            switch (code) {
1306                case INTERFACE_TRANSACTION: {
1307                    reply.writeString(DESCRIPTOR);
1308                    return true;
1309                }
1310                case TRANSACTION_registerListener: {
1311                    data.enforceInterface(DESCRIPTOR);
1312                    IMountServiceListener listener;
1313                    listener = IMountServiceListener.Stub.asInterface(data.readStrongBinder());
1314                    registerListener(listener);
1315                    reply.writeNoException();
1316                    return true;
1317                }
1318                case TRANSACTION_unregisterListener: {
1319                    data.enforceInterface(DESCRIPTOR);
1320                    IMountServiceListener listener;
1321                    listener = IMountServiceListener.Stub.asInterface(data.readStrongBinder());
1322                    unregisterListener(listener);
1323                    reply.writeNoException();
1324                    return true;
1325                }
1326                case TRANSACTION_isUsbMassStorageConnected: {
1327                    data.enforceInterface(DESCRIPTOR);
1328                    boolean result = isUsbMassStorageConnected();
1329                    reply.writeNoException();
1330                    reply.writeInt((result ? 1 : 0));
1331                    return true;
1332                }
1333                case TRANSACTION_setUsbMassStorageEnabled: {
1334                    data.enforceInterface(DESCRIPTOR);
1335                    boolean enable;
1336                    enable = 0 != data.readInt();
1337                    setUsbMassStorageEnabled(enable);
1338                    reply.writeNoException();
1339                    return true;
1340                }
1341                case TRANSACTION_isUsbMassStorageEnabled: {
1342                    data.enforceInterface(DESCRIPTOR);
1343                    boolean result = isUsbMassStorageEnabled();
1344                    reply.writeNoException();
1345                    reply.writeInt((result ? 1 : 0));
1346                    return true;
1347                }
1348                case TRANSACTION_mountVolume: {
1349                    data.enforceInterface(DESCRIPTOR);
1350                    String mountPoint;
1351                    mountPoint = data.readString();
1352                    int resultCode = mountVolume(mountPoint);
1353                    reply.writeNoException();
1354                    reply.writeInt(resultCode);
1355                    return true;
1356                }
1357                case TRANSACTION_unmountVolume: {
1358                    data.enforceInterface(DESCRIPTOR);
1359                    String mountPoint;
1360                    mountPoint = data.readString();
1361                    boolean force = 0 != data.readInt();
1362                    boolean removeEncrypt = 0 != data.readInt();
1363                    unmountVolume(mountPoint, force, removeEncrypt);
1364                    reply.writeNoException();
1365                    return true;
1366                }
1367                case TRANSACTION_formatVolume: {
1368                    data.enforceInterface(DESCRIPTOR);
1369                    String mountPoint;
1370                    mountPoint = data.readString();
1371                    int result = formatVolume(mountPoint);
1372                    reply.writeNoException();
1373                    reply.writeInt(result);
1374                    return true;
1375                }
1376                case TRANSACTION_getStorageUsers: {
1377                    data.enforceInterface(DESCRIPTOR);
1378                    String path;
1379                    path = data.readString();
1380                    int[] pids = getStorageUsers(path);
1381                    reply.writeNoException();
1382                    reply.writeIntArray(pids);
1383                    return true;
1384                }
1385                case TRANSACTION_getVolumeState: {
1386                    data.enforceInterface(DESCRIPTOR);
1387                    String mountPoint;
1388                    mountPoint = data.readString();
1389                    String state = getVolumeState(mountPoint);
1390                    reply.writeNoException();
1391                    reply.writeString(state);
1392                    return true;
1393                }
1394                case TRANSACTION_createSecureContainer: {
1395                    data.enforceInterface(DESCRIPTOR);
1396                    String id;
1397                    id = data.readString();
1398                    int sizeMb;
1399                    sizeMb = data.readInt();
1400                    String fstype;
1401                    fstype = data.readString();
1402                    String key;
1403                    key = data.readString();
1404                    int ownerUid;
1405                    ownerUid = data.readInt();
1406                    boolean external;
1407                    external = 0 != data.readInt();
1408                    int resultCode = createSecureContainer(id, sizeMb, fstype, key, ownerUid,
1409                            external);
1410                    reply.writeNoException();
1411                    reply.writeInt(resultCode);
1412                    return true;
1413                }
1414                case TRANSACTION_finalizeSecureContainer: {
1415                    data.enforceInterface(DESCRIPTOR);
1416                    String id;
1417                    id = data.readString();
1418                    int resultCode = finalizeSecureContainer(id);
1419                    reply.writeNoException();
1420                    reply.writeInt(resultCode);
1421                    return true;
1422                }
1423                case TRANSACTION_destroySecureContainer: {
1424                    data.enforceInterface(DESCRIPTOR);
1425                    String id;
1426                    id = data.readString();
1427                    boolean force;
1428                    force = 0 != data.readInt();
1429                    int resultCode = destroySecureContainer(id, force);
1430                    reply.writeNoException();
1431                    reply.writeInt(resultCode);
1432                    return true;
1433                }
1434                case TRANSACTION_mountSecureContainer: {
1435                    data.enforceInterface(DESCRIPTOR);
1436                    String id;
1437                    id = data.readString();
1438                    String key;
1439                    key = data.readString();
1440                    int ownerUid;
1441                    ownerUid = data.readInt();
1442                    boolean readOnly;
1443                    readOnly = data.readInt() != 0;
1444                    int resultCode = mountSecureContainer(id, key, ownerUid, readOnly);
1445                    reply.writeNoException();
1446                    reply.writeInt(resultCode);
1447                    return true;
1448                }
1449                case TRANSACTION_unmountSecureContainer: {
1450                    data.enforceInterface(DESCRIPTOR);
1451                    String id;
1452                    id = data.readString();
1453                    boolean force;
1454                    force = 0 != data.readInt();
1455                    int resultCode = unmountSecureContainer(id, force);
1456                    reply.writeNoException();
1457                    reply.writeInt(resultCode);
1458                    return true;
1459                }
1460                case TRANSACTION_isSecureContainerMounted: {
1461                    data.enforceInterface(DESCRIPTOR);
1462                    String id;
1463                    id = data.readString();
1464                    boolean status = isSecureContainerMounted(id);
1465                    reply.writeNoException();
1466                    reply.writeInt((status ? 1 : 0));
1467                    return true;
1468                }
1469                case TRANSACTION_renameSecureContainer: {
1470                    data.enforceInterface(DESCRIPTOR);
1471                    String oldId;
1472                    oldId = data.readString();
1473                    String newId;
1474                    newId = data.readString();
1475                    int resultCode = renameSecureContainer(oldId, newId);
1476                    reply.writeNoException();
1477                    reply.writeInt(resultCode);
1478                    return true;
1479                }
1480                case TRANSACTION_getSecureContainerPath: {
1481                    data.enforceInterface(DESCRIPTOR);
1482                    String id;
1483                    id = data.readString();
1484                    String path = getSecureContainerPath(id);
1485                    reply.writeNoException();
1486                    reply.writeString(path);
1487                    return true;
1488                }
1489                case TRANSACTION_getSecureContainerList: {
1490                    data.enforceInterface(DESCRIPTOR);
1491                    String[] ids = getSecureContainerList();
1492                    reply.writeNoException();
1493                    reply.writeStringArray(ids);
1494                    return true;
1495                }
1496                case TRANSACTION_shutdown: {
1497                    data.enforceInterface(DESCRIPTOR);
1498                    IMountShutdownObserver observer;
1499                    observer = IMountShutdownObserver.Stub.asInterface(data
1500                            .readStrongBinder());
1501                    shutdown(observer);
1502                    reply.writeNoException();
1503                    return true;
1504                }
1505                case TRANSACTION_finishMediaUpdate: {
1506                    data.enforceInterface(DESCRIPTOR);
1507                    finishMediaUpdate();
1508                    reply.writeNoException();
1509                    return true;
1510                }
1511                case TRANSACTION_mountObb: {
1512                    data.enforceInterface(DESCRIPTOR);
1513                    final String rawPath = data.readString();
1514                    final String canonicalPath = data.readString();
1515                    final String key = data.readString();
1516                    IObbActionListener observer;
1517                    observer = IObbActionListener.Stub.asInterface(data.readStrongBinder());
1518                    int nonce;
1519                    nonce = data.readInt();
1520                    mountObb(rawPath, canonicalPath, key, observer, nonce);
1521                    reply.writeNoException();
1522                    return true;
1523                }
1524                case TRANSACTION_unmountObb: {
1525                    data.enforceInterface(DESCRIPTOR);
1526                    String filename;
1527                    filename = data.readString();
1528                    boolean force;
1529                    force = 0 != data.readInt();
1530                    IObbActionListener observer;
1531                    observer = IObbActionListener.Stub.asInterface(data.readStrongBinder());
1532                    int nonce;
1533                    nonce = data.readInt();
1534                    unmountObb(filename, force, observer, nonce);
1535                    reply.writeNoException();
1536                    return true;
1537                }
1538                case TRANSACTION_isObbMounted: {
1539                    data.enforceInterface(DESCRIPTOR);
1540                    String filename;
1541                    filename = data.readString();
1542                    boolean status = isObbMounted(filename);
1543                    reply.writeNoException();
1544                    reply.writeInt((status ? 1 : 0));
1545                    return true;
1546                }
1547                case TRANSACTION_getMountedObbPath: {
1548                    data.enforceInterface(DESCRIPTOR);
1549                    String filename;
1550                    filename = data.readString();
1551                    String mountedPath = getMountedObbPath(filename);
1552                    reply.writeNoException();
1553                    reply.writeString(mountedPath);
1554                    return true;
1555                }
1556                case TRANSACTION_isExternalStorageEmulated: {
1557                    data.enforceInterface(DESCRIPTOR);
1558                    boolean emulated = isExternalStorageEmulated();
1559                    reply.writeNoException();
1560                    reply.writeInt(emulated ? 1 : 0);
1561                    return true;
1562                }
1563                case TRANSACTION_decryptStorage: {
1564                    data.enforceInterface(DESCRIPTOR);
1565                    String password = data.readString();
1566                    int result = decryptStorage(password);
1567                    reply.writeNoException();
1568                    reply.writeInt(result);
1569                    return true;
1570                }
1571                case TRANSACTION_encryptStorage: {
1572                    data.enforceInterface(DESCRIPTOR);
1573                    int type = data.readInt();
1574                    String password = data.readString();
1575                    int result = encryptStorage(type, password);
1576                    reply.writeNoException();
1577                    reply.writeInt(result);
1578                    return true;
1579                }
1580                case TRANSACTION_changeEncryptionPassword: {
1581                    data.enforceInterface(DESCRIPTOR);
1582                    int type = data.readInt();
1583                    String password = data.readString();
1584                    int result = changeEncryptionPassword(type, password);
1585                    reply.writeNoException();
1586                    reply.writeInt(result);
1587                    return true;
1588                }
1589                case TRANSACTION_getVolumeList: {
1590                    data.enforceInterface(DESCRIPTOR);
1591                    int userId = data.readInt();
1592                    StorageVolume[] result = getVolumeList(userId);
1593                    reply.writeNoException();
1594                    reply.writeTypedArray(result, android.os.Parcelable.PARCELABLE_WRITE_RETURN_VALUE);
1595                    return true;
1596                }
1597                case TRANSACTION_getSecureContainerFilesystemPath: {
1598                    data.enforceInterface(DESCRIPTOR);
1599                    String id;
1600                    id = data.readString();
1601                    String path = getSecureContainerFilesystemPath(id);
1602                    reply.writeNoException();
1603                    reply.writeString(path);
1604                    return true;
1605                }
1606                case TRANSACTION_getEncryptionState: {
1607                    data.enforceInterface(DESCRIPTOR);
1608                    int result = getEncryptionState();
1609                    reply.writeNoException();
1610                    reply.writeInt(result);
1611                    return true;
1612                }
1613                case TRANSACTION_fixPermissionsSecureContainer: {
1614                    data.enforceInterface(DESCRIPTOR);
1615                    String id;
1616                    id = data.readString();
1617                    int gid;
1618                    gid = data.readInt();
1619                    String filename;
1620                    filename = data.readString();
1621                    int resultCode = fixPermissionsSecureContainer(id, gid, filename);
1622                    reply.writeNoException();
1623                    reply.writeInt(resultCode);
1624                    return true;
1625                }
1626                case TRANSACTION_mkdirs: {
1627                    data.enforceInterface(DESCRIPTOR);
1628                    String callingPkg = data.readString();
1629                    String path = data.readString();
1630                    int result = mkdirs(callingPkg, path);
1631                    reply.writeNoException();
1632                    reply.writeInt(result);
1633                    return true;
1634                }
1635                case TRANSACTION_getPasswordType: {
1636                    data.enforceInterface(DESCRIPTOR);
1637                    int result = getPasswordType();
1638                    reply.writeNoException();
1639                    reply.writeInt(result);
1640                    return true;
1641                }
1642                case TRANSACTION_getPassword: {
1643                    data.enforceInterface(DESCRIPTOR);
1644                    String result = getPassword();
1645                    reply.writeNoException();
1646                    reply.writeString(result);
1647                    return true;
1648                }
1649                case TRANSACTION_clearPassword: {
1650                    data.enforceInterface(DESCRIPTOR);
1651                    clearPassword();
1652                    reply.writeNoException();
1653                    return true;
1654                }
1655                case TRANSACTION_setField: {
1656                    data.enforceInterface(DESCRIPTOR);
1657                    String field = data.readString();
1658                    String contents = data.readString();
1659                    setField(field, contents);
1660                    reply.writeNoException();
1661                    return true;
1662                }
1663                case TRANSACTION_getField: {
1664                    data.enforceInterface(DESCRIPTOR);
1665                    String field = data.readString();
1666                    String contents = getField(field);
1667                    reply.writeNoException();
1668                    reply.writeString(contents);
1669                    return true;
1670                }
1671                case TRANSACTION_resizeSecureContainer: {
1672                    data.enforceInterface(DESCRIPTOR);
1673                    String id;
1674                    id = data.readString();
1675                    int sizeMb;
1676                    sizeMb = data.readInt();
1677                    String key;
1678                    key = data.readString();
1679                    int resultCode = resizeSecureContainer(id, sizeMb, key);
1680                    reply.writeNoException();
1681                    reply.writeInt(resultCode);
1682                    return true;
1683                }
1684                case TRANSACTION_lastMaintenance: {
1685                    data.enforceInterface(DESCRIPTOR);
1686                    long lastMaintenance = lastMaintenance();
1687                    reply.writeNoException();
1688                    reply.writeLong(lastMaintenance);
1689                    return true;
1690                }
1691                case TRANSACTION_runMaintenance: {
1692                    data.enforceInterface(DESCRIPTOR);
1693                    runMaintenance();
1694                    reply.writeNoException();
1695                    return true;
1696                }
1697                case TRANSACTION_waitForAsecScan: {
1698                    data.enforceInterface(DESCRIPTOR);
1699                    waitForAsecScan();
1700                    reply.writeNoException();
1701                    return true;
1702                }
1703                case TRANSACTION_getDisks: {
1704                    data.enforceInterface(DESCRIPTOR);
1705                    DiskInfo[] disks = getDisks();
1706                    reply.writeNoException();
1707                    reply.writeTypedArray(disks, android.os.Parcelable.PARCELABLE_WRITE_RETURN_VALUE);
1708                    return true;
1709                }
1710                case TRANSACTION_getVolumes: {
1711                    data.enforceInterface(DESCRIPTOR);
1712                    int _flags = data.readInt();
1713                    VolumeInfo[] volumes = getVolumes(_flags);
1714                    reply.writeNoException();
1715                    reply.writeTypedArray(volumes, android.os.Parcelable.PARCELABLE_WRITE_RETURN_VALUE);
1716                    return true;
1717                }
1718                case TRANSACTION_getVolumeRecords: {
1719                    data.enforceInterface(DESCRIPTOR);
1720                    int _flags = data.readInt();
1721                    VolumeRecord[] volumes = getVolumeRecords(_flags);
1722                    reply.writeNoException();
1723                    reply.writeTypedArray(volumes, android.os.Parcelable.PARCELABLE_WRITE_RETURN_VALUE);
1724                    return true;
1725                }
1726                case TRANSACTION_mount: {
1727                    data.enforceInterface(DESCRIPTOR);
1728                    String volId = data.readString();
1729                    mount(volId);
1730                    reply.writeNoException();
1731                    return true;
1732                }
1733                case TRANSACTION_unmount: {
1734                    data.enforceInterface(DESCRIPTOR);
1735                    String volId = data.readString();
1736                    unmount(volId);
1737                    reply.writeNoException();
1738                    return true;
1739                }
1740                case TRANSACTION_format: {
1741                    data.enforceInterface(DESCRIPTOR);
1742                    String volId = data.readString();
1743                    format(volId);
1744                    reply.writeNoException();
1745                    return true;
1746                }
1747                case TRANSACTION_benchmark: {
1748                    data.enforceInterface(DESCRIPTOR);
1749                    String volId = data.readString();
1750                    long res = benchmark(volId);
1751                    reply.writeNoException();
1752                    reply.writeLong(res);
1753                    return true;
1754                }
1755                case TRANSACTION_partitionPublic: {
1756                    data.enforceInterface(DESCRIPTOR);
1757                    String diskId = data.readString();
1758                    partitionPublic(diskId);
1759                    reply.writeNoException();
1760                    return true;
1761                }
1762                case TRANSACTION_partitionPrivate: {
1763                    data.enforceInterface(DESCRIPTOR);
1764                    String diskId = data.readString();
1765                    partitionPrivate(diskId);
1766                    reply.writeNoException();
1767                    return true;
1768                }
1769                case TRANSACTION_partitionMixed: {
1770                    data.enforceInterface(DESCRIPTOR);
1771                    String diskId = data.readString();
1772                    int ratio = data.readInt();
1773                    partitionMixed(diskId, ratio);
1774                    reply.writeNoException();
1775                    return true;
1776                }
1777                case TRANSACTION_setVolumeNickname: {
1778                    data.enforceInterface(DESCRIPTOR);
1779                    String volId = data.readString();
1780                    String nickname = data.readString();
1781                    setVolumeNickname(volId, nickname);
1782                    reply.writeNoException();
1783                    return true;
1784                }
1785                case TRANSACTION_setVolumeUserFlags: {
1786                    data.enforceInterface(DESCRIPTOR);
1787                    String volId = data.readString();
1788                    int _flags = data.readInt();
1789                    int _mask = data.readInt();
1790                    setVolumeUserFlags(volId, _flags, _mask);
1791                    reply.writeNoException();
1792                    return true;
1793                }
1794                case TRANSACTION_forgetVolume: {
1795                    data.enforceInterface(DESCRIPTOR);
1796                    String fsUuid = data.readString();
1797                    forgetVolume(fsUuid);
1798                    reply.writeNoException();
1799                    return true;
1800                }
1801                case TRANSACTION_forgetAllVolumes: {
1802                    data.enforceInterface(DESCRIPTOR);
1803                    forgetAllVolumes();
1804                    reply.writeNoException();
1805                    return true;
1806                }
1807                case TRANSACTION_getPrimaryStorageUuid: {
1808                    data.enforceInterface(DESCRIPTOR);
1809                    String volumeUuid = getPrimaryStorageUuid();
1810                    reply.writeNoException();
1811                    reply.writeString(volumeUuid);
1812                    return true;
1813                }
1814                case TRANSACTION_setPrimaryStorageUuid: {
1815                    data.enforceInterface(DESCRIPTOR);
1816                    String volumeUuid = data.readString();
1817                    IPackageMoveObserver listener = IPackageMoveObserver.Stub.asInterface(
1818                            data.readStrongBinder());
1819                    setPrimaryStorageUuid(volumeUuid, listener);
1820                    reply.writeNoException();
1821                    return true;
1822                }
1823            }
1824            return super.onTransact(code, data, reply, flags);
1825        }
1826    }
1827
1828    /*
1829     * Creates a secure container with the specified parameters. Returns an int
1830     * consistent with MountServiceResultCode
1831     */
1832    public int createSecureContainer(String id, int sizeMb, String fstype, String key,
1833            int ownerUid, boolean external) throws RemoteException;
1834
1835    /*
1836     * Destroy a secure container, and free up all resources associated with it.
1837     * NOTE: Ensure all references are released prior to deleting. Returns an
1838     * int consistent with MountServiceResultCode
1839     */
1840    public int destroySecureContainer(String id, boolean force) throws RemoteException;
1841
1842    /*
1843     * Finalize a container which has just been created and populated. After
1844     * finalization, the container is immutable. Returns an int consistent with
1845     * MountServiceResultCode
1846     */
1847    public int finalizeSecureContainer(String id) throws RemoteException;
1848
1849    /**
1850     * Call into MountService by PackageManager to notify that its done
1851     * processing the media status update request.
1852     */
1853    public void finishMediaUpdate() throws RemoteException;
1854
1855    /**
1856     * Format external storage given a mount point. Returns an int consistent
1857     * with MountServiceResultCode
1858     */
1859    public int formatVolume(String mountPoint) throws RemoteException;
1860
1861    /**
1862     * Gets the path to the mounted Opaque Binary Blob (OBB).
1863     */
1864    public String getMountedObbPath(String rawPath) throws RemoteException;
1865
1866    /**
1867     * Gets an Array of currently known secure container IDs
1868     */
1869    public String[] getSecureContainerList() throws RemoteException;
1870
1871    /*
1872     * Returns the filesystem path of a mounted secure container.
1873     */
1874    public String getSecureContainerPath(String id) throws RemoteException;
1875
1876    /**
1877     * Returns an array of pids with open files on the specified path.
1878     */
1879    public int[] getStorageUsers(String path) throws RemoteException;
1880
1881    /**
1882     * Gets the state of a volume via its mountpoint.
1883     */
1884    public String getVolumeState(String mountPoint) throws RemoteException;
1885
1886    /**
1887     * Checks whether the specified Opaque Binary Blob (OBB) is mounted
1888     * somewhere.
1889     */
1890    public boolean isObbMounted(String rawPath) throws RemoteException;
1891
1892    /*
1893     * Returns true if the specified container is mounted
1894     */
1895    public boolean isSecureContainerMounted(String id) throws RemoteException;
1896
1897    /**
1898     * Returns true if a USB mass storage host is connected
1899     */
1900    public boolean isUsbMassStorageConnected() throws RemoteException;
1901
1902    /**
1903     * Returns true if a USB mass storage host is enabled (media is shared)
1904     */
1905    public boolean isUsbMassStorageEnabled() throws RemoteException;
1906
1907    /**
1908     * Mounts an Opaque Binary Blob (OBB) with the specified decryption key and
1909     * only allows the calling process's UID access to the contents.
1910     * MountService will call back to the supplied IObbActionListener to inform
1911     * it of the terminal state of the call.
1912     */
1913    public void mountObb(String rawPath, String canonicalPath, String key,
1914            IObbActionListener token, int nonce) throws RemoteException;
1915
1916    /*
1917     * Mount a secure container with the specified key and owner UID. Returns an
1918     * int consistent with MountServiceResultCode
1919     */
1920    public int mountSecureContainer(String id, String key, int ownerUid, boolean readOnly)
1921            throws RemoteException;
1922
1923    /**
1924     * Mount external storage at given mount point. Returns an int consistent
1925     * with MountServiceResultCode
1926     */
1927    public int mountVolume(String mountPoint) throws RemoteException;
1928
1929    /**
1930     * Registers an IMountServiceListener for receiving async notifications.
1931     */
1932    public void registerListener(IMountServiceListener listener) throws RemoteException;
1933
1934    /*
1935     * Rename an unmounted secure container. Returns an int consistent with
1936     * MountServiceResultCode
1937     */
1938    public int renameSecureContainer(String oldId, String newId) throws RemoteException;
1939
1940    /**
1941     * Enables / disables USB mass storage. The caller should check actual
1942     * status of enabling/disabling USB mass storage via StorageEventListener.
1943     */
1944    public void setUsbMassStorageEnabled(boolean enable) throws RemoteException;
1945
1946    /**
1947     * Shuts down the MountService and gracefully unmounts all external media.
1948     * Invokes call back once the shutdown is complete.
1949     */
1950    public void shutdown(IMountShutdownObserver observer) throws RemoteException;
1951
1952    /**
1953     * Unmounts an Opaque Binary Blob (OBB). When the force flag is specified,
1954     * any program using it will be forcibly killed to unmount the image.
1955     * MountService will call back to the supplied IObbActionListener to inform
1956     * it of the terminal state of the call.
1957     */
1958    public void unmountObb(String rawPath, boolean force, IObbActionListener token, int nonce)
1959            throws RemoteException;
1960
1961    /*
1962     * Unount a secure container. Returns an int consistent with
1963     * MountServiceResultCode
1964     */
1965    public int unmountSecureContainer(String id, boolean force) throws RemoteException;
1966
1967    /**
1968     * Safely unmount external storage at given mount point. The unmount is an
1969     * asynchronous operation. Applications should register StorageEventListener
1970     * for storage related status changes.
1971     * @param mountPoint the mount point
1972     * @param force whether or not to forcefully unmount it (e.g. even if programs are using this
1973     *     data currently)
1974     * @param removeEncryption whether or not encryption mapping should be removed from the volume.
1975     *     This value implies {@code force}.
1976     */
1977    public void unmountVolume(String mountPoint, boolean force, boolean removeEncryption)
1978            throws RemoteException;
1979
1980    /**
1981     * Unregisters an IMountServiceListener
1982     */
1983    public void unregisterListener(IMountServiceListener listener) throws RemoteException;
1984
1985    /**
1986     * Returns whether or not the external storage is emulated.
1987     */
1988    public boolean isExternalStorageEmulated() throws RemoteException;
1989
1990    /** The volume is not encrypted. */
1991    static final int ENCRYPTION_STATE_NONE = 1;
1992    /** The volume has been encrypted succesfully. */
1993    static final int ENCRYPTION_STATE_OK = 0;
1994    /** The volume is in a bad state.*/
1995    static final int ENCRYPTION_STATE_ERROR_UNKNOWN = -1;
1996    /** Encryption is incomplete */
1997    static final int ENCRYPTION_STATE_ERROR_INCOMPLETE = -2;
1998    /** Encryption is incomplete and irrecoverable */
1999    static final int ENCRYPTION_STATE_ERROR_INCONSISTENT = -3;
2000    /** Underlying data is corrupt */
2001    static final int ENCRYPTION_STATE_ERROR_CORRUPT = -4;
2002
2003    /**
2004     * Determines the encryption state of the volume.
2005     * @return a numerical value. See {@code ENCRYPTION_STATE_*} for possible values.
2006     */
2007    public int getEncryptionState() throws RemoteException;
2008
2009    /**
2010     * Decrypts any encrypted volumes.
2011     */
2012    public int decryptStorage(String password) throws RemoteException;
2013
2014    /**
2015     * Encrypts storage.
2016     */
2017    public int encryptStorage(int type, String password) throws RemoteException;
2018
2019    /**
2020     * Changes the encryption password.
2021     */
2022    public int changeEncryptionPassword(int type, String password)
2023        throws RemoteException;
2024
2025    /**
2026     * Verify the encryption password against the stored volume.  This method
2027     * may only be called by the system process.
2028     */
2029    public int verifyEncryptionPassword(String password) throws RemoteException;
2030
2031    /**
2032     * Returns list of all mountable volumes.
2033     */
2034    public StorageVolume[] getVolumeList(int userId) throws RemoteException;
2035
2036    /**
2037     * Gets the path on the filesystem for the ASEC container itself.
2038     *
2039     * @param cid ASEC container ID
2040     * @return path to filesystem or {@code null} if it's not found
2041     * @throws RemoteException
2042     */
2043    public String getSecureContainerFilesystemPath(String cid) throws RemoteException;
2044
2045    /*
2046     * Fix permissions in a container which has just been created and populated.
2047     * Returns an int consistent with MountServiceResultCode
2048     */
2049    public int fixPermissionsSecureContainer(String id, int gid, String filename)
2050            throws RemoteException;
2051
2052    /**
2053     * Ensure that all directories along given path exist, creating parent
2054     * directories as needed. Validates that given path is absolute and that it
2055     * contains no relative "." or ".." paths or symlinks. Also ensures that
2056     * path belongs to a volume managed by vold, and that path is either
2057     * external storage data or OBB directory belonging to calling app.
2058     */
2059    public int mkdirs(String callingPkg, String path) throws RemoteException;
2060
2061    /**
2062     * Determines the type of the encryption password
2063     * @return PasswordType
2064     */
2065    public int getPasswordType() throws RemoteException;
2066
2067    /**
2068     * Get password from vold
2069     * @return password or empty string
2070     */
2071    public String getPassword() throws RemoteException;
2072
2073    /**
2074     * Securely clear password from vold
2075     */
2076    public void clearPassword() throws RemoteException;
2077
2078    /**
2079     * Set a field in the crypto header.
2080     * @param field field to set
2081     * @param contents contents to set in field
2082     */
2083    public void setField(String field, String contents) throws RemoteException;
2084
2085    /**
2086     * Gets a field from the crypto header.
2087     * @param field field to get
2088     * @return contents of field
2089     */
2090    public String getField(String field) throws RemoteException;
2091
2092    public int resizeSecureContainer(String id, int sizeMb, String key) throws RemoteException;
2093
2094    /**
2095     * Report the time of the last maintenance operation such as fstrim.
2096     * @return Timestamp of the last maintenance operation, in the
2097     *     System.currentTimeMillis() time base
2098     * @throws RemoteException
2099     */
2100    public long lastMaintenance() throws RemoteException;
2101
2102    /**
2103     * Kick off an immediate maintenance operation
2104     * @throws RemoteException
2105     */
2106    public void runMaintenance() throws RemoteException;
2107
2108    public void waitForAsecScan() throws RemoteException;
2109
2110    public DiskInfo[] getDisks() throws RemoteException;
2111    public VolumeInfo[] getVolumes(int flags) throws RemoteException;
2112    public VolumeRecord[] getVolumeRecords(int flags) throws RemoteException;
2113
2114    public void mount(String volId) throws RemoteException;
2115    public void unmount(String volId) throws RemoteException;
2116    public void format(String volId) throws RemoteException;
2117    public long benchmark(String volId) throws RemoteException;
2118
2119    public void partitionPublic(String diskId) throws RemoteException;
2120    public void partitionPrivate(String diskId) throws RemoteException;
2121    public void partitionMixed(String diskId, int ratio) throws RemoteException;
2122
2123    public void setVolumeNickname(String fsUuid, String nickname) throws RemoteException;
2124    public void setVolumeUserFlags(String fsUuid, int flags, int mask) throws RemoteException;
2125    public void forgetVolume(String fsUuid) throws RemoteException;
2126    public void forgetAllVolumes() throws RemoteException;
2127
2128    public String getPrimaryStorageUuid() throws RemoteException;
2129    public void setPrimaryStorageUuid(String volumeUuid, IPackageMoveObserver callback)
2130            throws RemoteException;
2131}
2132