[Mesa-dev] [PATCH v2 1/6] android: Move gralloc handle struct to libdrm
Rob Herring
robh at kernel.org
Tue Feb 6 00:08:16 UTC 2018
On Mon, Jan 29, 2018 at 11:37 AM, Robert Foss <robert.foss at collabora.com> wrote:
> This struct is used in mesa and drm_hwcomposer.
> Versions of if have been implemented in several grallocs:
> drm_gralloc, gbm_gralloc, minigbm and intel-minigbm.
>
> Other than the 1:1 move of the struct a new generic name
> has been chosen and variables have had comments added to them.
>
> Signed-off-by: Robert Foss <robert.foss at collabora.com>
> ---
> Changes since v1:
> Suggested by Rob Herring:
> - Fixed copyright statement
> - Moved FDs to be first in handle
> - Initialize native_handle_t using native_handle_create()
>
> Android.mk | 8 +++-
> Makefile.sources | 3 ++
> android/gralloc_handle.h | 102 +++++++++++++++++++++++++++++++++++++++++++++++
> 3 files changed, 111 insertions(+), 2 deletions(-)
> create mode 100644 android/gralloc_handle.h
>
> diff --git a/Android.mk b/Android.mk
> index 292be2360263..8611c5e316d8 100644
> --- a/Android.mk
> +++ b/Android.mk
> @@ -28,7 +28,7 @@ LIBDRM_TOP := $(LOCAL_PATH)
>
> include $(CLEAR_VARS)
>
> -# Import variables LIBDRM_{,H_,INCLUDE_H_,INCLUDE_VMWGFX_H_}FILES
> +# Import variables LIBDRM_{,H,INCLUDE_H,INCLUDE_ANDROID_H,INCLUDE_VMWGFX_H}_FILES
> include $(LOCAL_PATH)/Makefile.sources
>
> #static library for the device (recovery)
> @@ -38,7 +38,8 @@ LOCAL_MODULE := libdrm
> LOCAL_SRC_FILES := $(LIBDRM_FILES)
> LOCAL_EXPORT_C_INCLUDE_DIRS := \
> $(LOCAL_PATH) \
> - $(LOCAL_PATH)/include/drm
> + $(LOCAL_PATH)/include/drm \
> + $(LOCAL_PATH)/android
>
> LOCAL_C_INCLUDES := \
> $(LOCAL_PATH)/include/drm
> @@ -54,6 +55,9 @@ LOCAL_SRC_FILES := $(LIBDRM_FILES)
> LOCAL_EXPORT_C_INCLUDE_DIRS := \
> $(LOCAL_PATH)/include/drm
>
> +LOCAL_SHARED_LIBRARIES := \
> + libcutils
> +
> LOCAL_C_INCLUDES := \
> $(LOCAL_PATH)/include/drm
>
> diff --git a/Makefile.sources b/Makefile.sources
> index 10aa1d0f4b6e..1f8372bca183 100644
> --- a/Makefile.sources
> +++ b/Makefile.sources
> @@ -37,5 +37,8 @@ LIBDRM_INCLUDE_H_FILES := \
> include/drm/via_drm.h \
> include/drm/virtgpu_drm.h
>
> +LIBDRM_INCLUDE_ANDROID_H_FILES := \
> + android/gralloc_handle.h
> +
> LIBDRM_INCLUDE_VMWGFX_H_FILES := \
> include/drm/vmwgfx_drm.h
> diff --git a/android/gralloc_handle.h b/android/gralloc_handle.h
> new file mode 100644
> index 000000000000..770ee7adb4b5
> --- /dev/null
> +++ b/android/gralloc_handle.h
> @@ -0,0 +1,102 @@
> +/*
> + * Copyright (C) 2018 Robert Foss <robert.foss at collabora.com>
Sorry, if I wasn't clear, but this obviously comes from
gralloc_drm_handle.h. You should maintain those copyrights (and make
sure we aren't changing the license).
> + *
> + * Permission is hereby granted, free of charge, to any person obtaining a
> + * copy of this software and associated documentation files (the "Software"),
> + * to deal in the Software without restriction, including without limitation
> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
> + * and/or sell copies of the Software, and to permit persons to whom the
> + * Software is furnished to do so, subject to the following conditions:
> + *
> + * The above copyright notice and this permission notice (including the next
> + * paragraph) shall be included in all copies or substantial portions of the
> + * Software.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
> + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
> + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
> + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
> + * SOFTWARE.
> + *
> + * Authors:
> + * Robert Foss <robert.foss at collabora.com>
> + */
> +
> +#ifndef __ANDROID_GRALLOC_HANDLE_H__
> +#define __ANDROID_GRALLOC_HANDLE_H__
> +
> +#include <cutils/native_handle.h>
> +
> +/* support users of drm_gralloc/gbm_gralloc */
> +#define gralloc_gbm_handle_t gralloc_handle_t
> +#define gralloc_drm_handle_t gralloc_handle_t
> +
> +struct gralloc_handle_t {
> + native_handle_t base;
> +
> + /* dma-buf file descriptor
> + * Must be located first since, native_handle_t is allocated
> + * using native_handle_create(), which allocates space for
> + * sizeof(native_handle_t) + sizeof(int) * (numFds + numInts)
> + * numFds = GRALLOC_HANDLE_NUM_FDS
> + * numInts = GRALLOC_HANDLE_NUM_INTS
> + * Where numFds represents the number of FDs and
> + * numInts represents the space needed for the
> + * remainder of this struct.
> + * And the FDs are expected to be found first following
> + * native_handle_t.
> + */
> + int prime_fd;
> +
> + int magic; /* differentiate between allocator impls */
> +
> + int width; /* width of buffer in pixels */
> + int height; /* height of buffer in pixels */
> + int format; /* pixel format (Android) */
> + int usage; /* android libhardware usage flags */
> +
> + int name; /* the name of the bo */
> + int stride; /* the stride in bytes */
> + uint64_t modifier; /* buffer modifiers */
> +
> + int data_owner; /* owner of data (for validation) */
> + union {
> + void *data; /* pointer to struct gralloc_gbm_bo_t */
> + uint64_t reserved;
> + } __attribute__((aligned(8)));
> +};
> +
> +#define GRALLOC_HANDLE_MAGIC 0x60585350
> +#define GRALLOC_HANDLE_NUM_FDS 1
> +#define GRALLOC_HANDLE_NUM_INTS ( \
> + ((sizeof(struct alloc_handle_t) - sizeof(native_handle_t))/sizeof(int)) \
> + - GRALLOC_HANDLE_NUM_FDS)
> +
> +/**
> + * Create a buffer handle.
> + */
> +static struct gralloc_handle_t gralloc_handle_create(int width, int height,
> + int format, int usage)
> +{
> + struct gralloc_handle_t handle = { .magic = GRALLOC_HANDLE_MAGIC };
> +
> + native_handle_t *nhandle = native_handle_create(GRALLOC_HANDLE_NUM_FDS,
> + GRALLOC_HANDLE_NUM_INTS);
> + handle.base = *nhandle;
> + native_handle_delete(nhandle);
> +
> + handle.width = width;
> + handle.height = height;
> + handle.format = format;
> + handle.usage = usage;
> + handle.prime_fd = -1;
> +
> + handle->data_owner = getpid();
> + handle->data = bo;
> +
> + return handle;
> +}
> +
> +#endif
> --
> 2.14.1
>
More information about the mesa-dev
mailing list