Loading include/ui/GraphicBuffer.h +10 −0 Original line number Original line Diff line number Diff line Loading @@ -26,6 +26,8 @@ #include <utils/Flattenable.h> #include <utils/Flattenable.h> #include <pixelflinger/pixelflinger.h> #include <pixelflinger/pixelflinger.h> #include <hardware/hardware.h> struct android_native_buffer_t; struct android_native_buffer_t; namespace android { namespace android { Loading Loading @@ -63,6 +65,13 @@ public: USAGE_HW_MASK = GRALLOC_USAGE_HW_MASK USAGE_HW_MASK = GRALLOC_USAGE_HW_MASK }; }; enum { TRANSFORM_IDENTITY = 0, TRANSFORM_ROT_90 = HAL_TRANSFORM_ROT_90, TRANSFORM_ROT_180 = HAL_TRANSFORM_ROT_180, TRANSFORM_ROT_270 = HAL_TRANSFORM_ROT_270 }; GraphicBuffer(); GraphicBuffer(); // creates w * h buffer // creates w * h buffer Loading @@ -79,6 +88,7 @@ public: uint32_t getHeight() const { return height; } uint32_t getHeight() const { return height; } uint32_t getStride() const { return stride; } uint32_t getStride() const { return stride; } uint32_t getUsage() const { return usage; } uint32_t getUsage() const { return usage; } uint32_t getTransform() const { return transform; } PixelFormat getPixelFormat() const { return format; } PixelFormat getPixelFormat() const { return format; } Rect getBounds() const { return Rect(width, height); } Rect getBounds() const { return Rect(width, height); } Loading include/ui/android_native_buffer.h +6 −2 Original line number Original line Diff line number Diff line Loading @@ -52,7 +52,11 @@ typedef struct android_native_buffer_t int format; int format; int usage; int usage; void* reserved[2]; /* transformation as defined in hardware.h */ uint8_t transform; uint8_t reserved_bytes[3]; void* reserved[1]; buffer_handle_t handle; buffer_handle_t handle; Loading libs/ui/GraphicBuffer.cpp +13 −6 Original line number Original line Diff line number Diff line Loading @@ -45,6 +45,7 @@ GraphicBuffer::GraphicBuffer() stride = stride = format = format = usage = 0; usage = 0; transform = 0; handle = NULL; handle = NULL; } } Loading @@ -57,7 +58,8 @@ GraphicBuffer::GraphicBuffer(uint32_t w, uint32_t h, height = height = stride = stride = format = format = usage = 0; usage = transform = 0; handle = NULL; handle = NULL; mInitCheck = initSize(w, h, reqFormat, reqUsage); mInitCheck = initSize(w, h, reqFormat, reqUsage); } } Loading @@ -74,6 +76,7 @@ GraphicBuffer::GraphicBuffer(uint32_t w, uint32_t h, stride = inStride; stride = inStride; format = inFormat; format = inFormat; usage = inUsage; usage = inUsage; transform = 0; handle = inHandle; handle = inHandle; } } Loading Loading @@ -182,8 +185,10 @@ status_t GraphicBuffer::lock(GGLSurface* sur, uint32_t usage) return res; return res; } } const int kFlattenFdsOffset = 9; size_t GraphicBuffer::getFlattenedSize() const { size_t GraphicBuffer::getFlattenedSize() const { return (8 + (handle ? handle->numInts : 0))*sizeof(int); return (kFlattenFdsOffset + (handle ? handle->numInts : 0))*sizeof(int); } } size_t GraphicBuffer::getFdCount() const { size_t GraphicBuffer::getFdCount() const { Loading @@ -208,13 +213,14 @@ status_t GraphicBuffer::flatten(void* buffer, size_t size, buf[5] = usage; buf[5] = usage; buf[6] = 0; buf[6] = 0; buf[7] = 0; buf[7] = 0; buf[8] = transform; if (handle) { if (handle) { buf[6] = handle->numFds; buf[6] = handle->numFds; buf[7] = handle->numInts; buf[7] = handle->numInts; native_handle_t const* const h = handle; native_handle_t const* const h = handle; memcpy(fds, h->data, h->numFds*sizeof(int)); memcpy(fds, h->data, h->numFds*sizeof(int)); memcpy(&buf[8], h->data + h->numFds, h->numInts*sizeof(int)); memcpy(&buf[kFlattenFdsOffset], h->data + h->numFds, h->numInts*sizeof(int)); } } return NO_ERROR; return NO_ERROR; Loading @@ -223,7 +229,7 @@ status_t GraphicBuffer::flatten(void* buffer, size_t size, status_t GraphicBuffer::unflatten(void const* buffer, size_t size, status_t GraphicBuffer::unflatten(void const* buffer, size_t size, int fds[], size_t count) int fds[], size_t count) { { if (size < 8*sizeof(int)) return NO_MEMORY; if (size < kFlattenFdsOffset*sizeof(int)) return NO_MEMORY; int const* buf = static_cast<int const*>(buffer); int const* buf = static_cast<int const*>(buffer); if (buf[0] != 'GBFR') return BAD_TYPE; if (buf[0] != 'GBFR') return BAD_TYPE; Loading @@ -231,7 +237,7 @@ status_t GraphicBuffer::unflatten(void const* buffer, size_t size, const size_t numFds = buf[6]; const size_t numFds = buf[6]; const size_t numInts = buf[7]; const size_t numInts = buf[7]; const size_t sizeNeeded = (8 + numInts) * sizeof(int); const size_t sizeNeeded = (kFlattenFdsOffset + numInts) * sizeof(int); if (size < sizeNeeded) return NO_MEMORY; if (size < sizeNeeded) return NO_MEMORY; size_t fdCountNeeded = 0; size_t fdCountNeeded = 0; Loading @@ -248,9 +254,10 @@ status_t GraphicBuffer::unflatten(void const* buffer, size_t size, stride = buf[3]; stride = buf[3]; format = buf[4]; format = buf[4]; usage = buf[5]; usage = buf[5]; transform = buf[8]; native_handle* h = native_handle_create(numFds, numInts); native_handle* h = native_handle_create(numFds, numInts); memcpy(h->data, fds, numFds*sizeof(int)); memcpy(h->data, fds, numFds*sizeof(int)); memcpy(h->data + numFds, &buf[8], numInts*sizeof(int)); memcpy(h->data + numFds, &buf[kFlattenFdsOffset], numInts*sizeof(int)); handle = h; handle = h; } else { } else { width = height = stride = format = usage = 0; width = height = stride = format = usage = 0; Loading services/surfaceflinger/Android.mk +1 −0 Original line number Original line Diff line number Diff line Loading @@ -25,6 +25,7 @@ ifeq ($(TARGET_BOARD_PLATFORM), omap3) endif endif ifeq ($(TARGET_BOARD_PLATFORM), s5pc110) ifeq ($(TARGET_BOARD_PLATFORM), s5pc110) LOCAL_CFLAGS += -DHAS_CONTEXT_PRIORITY LOCAL_CFLAGS += -DHAS_CONTEXT_PRIORITY LOCAL_CFLAGS += -DUSE_COMPOSITION_BYPASS endif endif Loading services/surfaceflinger/DisplayHardware/DisplayHardware.cpp +6 −0 Original line number Original line Diff line number Diff line Loading @@ -339,6 +339,12 @@ void DisplayHardware::flip(const Region& dirty) const //glClear(GL_COLOR_BUFFER_BIT); //glClear(GL_COLOR_BUFFER_BIT); } } status_t DisplayHardware::postBypassBuffer(const native_handle_t* handle) const { framebuffer_device_t *fbDev = (framebuffer_device_t *)mNativeWindow->getDevice(); return fbDev->post(fbDev, handle); } uint32_t DisplayHardware::getFlags() const uint32_t DisplayHardware::getFlags() const { { return mFlags; return mFlags; Loading Loading
include/ui/GraphicBuffer.h +10 −0 Original line number Original line Diff line number Diff line Loading @@ -26,6 +26,8 @@ #include <utils/Flattenable.h> #include <utils/Flattenable.h> #include <pixelflinger/pixelflinger.h> #include <pixelflinger/pixelflinger.h> #include <hardware/hardware.h> struct android_native_buffer_t; struct android_native_buffer_t; namespace android { namespace android { Loading Loading @@ -63,6 +65,13 @@ public: USAGE_HW_MASK = GRALLOC_USAGE_HW_MASK USAGE_HW_MASK = GRALLOC_USAGE_HW_MASK }; }; enum { TRANSFORM_IDENTITY = 0, TRANSFORM_ROT_90 = HAL_TRANSFORM_ROT_90, TRANSFORM_ROT_180 = HAL_TRANSFORM_ROT_180, TRANSFORM_ROT_270 = HAL_TRANSFORM_ROT_270 }; GraphicBuffer(); GraphicBuffer(); // creates w * h buffer // creates w * h buffer Loading @@ -79,6 +88,7 @@ public: uint32_t getHeight() const { return height; } uint32_t getHeight() const { return height; } uint32_t getStride() const { return stride; } uint32_t getStride() const { return stride; } uint32_t getUsage() const { return usage; } uint32_t getUsage() const { return usage; } uint32_t getTransform() const { return transform; } PixelFormat getPixelFormat() const { return format; } PixelFormat getPixelFormat() const { return format; } Rect getBounds() const { return Rect(width, height); } Rect getBounds() const { return Rect(width, height); } Loading
include/ui/android_native_buffer.h +6 −2 Original line number Original line Diff line number Diff line Loading @@ -52,7 +52,11 @@ typedef struct android_native_buffer_t int format; int format; int usage; int usage; void* reserved[2]; /* transformation as defined in hardware.h */ uint8_t transform; uint8_t reserved_bytes[3]; void* reserved[1]; buffer_handle_t handle; buffer_handle_t handle; Loading
libs/ui/GraphicBuffer.cpp +13 −6 Original line number Original line Diff line number Diff line Loading @@ -45,6 +45,7 @@ GraphicBuffer::GraphicBuffer() stride = stride = format = format = usage = 0; usage = 0; transform = 0; handle = NULL; handle = NULL; } } Loading @@ -57,7 +58,8 @@ GraphicBuffer::GraphicBuffer(uint32_t w, uint32_t h, height = height = stride = stride = format = format = usage = 0; usage = transform = 0; handle = NULL; handle = NULL; mInitCheck = initSize(w, h, reqFormat, reqUsage); mInitCheck = initSize(w, h, reqFormat, reqUsage); } } Loading @@ -74,6 +76,7 @@ GraphicBuffer::GraphicBuffer(uint32_t w, uint32_t h, stride = inStride; stride = inStride; format = inFormat; format = inFormat; usage = inUsage; usage = inUsage; transform = 0; handle = inHandle; handle = inHandle; } } Loading Loading @@ -182,8 +185,10 @@ status_t GraphicBuffer::lock(GGLSurface* sur, uint32_t usage) return res; return res; } } const int kFlattenFdsOffset = 9; size_t GraphicBuffer::getFlattenedSize() const { size_t GraphicBuffer::getFlattenedSize() const { return (8 + (handle ? handle->numInts : 0))*sizeof(int); return (kFlattenFdsOffset + (handle ? handle->numInts : 0))*sizeof(int); } } size_t GraphicBuffer::getFdCount() const { size_t GraphicBuffer::getFdCount() const { Loading @@ -208,13 +213,14 @@ status_t GraphicBuffer::flatten(void* buffer, size_t size, buf[5] = usage; buf[5] = usage; buf[6] = 0; buf[6] = 0; buf[7] = 0; buf[7] = 0; buf[8] = transform; if (handle) { if (handle) { buf[6] = handle->numFds; buf[6] = handle->numFds; buf[7] = handle->numInts; buf[7] = handle->numInts; native_handle_t const* const h = handle; native_handle_t const* const h = handle; memcpy(fds, h->data, h->numFds*sizeof(int)); memcpy(fds, h->data, h->numFds*sizeof(int)); memcpy(&buf[8], h->data + h->numFds, h->numInts*sizeof(int)); memcpy(&buf[kFlattenFdsOffset], h->data + h->numFds, h->numInts*sizeof(int)); } } return NO_ERROR; return NO_ERROR; Loading @@ -223,7 +229,7 @@ status_t GraphicBuffer::flatten(void* buffer, size_t size, status_t GraphicBuffer::unflatten(void const* buffer, size_t size, status_t GraphicBuffer::unflatten(void const* buffer, size_t size, int fds[], size_t count) int fds[], size_t count) { { if (size < 8*sizeof(int)) return NO_MEMORY; if (size < kFlattenFdsOffset*sizeof(int)) return NO_MEMORY; int const* buf = static_cast<int const*>(buffer); int const* buf = static_cast<int const*>(buffer); if (buf[0] != 'GBFR') return BAD_TYPE; if (buf[0] != 'GBFR') return BAD_TYPE; Loading @@ -231,7 +237,7 @@ status_t GraphicBuffer::unflatten(void const* buffer, size_t size, const size_t numFds = buf[6]; const size_t numFds = buf[6]; const size_t numInts = buf[7]; const size_t numInts = buf[7]; const size_t sizeNeeded = (8 + numInts) * sizeof(int); const size_t sizeNeeded = (kFlattenFdsOffset + numInts) * sizeof(int); if (size < sizeNeeded) return NO_MEMORY; if (size < sizeNeeded) return NO_MEMORY; size_t fdCountNeeded = 0; size_t fdCountNeeded = 0; Loading @@ -248,9 +254,10 @@ status_t GraphicBuffer::unflatten(void const* buffer, size_t size, stride = buf[3]; stride = buf[3]; format = buf[4]; format = buf[4]; usage = buf[5]; usage = buf[5]; transform = buf[8]; native_handle* h = native_handle_create(numFds, numInts); native_handle* h = native_handle_create(numFds, numInts); memcpy(h->data, fds, numFds*sizeof(int)); memcpy(h->data, fds, numFds*sizeof(int)); memcpy(h->data + numFds, &buf[8], numInts*sizeof(int)); memcpy(h->data + numFds, &buf[kFlattenFdsOffset], numInts*sizeof(int)); handle = h; handle = h; } else { } else { width = height = stride = format = usage = 0; width = height = stride = format = usage = 0; Loading
services/surfaceflinger/Android.mk +1 −0 Original line number Original line Diff line number Diff line Loading @@ -25,6 +25,7 @@ ifeq ($(TARGET_BOARD_PLATFORM), omap3) endif endif ifeq ($(TARGET_BOARD_PLATFORM), s5pc110) ifeq ($(TARGET_BOARD_PLATFORM), s5pc110) LOCAL_CFLAGS += -DHAS_CONTEXT_PRIORITY LOCAL_CFLAGS += -DHAS_CONTEXT_PRIORITY LOCAL_CFLAGS += -DUSE_COMPOSITION_BYPASS endif endif Loading
services/surfaceflinger/DisplayHardware/DisplayHardware.cpp +6 −0 Original line number Original line Diff line number Diff line Loading @@ -339,6 +339,12 @@ void DisplayHardware::flip(const Region& dirty) const //glClear(GL_COLOR_BUFFER_BIT); //glClear(GL_COLOR_BUFFER_BIT); } } status_t DisplayHardware::postBypassBuffer(const native_handle_t* handle) const { framebuffer_device_t *fbDev = (framebuffer_device_t *)mNativeWindow->getDevice(); return fbDev->post(fbDev, handle); } uint32_t DisplayHardware::getFlags() const uint32_t DisplayHardware::getFlags() const { { return mFlags; return mFlags; Loading