We need to share the cb_hande_t between gralloc/EGL/GLES, moved it into the opengl system common lib. Also added eglSwapBuffers implementation. Change-Id: Ia461a48c273af42293aafcf084e457adf03cbed3
77 lines
2.3 KiB
C
77 lines
2.3 KiB
C
#ifndef __GRALLOC_CB_H__
|
|
#define __GRALLOC_CB_H__
|
|
|
|
#include <hardware/hardware.h>
|
|
#include <hardware/gralloc.h>
|
|
#include <cutils/native_handle.h>
|
|
|
|
#define BUFFER_HANDLE_MAGIC ((int)0xabfabfab)
|
|
#define CB_HANDLE_NUM_INTS(nfds) ((sizeof(cb_handle_t) - (nfds)*sizeof(int)) / sizeof(int))
|
|
|
|
//
|
|
// Our buffer handle structure
|
|
//
|
|
struct cb_handle_t : public native_handle {
|
|
|
|
cb_handle_t(int p_fd, int p_ashmemSize, int p_usage,
|
|
int p_width, int p_height, int p_glFormat) :
|
|
fd(p_fd),
|
|
magic(BUFFER_HANDLE_MAGIC),
|
|
usage(p_usage),
|
|
width(p_width),
|
|
height(p_height),
|
|
glFormat(p_glFormat),
|
|
ashmemSize(p_ashmemSize),
|
|
ashmemBase(NULL),
|
|
ashmemBasePid(0),
|
|
mappedPid(0),
|
|
lockedLeft(0),
|
|
lockedTop(0),
|
|
lockedWidth(0),
|
|
lockedHeight(0),
|
|
hostHandle(0)
|
|
{
|
|
version = sizeof(native_handle);
|
|
numFds = 1;
|
|
numInts = CB_HANDLE_NUM_INTS(numFds);
|
|
}
|
|
|
|
~cb_handle_t() {
|
|
magic = 0;
|
|
}
|
|
|
|
bool validate() const {
|
|
return (version == sizeof(native_handle) &&
|
|
magic == BUFFER_HANDLE_MAGIC &&
|
|
numInts == CB_HANDLE_NUM_INTS(1) &&
|
|
numFds == 1);
|
|
}
|
|
|
|
bool canBePosted() {
|
|
return (0 != (usage & GRALLOC_USAGE_HW_FB));
|
|
}
|
|
|
|
// file-descriptors
|
|
int fd; // ashmem fd (-1 of ashmem region did not allocated, i.e. no SW access needed)
|
|
|
|
// ints
|
|
int magic; // magic number in order to validate a pointer to be a cb_handle_t
|
|
int usage; // usage bits the buffer was created with
|
|
int width; // buffer width
|
|
int height; // buffer height
|
|
int glFormat; // OpenGL format enum used for host h/w color buffer
|
|
int ashmemSize; // ashmem region size for the buffer (0 unless is HW_FB buffer or
|
|
// s/w access is needed)
|
|
int ashmemBase; // CPU address of the mapped ashmem region
|
|
int ashmemBasePid; // process id which mapped the ashmem region
|
|
int mappedPid; // process id which succeeded gralloc_register call
|
|
int lockedLeft; // region of buffer locked for s/w write
|
|
int lockedTop;
|
|
int lockedWidth;
|
|
int lockedHeight;
|
|
uint32_t hostHandle;
|
|
};
|
|
|
|
|
|
#endif //__GRALLOC_CB_H__
|