blob: afdfe4f6d33e108a10f8c87e73381c421bc53e79 [file] [log] [blame]
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2005 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
17#ifndef ANDROID_PARCEL_H
18#define ANDROID_PARCEL_H
19
Christopher Wiley9a5e32f2016-01-28 16:56:53 -080020#include <string>
Casey Dahlin451ff582015-10-19 18:12:18 -070021#include <vector>
22
Christopher Wiley83e6b982016-04-19 10:27:00 -070023#include <android-base/unique_fd.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080024#include <cutils/native_handle.h>
25#include <utils/Errors.h>
26#include <utils/RefBase.h>
27#include <utils/String16.h>
28#include <utils/Vector.h>
Mathias Agopian8683fca2012-08-12 19:37:16 -070029#include <utils/Flattenable.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080030
Steven Morelandf0212002018-12-26 13:59:23 -080031#include <binder/binder_kernel.h>
Casey Dahlinf0c13772015-10-27 18:33:56 -070032#include <binder/IInterface.h>
Christopher Wiley97f048d2015-11-19 06:49:05 -080033#include <binder/Parcelable.h>
Robert Quattlebaum6316f5b2017-01-04 13:25:14 -080034#include <binder/Map.h>
Casey Dahlinf0c13772015-10-27 18:33:56 -070035
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080036// ---------------------------------------------------------------------------
37namespace android {
38
Mathias Agopiane1424282013-07-29 21:24:40 -070039template <typename T> class Flattenable;
Mathias Agopian8683fca2012-08-12 19:37:16 -070040template <typename T> class LightFlattenable;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080041class IBinder;
Brad Fitzpatrick70081a12010-07-27 09:49:11 -070042class IPCThreadState;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080043class ProcessState;
44class String8;
45class TextOutput;
46
Robert Quattlebaum6316f5b2017-01-04 13:25:14 -080047namespace binder {
48class Value;
49};
50
Mathias Agopiane1424282013-07-29 21:24:40 -070051class Parcel {
Serban Constantinescuf683e012013-11-05 16:53:55 +000052 friend class IPCThreadState;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080053public:
Jeff Brown5707dbf2011-09-23 21:17:56 -070054 class ReadableBlob;
55 class WritableBlob;
56
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080057 Parcel();
58 ~Parcel();
59
60 const uint8_t* data() const;
61 size_t dataSize() const;
62 size_t dataAvail() const;
63 size_t dataPosition() const;
64 size_t dataCapacity() const;
Dianne Hackborn8938ed22011-09-28 23:19:47 -040065
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080066 status_t setDataSize(size_t size);
67 void setDataPosition(size_t pos) const;
68 status_t setDataCapacity(size_t size);
69
70 status_t setData(const uint8_t* buffer, size_t len);
71
Andreas Huber51faf462011-04-13 10:21:56 -070072 status_t appendFrom(const Parcel *parcel,
73 size_t start, size_t len);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080074
Dianne Hackborn15feb9b2017-04-10 15:34:35 -070075 int compareData(const Parcel& other);
76
Jeff Brown13b16042014-11-11 16:44:25 -080077 bool allowFds() const;
Dianne Hackborn7746cc32011-10-03 21:09:35 -070078 bool pushAllowFds(bool allowFds);
79 void restoreAllowFds(bool lastValue);
Dianne Hackborn8938ed22011-09-28 23:19:47 -040080
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080081 bool hasFileDescriptors() const;
82
Brad Fitzpatrick702ea9d2010-06-18 13:07:53 -070083 // Writes the RPC header.
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080084 status_t writeInterfaceToken(const String16& interface);
Brad Fitzpatricka877cd82010-07-07 16:06:39 -070085
Brad Fitzpatrick702ea9d2010-06-18 13:07:53 -070086 // Parses the RPC header, returning true if the interface name
87 // in the header matches the expected interface from the caller.
Brad Fitzpatrick70081a12010-07-27 09:49:11 -070088 //
89 // Additionally, enforceInterface does part of the work of
90 // propagating the StrictMode policy mask, populating the current
91 // IPCThreadState, which as an optimization may optionally be
92 // passed in.
Brad Fitzpatricka877cd82010-07-07 16:06:39 -070093 bool enforceInterface(const String16& interface,
Yi Kong0cf75842018-07-10 11:44:36 -070094 IPCThreadState* threadState = nullptr) const;
Brad Fitzpatrick702ea9d2010-06-18 13:07:53 -070095 bool checkInterface(IBinder*) const;
Mathias Agopian83c04462009-05-22 19:00:22 -070096
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080097 void freeData();
98
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -080099private:
100 const binder_size_t* objects() const;
101
102public:
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800103 size_t objectsCount() const;
104
105 status_t errorCheck() const;
106 void setError(status_t err);
107
108 status_t write(const void* data, size_t len);
109 void* writeInplace(size_t len);
110 status_t writeUnpadded(const void* data, size_t len);
111 status_t writeInt32(int32_t val);
Dan Stoza41a0f2f2014-12-01 10:01:10 -0800112 status_t writeUint32(uint32_t val);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800113 status_t writeInt64(int64_t val);
Ronghua Wu2d13afd2015-03-16 11:11:07 -0700114 status_t writeUint64(uint64_t val);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800115 status_t writeFloat(float val);
116 status_t writeDouble(double val);
117 status_t writeCString(const char* str);
118 status_t writeString8(const String8& str);
119 status_t writeString16(const String16& str);
Casey Dahlinb9872622015-11-25 15:09:45 -0800120 status_t writeString16(const std::unique_ptr<String16>& str);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800121 status_t writeString16(const char16_t* str, size_t len);
122 status_t writeStrongBinder(const sp<IBinder>& val);
123 status_t writeWeakBinder(const wp<IBinder>& val);
Marco Nelissen5c0106e2013-10-16 10:57:51 -0700124 status_t writeInt32Array(size_t len, const int32_t *val);
Marco Nelissenf0190bf2014-03-13 14:17:40 -0700125 status_t writeByteArray(size_t len, const uint8_t *val);
Casey Dahlind6848f52015-10-15 15:44:59 -0700126 status_t writeBool(bool val);
127 status_t writeChar(char16_t val);
128 status_t writeByte(int8_t val);
Mathias Agopiane1424282013-07-29 21:24:40 -0700129
Christopher Wiley9a5e32f2016-01-28 16:56:53 -0800130 // Take a UTF8 encoded string, convert to UTF16, write it to the parcel.
131 status_t writeUtf8AsUtf16(const std::string& str);
132 status_t writeUtf8AsUtf16(const std::unique_ptr<std::string>& str);
133
Casey Dahlinb9872622015-11-25 15:09:45 -0800134 status_t writeByteVector(const std::unique_ptr<std::vector<int8_t>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700135 status_t writeByteVector(const std::vector<int8_t>& val);
Casey Dahlin185d3442016-02-09 11:08:35 -0800136 status_t writeByteVector(const std::unique_ptr<std::vector<uint8_t>>& val);
137 status_t writeByteVector(const std::vector<uint8_t>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800138 status_t writeInt32Vector(const std::unique_ptr<std::vector<int32_t>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700139 status_t writeInt32Vector(const std::vector<int32_t>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800140 status_t writeInt64Vector(const std::unique_ptr<std::vector<int64_t>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700141 status_t writeInt64Vector(const std::vector<int64_t>& val);
Kevin DuBois2f82d5b2018-12-05 12:56:10 -0800142 status_t writeUint64Vector(const std::unique_ptr<std::vector<uint64_t>>& val);
143 status_t writeUint64Vector(const std::vector<uint64_t>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800144 status_t writeFloatVector(const std::unique_ptr<std::vector<float>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700145 status_t writeFloatVector(const std::vector<float>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800146 status_t writeDoubleVector(const std::unique_ptr<std::vector<double>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700147 status_t writeDoubleVector(const std::vector<double>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800148 status_t writeBoolVector(const std::unique_ptr<std::vector<bool>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700149 status_t writeBoolVector(const std::vector<bool>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800150 status_t writeCharVector(const std::unique_ptr<std::vector<char16_t>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700151 status_t writeCharVector(const std::vector<char16_t>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800152 status_t writeString16Vector(
153 const std::unique_ptr<std::vector<std::unique_ptr<String16>>>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700154 status_t writeString16Vector(const std::vector<String16>& val);
Christopher Wiley9a5e32f2016-01-28 16:56:53 -0800155 status_t writeUtf8VectorAsUtf16Vector(
156 const std::unique_ptr<std::vector<std::unique_ptr<std::string>>>& val);
157 status_t writeUtf8VectorAsUtf16Vector(const std::vector<std::string>& val);
Casey Dahlin451ff582015-10-19 18:12:18 -0700158
Casey Dahlinb9872622015-11-25 15:09:45 -0800159 status_t writeStrongBinderVector(const std::unique_ptr<std::vector<sp<IBinder>>>& val);
Casey Dahlineb8e15f2015-11-03 13:50:37 -0800160 status_t writeStrongBinderVector(const std::vector<sp<IBinder>>& val);
161
Mathias Agopiane1424282013-07-29 21:24:40 -0700162 template<typename T>
Casey Dahlinb9872622015-11-25 15:09:45 -0800163 status_t writeParcelableVector(const std::unique_ptr<std::vector<std::unique_ptr<T>>>& val);
164 template<typename T>
Janis Danisevskis8d747092016-08-11 13:52:12 +0100165 status_t writeParcelableVector(const std::shared_ptr<std::vector<std::unique_ptr<T>>>& val);
166 template<typename T>
Christopher Wiley97f048d2015-11-19 06:49:05 -0800167 status_t writeParcelableVector(const std::vector<T>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800168
169 template<typename T>
170 status_t writeNullableParcelable(const std::unique_ptr<T>& parcelable);
171
Christopher Wiley97f048d2015-11-19 06:49:05 -0800172 status_t writeParcelable(const Parcelable& parcelable);
173
Robert Quattlebaum6316f5b2017-01-04 13:25:14 -0800174 status_t writeValue(const binder::Value& value);
175
Christopher Wiley97f048d2015-11-19 06:49:05 -0800176 template<typename T>
Mathias Agopiane1424282013-07-29 21:24:40 -0700177 status_t write(const Flattenable<T>& val);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800178
Mathias Agopian8683fca2012-08-12 19:37:16 -0700179 template<typename T>
180 status_t write(const LightFlattenable<T>& val);
181
Christopher Wiley31c1beb2016-08-19 11:43:54 -0700182 template<typename T>
183 status_t writeVectorSize(const std::vector<T>& val);
184 template<typename T>
185 status_t writeVectorSize(const std::unique_ptr<std::vector<T>>& val);
Mathias Agopian8683fca2012-08-12 19:37:16 -0700186
Robert Quattlebaum6316f5b2017-01-04 13:25:14 -0800187 status_t writeMap(const binder::Map& map);
188 status_t writeNullableMap(const std::unique_ptr<binder::Map>& map);
189
Mathias Agopiana47f02a2009-05-21 16:29:38 -0700190 // Place a native_handle into the parcel (the native_handle's file-
191 // descriptors are dup'ed, so it is safe to delete the native_handle
Casey Dahlin451ff582015-10-19 18:12:18 -0700192 // when this function returns).
Mathias Agopiana47f02a2009-05-21 16:29:38 -0700193 // Doesn't take ownership of the native_handle.
194 status_t writeNativeHandle(const native_handle* handle);
Dianne Hackborn1941a402016-08-29 12:30:43 -0700195
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800196 // Place a file descriptor into the parcel. The given fd must remain
197 // valid for the lifetime of the parcel.
Jeff Brown93ff1f92011-11-04 19:01:44 -0700198 // The Parcel does not take ownership of the given fd unless you ask it to.
199 status_t writeFileDescriptor(int fd, bool takeOwnership = false);
Dianne Hackborn1941a402016-08-29 12:30:43 -0700200
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800201 // Place a file descriptor into the parcel. A dup of the fd is made, which
202 // will be closed once the parcel is destroyed.
203 status_t writeDupFileDescriptor(int fd);
Jeff Brown5707dbf2011-09-23 21:17:56 -0700204
Dianne Hackborn1941a402016-08-29 12:30:43 -0700205 // Place a Java "parcel file descriptor" into the parcel. The given fd must remain
206 // valid for the lifetime of the parcel.
207 // The Parcel does not take ownership of the given fd unless you ask it to.
208 status_t writeParcelFileDescriptor(int fd, bool takeOwnership = false);
209
Ryo Hashimotobf551892018-05-31 16:58:35 +0900210 // Place a Java "parcel file descriptor" into the parcel. A dup of the fd is made, which will
211 // be closed once the parcel is destroyed.
212 status_t writeDupParcelFileDescriptor(int fd);
213
Casey Dahlin06673e32015-11-23 13:24:23 -0800214 // Place a file descriptor into the parcel. This will not affect the
215 // semantics of the smart file descriptor. A new descriptor will be
216 // created, and will be closed when the parcel is destroyed.
217 status_t writeUniqueFileDescriptor(
Christopher Wiley2cf19952016-04-11 11:09:37 -0700218 const base::unique_fd& fd);
Casey Dahlin06673e32015-11-23 13:24:23 -0800219
220 // Place a vector of file desciptors into the parcel. Each descriptor is
221 // dup'd as in writeDupFileDescriptor
222 status_t writeUniqueFileDescriptorVector(
Christopher Wiley2cf19952016-04-11 11:09:37 -0700223 const std::unique_ptr<std::vector<base::unique_fd>>& val);
Casey Dahlinb9872622015-11-25 15:09:45 -0800224 status_t writeUniqueFileDescriptorVector(
Christopher Wiley2cf19952016-04-11 11:09:37 -0700225 const std::vector<base::unique_fd>& val);
Casey Dahlin06673e32015-11-23 13:24:23 -0800226
Jeff Brown5707dbf2011-09-23 21:17:56 -0700227 // Writes a blob to the parcel.
228 // If the blob is small, then it is stored in-place, otherwise it is
Jeff Brown13b16042014-11-11 16:44:25 -0800229 // transferred by way of an anonymous shared memory region. Prefer sending
230 // immutable blobs if possible since they may be subsequently transferred between
231 // processes without further copying whereas mutable blobs always need to be copied.
Jeff Brown5707dbf2011-09-23 21:17:56 -0700232 // The caller should call release() on the blob after writing its contents.
Jeff Brown13b16042014-11-11 16:44:25 -0800233 status_t writeBlob(size_t len, bool mutableCopy, WritableBlob* outBlob);
234
235 // Write an existing immutable blob file descriptor to the parcel.
236 // This allows the client to send the same blob to multiple processes
237 // as long as it keeps a dup of the blob file descriptor handy for later.
238 status_t writeDupImmutableBlobFileDescriptor(int fd);
Jeff Brown5707dbf2011-09-23 21:17:56 -0700239
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800240 status_t writeObject(const flat_binder_object& val, bool nullMetaData);
241
Brad Fitzpatrick837a0d02010-07-13 15:33:35 -0700242 // Like Parcel.java's writeNoException(). Just writes a zero int32.
243 // Currently the native implementation doesn't do any of the StrictMode
244 // stack gathering and serialization that the Java implementation does.
245 status_t writeNoException();
246
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800247 void remove(size_t start, size_t amt);
248
249 status_t read(void* outData, size_t len) const;
250 const void* readInplace(size_t len) const;
251 int32_t readInt32() const;
252 status_t readInt32(int32_t *pArg) const;
Dan Stoza41a0f2f2014-12-01 10:01:10 -0800253 uint32_t readUint32() const;
254 status_t readUint32(uint32_t *pArg) const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800255 int64_t readInt64() const;
256 status_t readInt64(int64_t *pArg) const;
Ronghua Wu2d13afd2015-03-16 11:11:07 -0700257 uint64_t readUint64() const;
258 status_t readUint64(uint64_t *pArg) const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800259 float readFloat() const;
260 status_t readFloat(float *pArg) const;
261 double readDouble() const;
262 status_t readDouble(double *pArg) const;
Andreas Huber84a6d042009-08-17 13:33:27 -0700263 intptr_t readIntPtr() const;
264 status_t readIntPtr(intptr_t *pArg) const;
Casey Dahlind6848f52015-10-15 15:44:59 -0700265 bool readBool() const;
266 status_t readBool(bool *pArg) const;
267 char16_t readChar() const;
268 status_t readChar(char16_t *pArg) const;
269 int8_t readByte() const;
270 status_t readByte(int8_t *pArg) const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800271
Christopher Wiley9a5e32f2016-01-28 16:56:53 -0800272 // Read a UTF16 encoded string, convert to UTF8
273 status_t readUtf8FromUtf16(std::string* str) const;
274 status_t readUtf8FromUtf16(std::unique_ptr<std::string>* str) const;
275
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800276 const char* readCString() const;
277 String8 readString8() const;
Roshan Pius87b64d22016-07-18 12:51:02 -0700278 status_t readString8(String8* pArg) const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800279 String16 readString16() const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700280 status_t readString16(String16* pArg) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800281 status_t readString16(std::unique_ptr<String16>* pArg) const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800282 const char16_t* readString16Inplace(size_t* outLen) const;
283 sp<IBinder> readStrongBinder() const;
Casey Dahlinf0c13772015-10-27 18:33:56 -0700284 status_t readStrongBinder(sp<IBinder>* val) const;
Christopher Wiley35d77ca2016-03-08 10:49:51 -0800285 status_t readNullableStrongBinder(sp<IBinder>* val) const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800286 wp<IBinder> readWeakBinder() const;
Mathias Agopiane1424282013-07-29 21:24:40 -0700287
Casey Dahlinf0c13772015-10-27 18:33:56 -0700288 template<typename T>
Casey Dahlinb9872622015-11-25 15:09:45 -0800289 status_t readParcelableVector(
290 std::unique_ptr<std::vector<std::unique_ptr<T>>>* val) const;
291 template<typename T>
Christopher Wiley97f048d2015-11-19 06:49:05 -0800292 status_t readParcelableVector(std::vector<T>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800293
Christopher Wiley97f048d2015-11-19 06:49:05 -0800294 status_t readParcelable(Parcelable* parcelable) const;
295
296 template<typename T>
Casey Dahlinb9872622015-11-25 15:09:45 -0800297 status_t readParcelable(std::unique_ptr<T>* parcelable) const;
298
Robert Quattlebaum6316f5b2017-01-04 13:25:14 -0800299 status_t readValue(binder::Value* value) const;
300
Casey Dahlinb9872622015-11-25 15:09:45 -0800301 template<typename T>
Casey Dahlineb8e15f2015-11-03 13:50:37 -0800302 status_t readStrongBinder(sp<T>* val) const;
303
Christopher Wiley35d77ca2016-03-08 10:49:51 -0800304 template<typename T>
305 status_t readNullableStrongBinder(sp<T>* val) const;
306
Casey Dahlinb9872622015-11-25 15:09:45 -0800307 status_t readStrongBinderVector(std::unique_ptr<std::vector<sp<IBinder>>>* val) const;
Casey Dahlineb8e15f2015-11-03 13:50:37 -0800308 status_t readStrongBinderVector(std::vector<sp<IBinder>>* val) const;
Casey Dahlinf0c13772015-10-27 18:33:56 -0700309
Casey Dahlinb9872622015-11-25 15:09:45 -0800310 status_t readByteVector(std::unique_ptr<std::vector<int8_t>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700311 status_t readByteVector(std::vector<int8_t>* val) const;
Casey Dahlin185d3442016-02-09 11:08:35 -0800312 status_t readByteVector(std::unique_ptr<std::vector<uint8_t>>* val) const;
313 status_t readByteVector(std::vector<uint8_t>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800314 status_t readInt32Vector(std::unique_ptr<std::vector<int32_t>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700315 status_t readInt32Vector(std::vector<int32_t>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800316 status_t readInt64Vector(std::unique_ptr<std::vector<int64_t>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700317 status_t readInt64Vector(std::vector<int64_t>* val) const;
Kevin DuBois2f82d5b2018-12-05 12:56:10 -0800318 status_t readUint64Vector(std::unique_ptr<std::vector<uint64_t>>* val) const;
319 status_t readUint64Vector(std::vector<uint64_t>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800320 status_t readFloatVector(std::unique_ptr<std::vector<float>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700321 status_t readFloatVector(std::vector<float>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800322 status_t readDoubleVector(std::unique_ptr<std::vector<double>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700323 status_t readDoubleVector(std::vector<double>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800324 status_t readBoolVector(std::unique_ptr<std::vector<bool>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700325 status_t readBoolVector(std::vector<bool>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800326 status_t readCharVector(std::unique_ptr<std::vector<char16_t>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700327 status_t readCharVector(std::vector<char16_t>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800328 status_t readString16Vector(
329 std::unique_ptr<std::vector<std::unique_ptr<String16>>>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700330 status_t readString16Vector(std::vector<String16>* val) const;
Christopher Wiley9a5e32f2016-01-28 16:56:53 -0800331 status_t readUtf8VectorFromUtf16Vector(
332 std::unique_ptr<std::vector<std::unique_ptr<std::string>>>* val) const;
333 status_t readUtf8VectorFromUtf16Vector(std::vector<std::string>* val) const;
Casey Dahlin451ff582015-10-19 18:12:18 -0700334
Mathias Agopiane1424282013-07-29 21:24:40 -0700335 template<typename T>
336 status_t read(Flattenable<T>& val) const;
Brad Fitzpatrick837a0d02010-07-13 15:33:35 -0700337
Mathias Agopian8683fca2012-08-12 19:37:16 -0700338 template<typename T>
339 status_t read(LightFlattenable<T>& val) const;
340
Christopher Wiley31c1beb2016-08-19 11:43:54 -0700341 template<typename T>
342 status_t resizeOutVector(std::vector<T>* val) const;
343 template<typename T>
344 status_t resizeOutVector(std::unique_ptr<std::vector<T>>* val) const;
345
Robert Quattlebaum6316f5b2017-01-04 13:25:14 -0800346 status_t readMap(binder::Map* map)const;
347 status_t readNullableMap(std::unique_ptr<binder::Map>* map) const;
348
Brad Fitzpatrick837a0d02010-07-13 15:33:35 -0700349 // Like Parcel.java's readExceptionCode(). Reads the first int32
350 // off of a Parcel's header, returning 0 or the negative error
351 // code on exceptions, but also deals with skipping over rich
352 // response headers. Callers should use this to read & parse the
353 // response headers rather than doing it by hand.
354 int32_t readExceptionCode() const;
355
Mathias Agopiana47f02a2009-05-21 16:29:38 -0700356 // Retrieve native_handle from the parcel. This returns a copy of the
357 // parcel's native_handle (the caller takes ownership). The caller
358 // must free the native_handle with native_handle_close() and
359 // native_handle_delete().
360 native_handle* readNativeHandle() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800361
362
363 // Retrieve a file descriptor from the parcel. This returns the raw fd
364 // in the parcel, which you do not own -- use dup() to get your own copy.
365 int readFileDescriptor() const;
Jeff Brown5707dbf2011-09-23 21:17:56 -0700366
Dianne Hackborn1941a402016-08-29 12:30:43 -0700367 // Retrieve a Java "parcel file descriptor" from the parcel. This returns the raw fd
368 // in the parcel, which you do not own -- use dup() to get your own copy.
369 int readParcelFileDescriptor() const;
370
Casey Dahlin06673e32015-11-23 13:24:23 -0800371 // Retrieve a smart file descriptor from the parcel.
372 status_t readUniqueFileDescriptor(
Christopher Wiley2cf19952016-04-11 11:09:37 -0700373 base::unique_fd* val) const;
Casey Dahlin06673e32015-11-23 13:24:23 -0800374
Ryo Hashimotobf551892018-05-31 16:58:35 +0900375 // Retrieve a Java "parcel file descriptor" from the parcel.
376 status_t readUniqueParcelFileDescriptor(base::unique_fd* val) const;
377
Casey Dahlin06673e32015-11-23 13:24:23 -0800378
379 // Retrieve a vector of smart file descriptors from the parcel.
380 status_t readUniqueFileDescriptorVector(
Christopher Wiley2cf19952016-04-11 11:09:37 -0700381 std::unique_ptr<std::vector<base::unique_fd>>* val) const;
Casey Dahlinb9872622015-11-25 15:09:45 -0800382 status_t readUniqueFileDescriptorVector(
Christopher Wiley2cf19952016-04-11 11:09:37 -0700383 std::vector<base::unique_fd>* val) const;
Casey Dahlin06673e32015-11-23 13:24:23 -0800384
Jeff Brown5707dbf2011-09-23 21:17:56 -0700385 // Reads a blob from the parcel.
386 // The caller should call release() on the blob after reading its contents.
387 status_t readBlob(size_t len, ReadableBlob* outBlob) const;
388
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800389 const flat_binder_object* readObject(bool nullMetaData) const;
390
391 // Explicitly close all file descriptors in the parcel.
392 void closeFileDescriptors();
Dianne Hackborn7e790af2014-11-11 12:22:53 -0800393
394 // Debugging: get metrics on current allocations.
395 static size_t getGlobalAllocSize();
396 static size_t getGlobalAllocCount();
397
Olivier Gaillarddc848a02019-01-30 17:10:44 +0000398 bool replaceCallingWorkSourceUid(uid_t uid);
399 // Returns the work source provided by the caller. This can only be trusted for trusted calling
400 // uid.
401 uid_t readCallingWorkSourceUid();
402 void readRequestHeaders() const;
403
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -0800404private:
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800405 typedef void (*release_func)(Parcel* parcel,
406 const uint8_t* data, size_t dataSize,
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -0800407 const binder_size_t* objects, size_t objectsSize,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800408 void* cookie);
409
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -0800410 uintptr_t ipcData() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800411 size_t ipcDataSize() const;
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -0800412 uintptr_t ipcObjects() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800413 size_t ipcObjectsCount() const;
414 void ipcSetDataReference(const uint8_t* data, size_t dataSize,
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -0800415 const binder_size_t* objects, size_t objectsCount,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800416 release_func relFunc, void* relCookie);
417
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -0800418public:
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800419 void print(TextOutput& to, uint32_t flags = 0) const;
Jeff Brown5707dbf2011-09-23 21:17:56 -0700420
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800421private:
422 Parcel(const Parcel& o);
423 Parcel& operator=(const Parcel& o);
424
425 status_t finishWrite(size_t len);
426 void releaseObjects();
427 void acquireObjects();
428 status_t growData(size_t len);
429 status_t restartWrite(size_t desired);
430 status_t continueWrite(size_t desired);
Serban Constantinescuf683e012013-11-05 16:53:55 +0000431 status_t writePointer(uintptr_t val);
432 status_t readPointer(uintptr_t *pArg) const;
433 uintptr_t readPointer() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800434 void freeDataNoInit();
435 void initState();
436 void scanForFds() const;
Michael Wachenschwanzc5176812017-11-17 18:25:05 -0800437 status_t validateReadData(size_t len) const;
Olivier Gaillarddc848a02019-01-30 17:10:44 +0000438 void updateWorkSourceRequestHeaderPosition() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800439
Andreas Huber84a6d042009-08-17 13:33:27 -0700440 template<class T>
441 status_t readAligned(T *pArg) const;
442
443 template<class T> T readAligned() const;
444
445 template<class T>
446 status_t writeAligned(T val);
447
Casey Dahlinb9872622015-11-25 15:09:45 -0800448 status_t writeRawNullableParcelable(const Parcelable*
449 parcelable);
450
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800451 template<typename T, typename U>
452 status_t unsafeReadTypedVector(std::vector<T>* val,
453 status_t(Parcel::*read_func)(U*) const) const;
454 template<typename T>
Casey Dahlinb9872622015-11-25 15:09:45 -0800455 status_t readNullableTypedVector(std::unique_ptr<std::vector<T>>* val,
456 status_t(Parcel::*read_func)(T*) const) const;
457 template<typename T>
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800458 status_t readTypedVector(std::vector<T>* val,
459 status_t(Parcel::*read_func)(T*) const) const;
460 template<typename T, typename U>
461 status_t unsafeWriteTypedVector(const std::vector<T>& val,
462 status_t(Parcel::*write_func)(U));
463 template<typename T>
Casey Dahlinb9872622015-11-25 15:09:45 -0800464 status_t writeNullableTypedVector(const std::unique_ptr<std::vector<T>>& val,
465 status_t(Parcel::*write_func)(const T&));
466 template<typename T>
467 status_t writeNullableTypedVector(const std::unique_ptr<std::vector<T>>& val,
468 status_t(Parcel::*write_func)(T));
469 template<typename T>
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800470 status_t writeTypedVector(const std::vector<T>& val,
471 status_t(Parcel::*write_func)(const T&));
472 template<typename T>
473 status_t writeTypedVector(const std::vector<T>& val,
474 status_t(Parcel::*write_func)(T));
475
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800476 status_t mError;
477 uint8_t* mData;
478 size_t mDataSize;
479 size_t mDataCapacity;
480 mutable size_t mDataPos;
Arve Hjønnevåg84e625a2014-01-28 20:12:59 -0800481 binder_size_t* mObjects;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800482 size_t mObjectsSize;
483 size_t mObjectsCapacity;
484 mutable size_t mNextObjectHint;
Michael Wachenschwanzc5176812017-11-17 18:25:05 -0800485 mutable bool mObjectsSorted;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800486
Olivier Gaillarddc848a02019-01-30 17:10:44 +0000487 mutable bool mRequestHeaderPresent;
488 mutable size_t mWorkSourceRequestHeaderPosition;
489
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800490 mutable bool mFdsKnown;
491 mutable bool mHasFds;
Dianne Hackborn8938ed22011-09-28 23:19:47 -0400492 bool mAllowFds;
Christopher Tatee4e0ae82016-03-24 16:03:44 -0700493
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800494 release_func mOwner;
495 void* mOwnerCookie;
Jeff Brown5707dbf2011-09-23 21:17:56 -0700496
497 class Blob {
498 public:
499 Blob();
500 ~Blob();
501
Jeff Brown13b16042014-11-11 16:44:25 -0800502 void clear();
Jeff Brown5707dbf2011-09-23 21:17:56 -0700503 void release();
504 inline size_t size() const { return mSize; }
Colin Cross17576de2016-09-26 13:07:06 -0700505 inline int fd() const { return mFd; }
Jeff Brown13b16042014-11-11 16:44:25 -0800506 inline bool isMutable() const { return mMutable; }
Jeff Brown5707dbf2011-09-23 21:17:56 -0700507
508 protected:
Jeff Brown13b16042014-11-11 16:44:25 -0800509 void init(int fd, void* data, size_t size, bool isMutable);
Jeff Brown5707dbf2011-09-23 21:17:56 -0700510
Jeff Brown13b16042014-11-11 16:44:25 -0800511 int mFd; // owned by parcel so not closed when released
Jeff Brown5707dbf2011-09-23 21:17:56 -0700512 void* mData;
513 size_t mSize;
Jeff Brown13b16042014-11-11 16:44:25 -0800514 bool mMutable;
Jeff Brown5707dbf2011-09-23 21:17:56 -0700515 };
516
Colin Cross97b64db2016-09-26 13:48:02 -0700517 #if defined(__clang__)
518 #pragma clang diagnostic push
519 #pragma clang diagnostic ignored "-Wweak-vtables"
520 #endif
521
Fabien Sanglardc38992f2016-10-27 19:05:29 -0700522 // FlattenableHelperInterface and FlattenableHelper avoid generating a vtable entry in objects
523 // following Flattenable template/protocol.
Mathias Agopiane1424282013-07-29 21:24:40 -0700524 class FlattenableHelperInterface {
525 protected:
526 ~FlattenableHelperInterface() { }
527 public:
528 virtual size_t getFlattenedSize() const = 0;
529 virtual size_t getFdCount() const = 0;
530 virtual status_t flatten(void* buffer, size_t size, int* fds, size_t count) const = 0;
531 virtual status_t unflatten(void const* buffer, size_t size, int const* fds, size_t count) = 0;
532 };
533
Colin Cross97b64db2016-09-26 13:48:02 -0700534 #if defined(__clang__)
535 #pragma clang diagnostic pop
536 #endif
537
Fabien Sanglardc38992f2016-10-27 19:05:29 -0700538 // Concrete implementation of FlattenableHelperInterface that delegates virtual calls to the
539 // specified class T implementing the Flattenable protocol. It "virtualizes" a compile-time
540 // protocol.
Mathias Agopiane1424282013-07-29 21:24:40 -0700541 template<typename T>
542 class FlattenableHelper : public FlattenableHelperInterface {
543 friend class Parcel;
544 const Flattenable<T>& val;
Colin Cross382ecd32016-09-26 13:33:59 -0700545 explicit FlattenableHelper(const Flattenable<T>& _val) : val(_val) { }
Mathias Agopiane1424282013-07-29 21:24:40 -0700546
Colin Cross97b64db2016-09-26 13:48:02 -0700547 protected:
548 ~FlattenableHelper() = default;
Mathias Agopiane1424282013-07-29 21:24:40 -0700549 public:
550 virtual size_t getFlattenedSize() const {
551 return val.getFlattenedSize();
552 }
553 virtual size_t getFdCount() const {
554 return val.getFdCount();
555 }
556 virtual status_t flatten(void* buffer, size_t size, int* fds, size_t count) const {
557 return val.flatten(buffer, size, fds, count);
558 }
559 virtual status_t unflatten(void const* buffer, size_t size, int const* fds, size_t count) {
560 return const_cast<Flattenable<T>&>(val).unflatten(buffer, size, fds, count);
561 }
562 };
563 status_t write(const FlattenableHelperInterface& val);
564 status_t read(FlattenableHelperInterface& val) const;
565
Jeff Brown5707dbf2011-09-23 21:17:56 -0700566public:
567 class ReadableBlob : public Blob {
568 friend class Parcel;
569 public:
570 inline const void* data() const { return mData; }
Yi Kong0cf75842018-07-10 11:44:36 -0700571 inline void* mutableData() { return isMutable() ? mData : nullptr; }
Jeff Brown5707dbf2011-09-23 21:17:56 -0700572 };
573
574 class WritableBlob : public Blob {
575 friend class Parcel;
576 public:
577 inline void* data() { return mData; }
578 };
Dan Sandleraa5c2342015-04-10 10:08:45 -0400579
580private:
Adrian Rooscbf37262015-10-22 16:12:53 -0700581 size_t mOpenAshmemSize;
Dan Sandleraa5c2342015-04-10 10:08:45 -0400582
583public:
Adrian Roos6bb31142015-10-22 16:46:12 -0700584 // TODO: Remove once ABI can be changed.
Dan Sandleraa5c2342015-04-10 10:08:45 -0400585 size_t getBlobAshmemSize() const;
Adrian Rooscbf37262015-10-22 16:12:53 -0700586 size_t getOpenAshmemSize() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800587};
588
589// ---------------------------------------------------------------------------
590
Mathias Agopian8683fca2012-08-12 19:37:16 -0700591template<typename T>
Mathias Agopiane1424282013-07-29 21:24:40 -0700592status_t Parcel::write(const Flattenable<T>& val) {
593 const FlattenableHelper<T> helper(val);
594 return write(helper);
595}
596
597template<typename T>
Mathias Agopian8683fca2012-08-12 19:37:16 -0700598status_t Parcel::write(const LightFlattenable<T>& val) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700599 size_t size(val.getFlattenedSize());
Mathias Agopian8683fca2012-08-12 19:37:16 -0700600 if (!val.isFixedSize()) {
Colin Cross4c62b4f2016-09-27 13:58:30 -0700601 if (size > INT32_MAX) {
602 return BAD_VALUE;
603 }
604 status_t err = writeInt32(static_cast<int32_t>(size));
Mathias Agopian8683fca2012-08-12 19:37:16 -0700605 if (err != NO_ERROR) {
606 return err;
607 }
608 }
Mathias Agopian20985172012-08-31 14:25:22 -0700609 if (size) {
610 void* buffer = writeInplace(size);
Yi Kong0cf75842018-07-10 11:44:36 -0700611 if (buffer == nullptr)
Mathias Agopiane1424282013-07-29 21:24:40 -0700612 return NO_MEMORY;
613 return val.flatten(buffer, size);
Mathias Agopian20985172012-08-31 14:25:22 -0700614 }
615 return NO_ERROR;
Mathias Agopian8683fca2012-08-12 19:37:16 -0700616}
617
618template<typename T>
Mathias Agopiane1424282013-07-29 21:24:40 -0700619status_t Parcel::read(Flattenable<T>& val) const {
620 FlattenableHelper<T> helper(val);
621 return read(helper);
622}
623
624template<typename T>
Mathias Agopian8683fca2012-08-12 19:37:16 -0700625status_t Parcel::read(LightFlattenable<T>& val) const {
626 size_t size;
627 if (val.isFixedSize()) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700628 size = val.getFlattenedSize();
Mathias Agopian8683fca2012-08-12 19:37:16 -0700629 } else {
630 int32_t s;
631 status_t err = readInt32(&s);
632 if (err != NO_ERROR) {
633 return err;
634 }
Colin Cross4c62b4f2016-09-27 13:58:30 -0700635 size = static_cast<size_t>(s);
Mathias Agopian8683fca2012-08-12 19:37:16 -0700636 }
Mathias Agopian20985172012-08-31 14:25:22 -0700637 if (size) {
638 void const* buffer = readInplace(size);
Yi Kong0cf75842018-07-10 11:44:36 -0700639 return buffer == nullptr ? NO_MEMORY :
Mathias Agopian20985172012-08-31 14:25:22 -0700640 val.unflatten(buffer, size);
641 }
642 return NO_ERROR;
Mathias Agopian8683fca2012-08-12 19:37:16 -0700643}
644
Casey Dahlinf0c13772015-10-27 18:33:56 -0700645template<typename T>
Christopher Wiley31c1beb2016-08-19 11:43:54 -0700646status_t Parcel::writeVectorSize(const std::vector<T>& val) {
647 if (val.size() > INT32_MAX) {
648 return BAD_VALUE;
649 }
Colin Cross4c62b4f2016-09-27 13:58:30 -0700650 return writeInt32(static_cast<int32_t>(val.size()));
Christopher Wiley31c1beb2016-08-19 11:43:54 -0700651}
652
653template<typename T>
654status_t Parcel::writeVectorSize(const std::unique_ptr<std::vector<T>>& val) {
655 if (!val) {
656 return writeInt32(-1);
657 }
658
659 return writeVectorSize(*val);
660}
661
662template<typename T>
663status_t Parcel::resizeOutVector(std::vector<T>* val) const {
664 int32_t size;
665 status_t err = readInt32(&size);
666 if (err != NO_ERROR) {
667 return err;
668 }
669
670 if (size < 0) {
671 return UNEXPECTED_NULL;
672 }
673 val->resize(size_t(size));
674 return OK;
675}
676
677template<typename T>
678status_t Parcel::resizeOutVector(std::unique_ptr<std::vector<T>>* val) const {
679 int32_t size;
680 status_t err = readInt32(&size);
681 if (err != NO_ERROR) {
682 return err;
683 }
684
685 val->reset();
686 if (size >= 0) {
687 val->reset(new std::vector<T>(size_t(size)));
688 }
689
690 return OK;
691}
692
693template<typename T>
Casey Dahlinf0c13772015-10-27 18:33:56 -0700694status_t Parcel::readStrongBinder(sp<T>* val) const {
695 sp<IBinder> tmp;
696 status_t ret = readStrongBinder(&tmp);
697
698 if (ret == OK) {
699 *val = interface_cast<T>(tmp);
700
701 if (val->get() == nullptr) {
702 return UNKNOWN_ERROR;
703 }
704 }
705
706 return ret;
707}
708
Christopher Wiley35d77ca2016-03-08 10:49:51 -0800709template<typename T>
710status_t Parcel::readNullableStrongBinder(sp<T>* val) const {
711 sp<IBinder> tmp;
712 status_t ret = readNullableStrongBinder(&tmp);
713
714 if (ret == OK) {
715 *val = interface_cast<T>(tmp);
716
Christopher Wiley447b00f2016-07-19 09:23:25 -0700717 if (val->get() == nullptr && tmp.get() != nullptr) {
718 ret = UNKNOWN_ERROR;
Christopher Wiley35d77ca2016-03-08 10:49:51 -0800719 }
720 }
Christopher Wiley447b00f2016-07-19 09:23:25 -0700721
722 return ret;
Christopher Wiley35d77ca2016-03-08 10:49:51 -0800723}
724
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800725template<typename T, typename U>
726status_t Parcel::unsafeReadTypedVector(
Casey Dahlinb9872622015-11-25 15:09:45 -0800727 std::vector<T>* val,
728 status_t(Parcel::*read_func)(U*) const) const {
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800729 int32_t size;
730 status_t status = this->readInt32(&size);
731
732 if (status != OK) {
733 return status;
734 }
735
736 if (size < 0) {
737 return UNEXPECTED_NULL;
738 }
739
Stephen Hines803ed292016-11-16 11:34:09 -0800740 if (val->max_size() < static_cast<size_t>(size)) {
Casey Dahlin65a8f072016-10-26 17:18:25 -0700741 return NO_MEMORY;
742 }
743
Colin Cross4c62b4f2016-09-27 13:58:30 -0700744 val->resize(static_cast<size_t>(size));
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800745
Stephen Hines803ed292016-11-16 11:34:09 -0800746 if (val->size() < static_cast<size_t>(size)) {
Casey Dahlin65a8f072016-10-26 17:18:25 -0700747 return NO_MEMORY;
748 }
749
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800750 for (auto& v: *val) {
751 status = (this->*read_func)(&v);
752
753 if (status != OK) {
754 return status;
755 }
756 }
757
758 return OK;
759}
760
761template<typename T>
762status_t Parcel::readTypedVector(std::vector<T>* val,
763 status_t(Parcel::*read_func)(T*) const) const {
764 return unsafeReadTypedVector(val, read_func);
765}
766
Casey Dahlinb9872622015-11-25 15:09:45 -0800767template<typename T>
768status_t Parcel::readNullableTypedVector(std::unique_ptr<std::vector<T>>* val,
769 status_t(Parcel::*read_func)(T*) const) const {
Colin Cross4c62b4f2016-09-27 13:58:30 -0700770 const size_t start = dataPosition();
Casey Dahlinb9872622015-11-25 15:09:45 -0800771 int32_t size;
772 status_t status = readInt32(&size);
773 val->reset();
774
775 if (status != OK || size < 0) {
776 return status;
777 }
778
779 setDataPosition(start);
780 val->reset(new std::vector<T>());
781
782 status = unsafeReadTypedVector(val->get(), read_func);
783
784 if (status != OK) {
785 val->reset();
786 }
787
788 return status;
789}
790
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800791template<typename T, typename U>
792status_t Parcel::unsafeWriteTypedVector(const std::vector<T>& val,
793 status_t(Parcel::*write_func)(U)) {
794 if (val.size() > std::numeric_limits<int32_t>::max()) {
795 return BAD_VALUE;
796 }
797
Colin Cross4c62b4f2016-09-27 13:58:30 -0700798 status_t status = this->writeInt32(static_cast<int32_t>(val.size()));
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800799
800 if (status != OK) {
801 return status;
802 }
803
804 for (const auto& item : val) {
805 status = (this->*write_func)(item);
806
807 if (status != OK) {
808 return status;
809 }
810 }
811
812 return OK;
813}
814
815template<typename T>
816status_t Parcel::writeTypedVector(const std::vector<T>& val,
Casey Dahlinb9872622015-11-25 15:09:45 -0800817 status_t(Parcel::*write_func)(const T&)) {
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800818 return unsafeWriteTypedVector(val, write_func);
819}
820
821template<typename T>
822status_t Parcel::writeTypedVector(const std::vector<T>& val,
Casey Dahlinb9872622015-11-25 15:09:45 -0800823 status_t(Parcel::*write_func)(T)) {
Christopher Wiley03d1eb62015-11-19 06:42:40 -0800824 return unsafeWriteTypedVector(val, write_func);
825}
826
Christopher Wiley97f048d2015-11-19 06:49:05 -0800827template<typename T>
Casey Dahlinb9872622015-11-25 15:09:45 -0800828status_t Parcel::writeNullableTypedVector(const std::unique_ptr<std::vector<T>>& val,
829 status_t(Parcel::*write_func)(const T&)) {
830 if (val.get() == nullptr) {
831 return this->writeInt32(-1);
832 }
833
834 return unsafeWriteTypedVector(*val, write_func);
835}
836
837template<typename T>
838status_t Parcel::writeNullableTypedVector(const std::unique_ptr<std::vector<T>>& val,
839 status_t(Parcel::*write_func)(T)) {
840 if (val.get() == nullptr) {
841 return this->writeInt32(-1);
842 }
843
844 return unsafeWriteTypedVector(*val, write_func);
845}
846
847template<typename T>
Christopher Wiley97f048d2015-11-19 06:49:05 -0800848status_t Parcel::readParcelableVector(std::vector<T>* val) const {
Casey Dahlinb9872622015-11-25 15:09:45 -0800849 return unsafeReadTypedVector<T, Parcelable>(val, &Parcel::readParcelable);
850}
851
852template<typename T>
853status_t Parcel::readParcelableVector(std::unique_ptr<std::vector<std::unique_ptr<T>>>* val) const {
Colin Cross4c62b4f2016-09-27 13:58:30 -0700854 const size_t start = dataPosition();
Casey Dahlinb9872622015-11-25 15:09:45 -0800855 int32_t size;
856 status_t status = readInt32(&size);
857 val->reset();
858
859 if (status != OK || size < 0) {
860 return status;
861 }
862
863 setDataPosition(start);
Janis Danisevskisf26a3ab2016-05-20 18:10:04 +0100864 val->reset(new std::vector<std::unique_ptr<T>>());
Casey Dahlinb9872622015-11-25 15:09:45 -0800865
Janis Danisevskisf26a3ab2016-05-20 18:10:04 +0100866 status = unsafeReadTypedVector(val->get(), &Parcel::readParcelable<T>);
Casey Dahlinb9872622015-11-25 15:09:45 -0800867
868 if (status != OK) {
869 val->reset();
870 }
871
872 return status;
873}
874
875template<typename T>
876status_t Parcel::readParcelable(std::unique_ptr<T>* parcelable) const {
Colin Cross4c62b4f2016-09-27 13:58:30 -0700877 const size_t start = dataPosition();
Casey Dahlinb9872622015-11-25 15:09:45 -0800878 int32_t present;
879 status_t status = readInt32(&present);
880 parcelable->reset();
881
882 if (status != OK || !present) {
883 return status;
884 }
885
886 setDataPosition(start);
887 parcelable->reset(new T());
888
889 status = readParcelable(parcelable->get());
890
891 if (status != OK) {
892 parcelable->reset();
893 }
894
895 return status;
896}
897
898template<typename T>
899status_t Parcel::writeNullableParcelable(const std::unique_ptr<T>& parcelable) {
900 return writeRawNullableParcelable(parcelable.get());
Christopher Wiley97f048d2015-11-19 06:49:05 -0800901}
902
903template<typename T>
904status_t Parcel::writeParcelableVector(const std::vector<T>& val) {
Casey Dahlinb9872622015-11-25 15:09:45 -0800905 return unsafeWriteTypedVector<T,const Parcelable&>(val, &Parcel::writeParcelable);
906}
907
908template<typename T>
909status_t Parcel::writeParcelableVector(const std::unique_ptr<std::vector<std::unique_ptr<T>>>& val) {
910 if (val.get() == nullptr) {
911 return this->writeInt32(-1);
912 }
913
Janis Danisevskis8d747092016-08-11 13:52:12 +0100914 return unsafeWriteTypedVector(*val, &Parcel::writeNullableParcelable<T>);
915}
916
917template<typename T>
918status_t Parcel::writeParcelableVector(const std::shared_ptr<std::vector<std::unique_ptr<T>>>& val) {
919 if (val.get() == nullptr) {
920 return this->writeInt32(-1);
921 }
922
923 return unsafeWriteTypedVector(*val, &Parcel::writeNullableParcelable<T>);
Christopher Wiley97f048d2015-11-19 06:49:05 -0800924}
925
Mathias Agopian8683fca2012-08-12 19:37:16 -0700926// ---------------------------------------------------------------------------
927
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800928inline TextOutput& operator<<(TextOutput& to, const Parcel& parcel)
929{
930 parcel.print(to);
931 return to;
932}
933
934// ---------------------------------------------------------------------------
935
936// Generic acquire and release of objects.
937void acquire_object(const sp<ProcessState>& proc,
Ian Pedowitz68803072015-10-22 22:08:10 +0000938 const flat_binder_object& obj, const void* who);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800939void release_object(const sp<ProcessState>& proc,
Ian Pedowitz68803072015-10-22 22:08:10 +0000940 const flat_binder_object& obj, const void* who);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800941
942void flatten_binder(const sp<ProcessState>& proc,
943 const sp<IBinder>& binder, flat_binder_object* out);
944void flatten_binder(const sp<ProcessState>& proc,
945 const wp<IBinder>& binder, flat_binder_object* out);
946status_t unflatten_binder(const sp<ProcessState>& proc,
947 const flat_binder_object& flat, sp<IBinder>* out);
948status_t unflatten_binder(const sp<ProcessState>& proc,
949 const flat_binder_object& flat, wp<IBinder>* out);
950
951}; // namespace android
952
953// ---------------------------------------------------------------------------
954
955#endif // ANDROID_PARCEL_H