/* * 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 #include #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(®ion->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(®ion->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, ®ion->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, ®ion->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_ */