auto import from //branches/cupcake/...@127101
diff --git a/include/ui/Overlay.h b/include/ui/Overlay.h
index 9c7bc47..f8454fd 100644
--- a/include/ui/Overlay.h
+++ b/include/ui/Overlay.h
@@ -40,7 +40,7 @@
class OverlayRef : public LightRefBase<OverlayRef>
{
public:
- OverlayRef(overlay_handle_t const*, const sp<IOverlay>&,
+ OverlayRef(overlay_handle_t, const sp<IOverlay>&,
uint32_t w, uint32_t h, int32_t f, uint32_t ws, uint32_t hs);
static sp<OverlayRef> readFromParcel(const Parcel& data);
@@ -53,7 +53,7 @@
OverlayRef();
virtual ~OverlayRef();
- overlay_handle_t const *mOverlayHandle;
+ overlay_handle_t mOverlayHandle;
sp<IOverlay> mOverlayChannel;
uint32_t mWidth;
uint32_t mHeight;
@@ -74,7 +74,7 @@
void destroy();
/* get the HAL handle for this overlay */
- overlay_handle_t const* getHandleRef() const;
+ overlay_handle_t getHandleRef() const;
/* blocks until an overlay buffer is available and return that buffer. */
status_t dequeueBuffer(overlay_buffer_t* buffer);
diff --git a/include/utils/Parcel.h b/include/utils/Parcel.h
index 7c451ab..9087c44 100644
--- a/include/utils/Parcel.h
+++ b/include/utils/Parcel.h
@@ -17,6 +17,7 @@
#ifndef ANDROID_PARCEL_H
#define ANDROID_PARCEL_H
+#include <cutils/native_handle.h>
#include <utils/Errors.h>
#include <utils/RefBase.h>
#include <utils/String16.h>
@@ -78,6 +79,9 @@
status_t writeString16(const char16_t* str, size_t len);
status_t writeStrongBinder(const sp<IBinder>& val);
status_t writeWeakBinder(const wp<IBinder>& val);
+
+ // doesn't take ownership of the native_handle
+ status_t writeNativeHandle(const native_handle& handle);
// Place a file descriptor into the parcel. The given fd must remain
// valid for the lifetime of the parcel.
@@ -108,6 +112,15 @@
const char16_t* readString16Inplace(size_t* outLen) const;
sp<IBinder> readStrongBinder() const;
wp<IBinder> readWeakBinder() const;
+
+
+ // if alloc is NULL, native_handle is allocated with malloc(), otherwise
+ // alloc is used. If the function fails, the effects of alloc() must be
+ // reverted by the caller.
+ native_handle* readNativeHandle(
+ native_handle* (*alloc)(void* cookie, int numFds, int ints),
+ void* cookie) const;
+
// Retrieve a file descriptor from the parcel. This returns the raw fd
// in the parcel, which you do not own -- use dup() to get your own copy.