summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarco Nelissen <marcone@google.com>2014-03-14 22:55:54 +0000
committerAndroid Git Automerger <android-git-automerger@android.com>2014-03-14 22:55:54 +0000
commitb730a45216991cf22c39451c47393b4bccae111b (patch)
tree0032151858c993966c0da26d7be51d9204022fc3
parentd9e113f0e0feac1a801f8339d2f907302bd432c5 (diff)
parentf0190bff38b6c29abbfc4a877442f71fc3d7dad8 (diff)
downloadframeworks_native-b730a45216991cf22c39451c47393b4bccae111b.zip
frameworks_native-b730a45216991cf22c39451c47393b4bccae111b.tar.gz
frameworks_native-b730a45216991cf22c39451c47393b4bccae111b.tar.bz2
am f0190bff: Add support for writing byte arrays to parcels
* commit 'f0190bff38b6c29abbfc4a877442f71fc3d7dad8': Add support for writing byte arrays to parcels
-rw-r--r--include/binder/Parcel.h1
-rw-r--r--libs/binder/Parcel.cpp10
2 files changed, 11 insertions, 0 deletions
diff --git a/include/binder/Parcel.h b/include/binder/Parcel.h
index c95f297..98f20de 100644
--- a/include/binder/Parcel.h
+++ b/include/binder/Parcel.h
@@ -102,6 +102,7 @@ public:
status_t writeStrongBinder(const sp<IBinder>& val);
status_t writeWeakBinder(const wp<IBinder>& val);
status_t writeInt32Array(size_t len, const int32_t *val);
+ status_t writeByteArray(size_t len, const uint8_t *val);
template<typename T>
status_t write(const Flattenable<T>& val);
diff --git a/libs/binder/Parcel.cpp b/libs/binder/Parcel.cpp
index 0210606..17ffa05 100644
--- a/libs/binder/Parcel.cpp
+++ b/libs/binder/Parcel.cpp
@@ -628,6 +628,16 @@ status_t Parcel::writeInt32Array(size_t len, const int32_t *val) {
}
return ret;
}
+status_t Parcel::writeByteArray(size_t len, const uint8_t *val) {
+ if (!val) {
+ return writeAligned(-1);
+ }
+ status_t ret = writeAligned(len);
+ if (ret == NO_ERROR) {
+ ret = write(val, len * sizeof(*val));
+ }
+ return ret;
+}
status_t Parcel::writeInt64(int64_t val)
{