Parcel.h revision e142428a9c8b9d2380032cd4d7b55ee440fe8770
1edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project/* 2edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Copyright (C) 2005 The Android Open Source Project 3edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * 4edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 5edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * you may not use this file except in compliance with the License. 6edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * You may obtain a copy of the License at 7edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * 8edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 9edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * 10edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 11edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 12edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * See the License for the specific language governing permissions and 14edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * limitations under the License. 15edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project */ 16edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 17edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#ifndef ANDROID_PARCEL_H 18edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#define ANDROID_PARCEL_H 19edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 20edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <cutils/native_handle.h> 21edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/Errors.h> 22edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/RefBase.h> 23edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/String16.h> 24edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/Vector.h> 258683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian#include <utils/Flattenable.h> 26edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 27edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 28edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectnamespace android { 29edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 30e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopiantemplate <typename T> class Flattenable; 318683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopiantemplate <typename T> class LightFlattenable; 32edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass IBinder; 3370081a1511955f53bd0ed7f2aec9a1bf09f0f379Brad Fitzpatrickclass IPCThreadState; 34edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass ProcessState; 35edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass String8; 36edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass TextOutput; 37edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 38edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectstruct flat_binder_object; // defined in support_p/binder_module.h 39edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 40e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopianclass Parcel { 41edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectpublic: 425707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown class ReadableBlob; 435707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown class WritableBlob; 445707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 45edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project Parcel(); 46edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project ~Parcel(); 47edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 48edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const uint8_t* data() const; 49edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t dataSize() const; 50edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t dataAvail() const; 51edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t dataPosition() const; 52edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t dataCapacity() const; 538938ed2c8e906fc332301b64787728d4d34da571Dianne Hackborn 54edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t setDataSize(size_t size); 55edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void setDataPosition(size_t pos) const; 56edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t setDataCapacity(size_t size); 57edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 58edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t setData(const uint8_t* buffer, size_t len); 59edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 6051faf46e2958c57dab46d9420e585319125c7c42Andreas Huber status_t appendFrom(const Parcel *parcel, 6151faf46e2958c57dab46d9420e585319125c7c42Andreas Huber size_t start, size_t len); 62edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 637746cc318829358bb2c4dc0a03d40a7856a6d13eDianne Hackborn bool pushAllowFds(bool allowFds); 647746cc318829358bb2c4dc0a03d40a7856a6d13eDianne Hackborn void restoreAllowFds(bool lastValue); 658938ed2c8e906fc332301b64787728d4d34da571Dianne Hackborn 66edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project bool hasFileDescriptors() const; 67edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 68702ea9d42f52fc145090c0f0bfbe64993e4b8b33Brad Fitzpatrick // Writes the RPC header. 69edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeInterfaceToken(const String16& interface); 70a877cd85b5a026384542e3271fc310d6a8fe24c6Brad Fitzpatrick 71702ea9d42f52fc145090c0f0bfbe64993e4b8b33Brad Fitzpatrick // Parses the RPC header, returning true if the interface name 72702ea9d42f52fc145090c0f0bfbe64993e4b8b33Brad Fitzpatrick // in the header matches the expected interface from the caller. 7370081a1511955f53bd0ed7f2aec9a1bf09f0f379Brad Fitzpatrick // 7470081a1511955f53bd0ed7f2aec9a1bf09f0f379Brad Fitzpatrick // Additionally, enforceInterface does part of the work of 7570081a1511955f53bd0ed7f2aec9a1bf09f0f379Brad Fitzpatrick // propagating the StrictMode policy mask, populating the current 7670081a1511955f53bd0ed7f2aec9a1bf09f0f379Brad Fitzpatrick // IPCThreadState, which as an optimization may optionally be 7770081a1511955f53bd0ed7f2aec9a1bf09f0f379Brad Fitzpatrick // passed in. 78a877cd85b5a026384542e3271fc310d6a8fe24c6Brad Fitzpatrick bool enforceInterface(const String16& interface, 7970081a1511955f53bd0ed7f2aec9a1bf09f0f379Brad Fitzpatrick IPCThreadState* threadState = NULL) const; 80702ea9d42f52fc145090c0f0bfbe64993e4b8b33Brad Fitzpatrick bool checkInterface(IBinder*) const; 8183c0446f27b9542d6c2e724817b2b2d8d1f55085Mathias Agopian 82edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void freeData(); 83edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 84edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const size_t* objects() const; 85edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t objectsCount() const; 86edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 87edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t errorCheck() const; 88edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void setError(status_t err); 89edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 90edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t write(const void* data, size_t len); 91edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void* writeInplace(size_t len); 92edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeUnpadded(const void* data, size_t len); 93edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeInt32(int32_t val); 94edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeInt64(int64_t val); 95edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeFloat(float val); 96edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeDouble(double val); 9784a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber status_t writeIntPtr(intptr_t val); 98edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeCString(const char* str); 99edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeString8(const String8& str); 100edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeString16(const String16& str); 101edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeString16(const char16_t* str, size_t len); 102edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeStrongBinder(const sp<IBinder>& val); 103edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeWeakBinder(const wp<IBinder>& val); 104e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian 105e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian template<typename T> 106e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian status_t write(const Flattenable<T>& val); 107edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 1088683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian template<typename T> 1098683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian status_t write(const LightFlattenable<T>& val); 1108683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian 1118683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian 112a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // Place a native_handle into the parcel (the native_handle's file- 113a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // descriptors are dup'ed, so it is safe to delete the native_handle 114a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // when this function returns). 115a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // Doesn't take ownership of the native_handle. 116a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian status_t writeNativeHandle(const native_handle* handle); 117edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 118edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project // Place a file descriptor into the parcel. The given fd must remain 119edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project // valid for the lifetime of the parcel. 12093ff1f985e233fe04412a65041e977c9f0c21f5bJeff Brown // The Parcel does not take ownership of the given fd unless you ask it to. 12193ff1f985e233fe04412a65041e977c9f0c21f5bJeff Brown status_t writeFileDescriptor(int fd, bool takeOwnership = false); 122edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 123edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project // Place a file descriptor into the parcel. A dup of the fd is made, which 124edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project // will be closed once the parcel is destroyed. 125edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeDupFileDescriptor(int fd); 1265707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 1275707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown // Writes a blob to the parcel. 1285707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown // If the blob is small, then it is stored in-place, otherwise it is 1295707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown // transferred by way of an anonymous shared memory region. 1305707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown // The caller should call release() on the blob after writing its contents. 1315707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown status_t writeBlob(size_t len, WritableBlob* outBlob); 1325707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 133edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t writeObject(const flat_binder_object& val, bool nullMetaData); 134edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 135837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // Like Parcel.java's writeNoException(). Just writes a zero int32. 136837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // Currently the native implementation doesn't do any of the StrictMode 137837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // stack gathering and serialization that the Java implementation does. 138837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick status_t writeNoException(); 139837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick 140edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void remove(size_t start, size_t amt); 141edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 142edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t read(void* outData, size_t len) const; 143edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const void* readInplace(size_t len) const; 144edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project int32_t readInt32() const; 145edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t readInt32(int32_t *pArg) const; 146edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project int64_t readInt64() const; 147edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t readInt64(int64_t *pArg) const; 148edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project float readFloat() const; 149edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t readFloat(float *pArg) const; 150edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project double readDouble() const; 151edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t readDouble(double *pArg) const; 15284a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber intptr_t readIntPtr() const; 15384a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber status_t readIntPtr(intptr_t *pArg) const; 154edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 155edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const char* readCString() const; 156edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project String8 readString8() const; 157edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project String16 readString16() const; 158edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const char16_t* readString16Inplace(size_t* outLen) const; 159edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project sp<IBinder> readStrongBinder() const; 160edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project wp<IBinder> readWeakBinder() const; 161e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian 162e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian template<typename T> 163e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian status_t read(Flattenable<T>& val) const; 164837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick 1658683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian template<typename T> 1668683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian status_t read(LightFlattenable<T>& val) const; 1678683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian 168837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // Like Parcel.java's readExceptionCode(). Reads the first int32 169837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // off of a Parcel's header, returning 0 or the negative error 170837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // code on exceptions, but also deals with skipping over rich 171837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // response headers. Callers should use this to read & parse the 172837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick // response headers rather than doing it by hand. 173837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick int32_t readExceptionCode() const; 174837a0d0fb2c3fba8082d47d04cb6120af1eb9a54Brad Fitzpatrick 175a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // Retrieve native_handle from the parcel. This returns a copy of the 176a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // parcel's native_handle (the caller takes ownership). The caller 177a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // must free the native_handle with native_handle_close() and 178a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian // native_handle_delete(). 179a47f02afb1e1f2c4abd9379c13903a5dde89d354Mathias Agopian native_handle* readNativeHandle() const; 180edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 181edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 182edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project // Retrieve a file descriptor from the parcel. This returns the raw fd 183edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project // in the parcel, which you do not own -- use dup() to get your own copy. 184edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project int readFileDescriptor() const; 1855707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 1865707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown // Reads a blob from the parcel. 1875707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown // The caller should call release() on the blob after reading its contents. 1885707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown status_t readBlob(size_t len, ReadableBlob* outBlob) const; 1895707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 190edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const flat_binder_object* readObject(bool nullMetaData) const; 191edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 192edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project // Explicitly close all file descriptors in the parcel. 193edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void closeFileDescriptors(); 194edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 195edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project typedef void (*release_func)(Parcel* parcel, 196edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const uint8_t* data, size_t dataSize, 197edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const size_t* objects, size_t objectsSize, 198edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void* cookie); 199edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 200edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const uint8_t* ipcData() const; 201edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t ipcDataSize() const; 202edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const size_t* ipcObjects() const; 203edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t ipcObjectsCount() const; 204edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void ipcSetDataReference(const uint8_t* data, size_t dataSize, 205edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const size_t* objects, size_t objectsCount, 206edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project release_func relFunc, void* relCookie); 207edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 208edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void print(TextOutput& to, uint32_t flags = 0) const; 2095707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 210edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectprivate: 211edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project Parcel(const Parcel& o); 212edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project Parcel& operator=(const Parcel& o); 213edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 214edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t finishWrite(size_t len); 215edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void releaseObjects(); 216edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void acquireObjects(); 217edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t growData(size_t len); 218edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t restartWrite(size_t desired); 219edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t continueWrite(size_t desired); 220edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void freeDataNoInit(); 221edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void initState(); 222edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void scanForFds() const; 223edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 22484a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber template<class T> 22584a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber status_t readAligned(T *pArg) const; 22684a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber 22784a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber template<class T> T readAligned() const; 22884a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber 22984a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber template<class T> 23084a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber status_t writeAligned(T val); 23184a6d041e2c69d4d0b69269a0b59e725c9f119a3Andreas Huber 232edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project status_t mError; 233edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project uint8_t* mData; 234edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t mDataSize; 235edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t mDataCapacity; 236edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project mutable size_t mDataPos; 237edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t* mObjects; 238edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t mObjectsSize; 239edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project size_t mObjectsCapacity; 240edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project mutable size_t mNextObjectHint; 241edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 242edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project mutable bool mFdsKnown; 243edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project mutable bool mHasFds; 2448938ed2c8e906fc332301b64787728d4d34da571Dianne Hackborn bool mAllowFds; 245edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 246edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project release_func mOwner; 247edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project void* mOwnerCookie; 2485707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 2495707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown class Blob { 2505707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown public: 2515707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown Blob(); 2525707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown ~Blob(); 2535707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 2545707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown void release(); 2555707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown inline size_t size() const { return mSize; } 2565707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 2575707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown protected: 2585707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown void init(bool mapped, void* data, size_t size); 2595707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown void clear(); 2605707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 2615707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown bool mMapped; 2625707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown void* mData; 2635707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown size_t mSize; 2645707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown }; 2655707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 266e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian class FlattenableHelperInterface { 267e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian protected: 268e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian ~FlattenableHelperInterface() { } 269e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian public: 270e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual size_t getFlattenedSize() const = 0; 271e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual size_t getFdCount() const = 0; 272e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual status_t flatten(void* buffer, size_t size, int* fds, size_t count) const = 0; 273e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual status_t unflatten(void const* buffer, size_t size, int const* fds, size_t count) = 0; 274e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian }; 275e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian 276e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian template<typename T> 277e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian class FlattenableHelper : public FlattenableHelperInterface { 278e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian friend class Parcel; 279e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian const Flattenable<T>& val; 280e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian explicit FlattenableHelper(const Flattenable<T>& val) : val(val) { } 281e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian 282e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian public: 283e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual size_t getFlattenedSize() const { 284e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return val.getFlattenedSize(); 285e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian } 286e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual size_t getFdCount() const { 287e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return val.getFdCount(); 288e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian } 289e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual status_t flatten(void* buffer, size_t size, int* fds, size_t count) const { 290e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return val.flatten(buffer, size, fds, count); 291e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian } 292e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian virtual status_t unflatten(void const* buffer, size_t size, int const* fds, size_t count) { 293e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return const_cast<Flattenable<T>&>(val).unflatten(buffer, size, fds, count); 294e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian } 295e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian }; 296e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian status_t write(const FlattenableHelperInterface& val); 297e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian status_t read(FlattenableHelperInterface& val) const; 298e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian 2995707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brownpublic: 3005707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown class ReadableBlob : public Blob { 3015707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown friend class Parcel; 3025707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown public: 3035707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown inline const void* data() const { return mData; } 3045707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown }; 3055707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown 3065707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown class WritableBlob : public Blob { 3075707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown friend class Parcel; 3085707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown public: 3095707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown inline void* data() { return mData; } 3105707dbf15d0b44c88fbaa6dd271097f2d42932e0Jeff Brown }; 311edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project}; 312edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 313edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 314edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 3158683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopiantemplate<typename T> 316e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopianstatus_t Parcel::write(const Flattenable<T>& val) { 317e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian const FlattenableHelper<T> helper(val); 318e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return write(helper); 319e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian} 320e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian 321e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopiantemplate<typename T> 3228683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopianstatus_t Parcel::write(const LightFlattenable<T>& val) { 323e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian size_t size(val.getFlattenedSize()); 3248683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian if (!val.isFixedSize()) { 3258683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian status_t err = writeInt32(size); 3268683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian if (err != NO_ERROR) { 3278683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian return err; 3288683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian } 3298683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian } 3302098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian if (size) { 3312098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian void* buffer = writeInplace(size); 332e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian if (buffer == NULL) 333e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return NO_MEMORY; 334e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return val.flatten(buffer, size); 3352098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian } 3362098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian return NO_ERROR; 3378683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian} 3388683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian 3398683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopiantemplate<typename T> 340e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopianstatus_t Parcel::read(Flattenable<T>& val) const { 341e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian FlattenableHelper<T> helper(val); 342e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian return read(helper); 343e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian} 344e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian 345e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopiantemplate<typename T> 3468683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopianstatus_t Parcel::read(LightFlattenable<T>& val) const { 3478683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian size_t size; 3488683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian if (val.isFixedSize()) { 349e142428a9c8b9d2380032cd4d7b55ee440fe8770Mathias Agopian size = val.getFlattenedSize(); 3508683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian } else { 3518683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian int32_t s; 3528683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian status_t err = readInt32(&s); 3538683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian if (err != NO_ERROR) { 3548683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian return err; 3558683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian } 3568683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian size = s; 3578683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian } 3582098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian if (size) { 3592098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian void const* buffer = readInplace(size); 3602098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian return buffer == NULL ? NO_MEMORY : 3612098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian val.unflatten(buffer, size); 3622098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian } 3632098517e3e12a401005d7a7510d6c4943707b98dMathias Agopian return NO_ERROR; 3648683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian} 3658683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian 3668683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian// --------------------------------------------------------------------------- 3678683fca395d01734ec7946e9f0595ec5d7b754c6Mathias Agopian 368edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectinline TextOutput& operator<<(TextOutput& to, const Parcel& parcel) 369edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project{ 370edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project parcel.print(to); 371edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project return to; 372edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project} 373edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 374edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 375edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 376edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// Generic acquire and release of objects. 377edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectvoid acquire_object(const sp<ProcessState>& proc, 378edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const flat_binder_object& obj, const void* who); 379edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectvoid release_object(const sp<ProcessState>& proc, 380edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const flat_binder_object& obj, const void* who); 381edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 382edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectvoid flatten_binder(const sp<ProcessState>& proc, 383edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const sp<IBinder>& binder, flat_binder_object* out); 384edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectvoid flatten_binder(const sp<ProcessState>& proc, 385edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const wp<IBinder>& binder, flat_binder_object* out); 386edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectstatus_t unflatten_binder(const sp<ProcessState>& proc, 387edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const flat_binder_object& flat, sp<IBinder>* out); 388edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectstatus_t unflatten_binder(const sp<ProcessState>& proc, 389edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project const flat_binder_object& flat, wp<IBinder>* out); 390edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 391edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project}; // namespace android 392edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 393edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 394edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 395edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#endif // ANDROID_PARCEL_H 396