blob: 58f3b87f1f5f07d290762c86fa2a5a4254e3bbc1 [file] [log] [blame]
/*
* Copyright (C) 2014-2018 ARM Limited. All rights reserved.
*
* Copyright (C) 2008 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef GRALLOC_BUFFER_PRIV_H_
#define GRALLOC_BUFFER_PRIV_H_
#include "gralloc_priv.h"
#include <errno.h>
#include <string.h>
#include "mali_gralloc_private_interface_types.h"
// private gralloc buffer manipulation API
struct attr_region
{
/* Rectangle to be cropped from the full frame (Origin in top-left corner!) */
int crop_top;
int crop_left;
int crop_height;
int crop_width;
int use_yuv_transform; /* DEPRECATED. Now explicitly signalled by gralloc through MALI_GRALLOC_INTFMT_AFBC_YUV_TRANSFORM */
int use_sparse_alloc;
mali_hdr_info hdr_info;
android_dataspace_t dataspace;
android_dataspace_t force_dataspace;
} __attribute__((packed));
typedef struct attr_region attr_region;
/*
* Allocate shared memory for attribute storage. Only to be
* used by gralloc internally.
*
* Return 0 on success.
*/
int gralloc_buffer_attr_allocate(struct private_handle_t *hnd);
/*
* Frees the shared memory allocated for attribute storage.
* Only to be used by gralloc internally.
* Return 0 on success.
*/
int gralloc_buffer_attr_free(struct private_handle_t *hnd);
/*
* Map the attribute storage area before attempting to
* read/write from it.
*
* Return 0 on success.
*/
static inline int gralloc_buffer_attr_map(struct private_handle_t *hnd, int readwrite)
{
int rval = -1;
int prot_flags = PROT_READ;
int share_attr_fd = -1;
if (!hnd)
{
goto out;
}
share_attr_fd = hnd->get_share_attr_fd();
if (share_attr_fd < 0)
{
ALOGE("Shared attribute region not available to be mapped");
goto out;
}
if (readwrite)
{
prot_flags |= PROT_WRITE;
}
hnd->attr_base = mmap(NULL, PAGE_SIZE, prot_flags, MAP_SHARED, share_attr_fd, 0);
if (hnd->attr_base == MAP_FAILED)
{
ALOGE("Failed to mmap shared attribute region err=%s", strerror(errno));
goto out;
}
rval = 0;
out:
return rval;
}
/*
* Unmap the attribute storage area when done with it.
*
* Return 0 on success.
*/
static inline int gralloc_buffer_attr_unmap(struct private_handle_t *hnd)
{
int rval = -1;
if (!hnd)
{
goto out;
}
if (hnd->attr_base != MAP_FAILED)
{
if (munmap(hnd->attr_base, PAGE_SIZE) == 0)
{
hnd->attr_base = MAP_FAILED;
rval = 0;
}
}
out:
return rval;
}
/*
* Read or write an attribute from/to the storage area.
*
* Return 0 on success.
*/
static inline int gralloc_buffer_attr_write(struct private_handle_t *hnd, buf_attr attr, int *val)
{
int rval = -1;
if (!hnd || !val || attr >= GRALLOC_ARM_BUFFER_ATTR_LAST)
{
goto out;
}
if (hnd->attr_base != MAP_FAILED)
{
attr_region *region = (attr_region *)hnd->attr_base;
switch (attr)
{
case GRALLOC_ARM_BUFFER_ATTR_CROP_RECT:
memcpy(&region->crop_top, val, sizeof(int) * 4);
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_AFBC_YUV_TRANS:
region->use_yuv_transform = *val;
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_AFBC_SPARSE_ALLOC:
region->use_sparse_alloc = *val;
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_HDR_INFO:
memcpy(&region->hdr_info, val, sizeof(mali_hdr_info));
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_DATASPACE:
region->dataspace = *((android_dataspace_t *)val);
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_FORCE_DATASPACE:
region->force_dataspace = *((android_dataspace_t *)val);
rval = 0;
break;
}
}
out:
return rval;
}
static inline int gralloc_buffer_attr_read(struct private_handle_t *hnd, buf_attr attr, int *val)
{
int rval = -1;
if (!hnd || !val || attr >= GRALLOC_ARM_BUFFER_ATTR_LAST)
{
goto out;
}
if (hnd->attr_base != MAP_FAILED)
{
attr_region *region = (attr_region *)hnd->attr_base;
switch (attr)
{
case GRALLOC_ARM_BUFFER_ATTR_CROP_RECT:
memcpy(val, &region->crop_top, sizeof(int) * 4);
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_AFBC_YUV_TRANS:
*val = region->use_yuv_transform;
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_AFBC_SPARSE_ALLOC:
*val = region->use_sparse_alloc;
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_HDR_INFO:
memcpy(val, &region->hdr_info, sizeof(mali_hdr_info));
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_DATASPACE:
*val = region->dataspace;
rval = 0;
break;
case GRALLOC_ARM_BUFFER_ATTR_FORCE_DATASPACE:
*val = region->force_dataspace;
rval = 0;
break;
}
}
out:
return rval;
}
#endif /* GRALLOC_BUFFER_PRIV_H_ */