[Mesa-dev] [PATCH v2 7/7] egl/android: Make drm_gralloc headers optional (v2)

Tomasz Figa tfiga at chromium.org
Wed Aug 3 02:55:05 UTC 2016


On Wed, Aug 3, 2016 at 5:12 AM, Rob Herring <robh at kernel.org> wrote:
> On Tue, Aug 2, 2016 at 6:07 AM, Tomasz Figa <tfiga at chromium.org> wrote:
>> Make the code at least compile when being built without drm_gralloc
>> headers.
>>
>> v2: Replaced #ifdefs with stubs for gralloc_drm_get_gem_handle()
>>     and GRALLOC_MODULE_PERFORM_GET_DRM_FD.
>>     Removed explicit render node probing code.
>>
>> Signed-off-by: Tomasz Figa <tfiga at chromium.org>
>> ---
>>  src/egl/Android.mk                                 |  1 +
>>  src/egl/Makefile.am                                |  4 ++-
>>  src/egl/drivers/dri2/egl_dri2.h                    |  2 +-
>>  src/egl/drivers/dri2/platform_android.c            |  2 +-
>>  .../drivers/dri2/platform_android_gralloc_drm.h    | 41 ++++++++++++++++++++++
>>  5 files changed, 47 insertions(+), 3 deletions(-)
>>  create mode 100644 src/egl/drivers/dri2/platform_android_gralloc_drm.h
>>
>> diff --git a/src/egl/Android.mk b/src/egl/Android.mk
>> index bfd56a7..72ec02a 100644
>> --- a/src/egl/Android.mk
>> +++ b/src/egl/Android.mk
>> @@ -41,6 +41,7 @@ LOCAL_SRC_FILES := \
>>  LOCAL_CFLAGS := \
>>         -D_EGL_NATIVE_PLATFORM=_EGL_PLATFORM_ANDROID \
>>         -D_EGL_BUILT_IN_DRIVER_DRI2 \
>> +       -DHAS_GRALLOC_DRM_HEADERS \
>>         -DHAVE_ANDROID_PLATFORM
>>
>>  LOCAL_C_INCLUDES := \
>> diff --git a/src/egl/Makefile.am b/src/egl/Makefile.am
>> index 95ee6cc..e6ed8e6 100644
>> --- a/src/egl/Makefile.am
>> +++ b/src/egl/Makefile.am
>> @@ -86,7 +86,9 @@ endif
>>
>>  if HAVE_EGL_PLATFORM_ANDROID
>>  AM_CFLAGS += -DHAVE_ANDROID_PLATFORM
>> -dri2_backend_FILES += drivers/dri2/platform_android.c
>> +dri2_backend_FILES += \
>> +       drivers/dri2/platform_android.c \
>> +       drivers/dri2/egl_dri2_drm_gralloc.h
>>  endif
>>
>>  if HAVE_EGL_DRIVER_DRI2
>> diff --git a/src/egl/drivers/dri2/egl_dri2.h b/src/egl/drivers/dri2/egl_dri2.h
>> index 3da6bef..14c1e05 100644
>> --- a/src/egl/drivers/dri2/egl_dri2.h
>> +++ b/src/egl/drivers/dri2/egl_dri2.h
>> @@ -64,8 +64,8 @@
>>  #  include <ui/android_native_buffer.h>
>>  #endif
>>
>> +#include "platform_android_gralloc_drm.h"
>
> This isn't needed here.
>
>>  #include <hardware/gralloc.h>
>
> This should probably just be included by platform_android.c, but
> that's a separate clean-up.
>
>> -#include <gralloc_drm_handle.h>
>>  #include <cutils/log.h>
>
> Maybe this too?

Good catch. I found this already long time ago and managed to forget
in the end. I'll create a separate patch with this cleanup.

>
>>
>>  #endif /* HAVE_ANDROID_PLATFORM */
>> diff --git a/src/egl/drivers/dri2/platform_android.c b/src/egl/drivers/dri2/platform_android.c
>> index 1768724..49a9eb0 100644
>> --- a/src/egl/drivers/dri2/platform_android.c
>> +++ b/src/egl/drivers/dri2/platform_android.c
>> @@ -38,7 +38,7 @@
>>  #include "loader.h"
>>  #include "egl_dri2.h"
>>  #include "egl_dri2_fallbacks.h"
>> -#include "gralloc_drm.h"
>> +#include "platform_android_gralloc_drm.h"
>>
>>  #define ALIGN(val, align)      (((val) + (align) - 1) & ~((align) - 1))
>>
>> diff --git a/src/egl/drivers/dri2/platform_android_gralloc_drm.h b/src/egl/drivers/dri2/platform_android_gralloc_drm.h
>> new file mode 100644
>> index 0000000..6757d1b
>> --- /dev/null
>> +++ b/src/egl/drivers/dri2/platform_android_gralloc_drm.h
>> @@ -0,0 +1,41 @@
>> +/*
>> + * Copyright 2016 Google Inc. All Rights Reserved.
>> + *
>> + * 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.
>> + */
>> +
>> +#pragma once
>> +
>> +#ifdef HAS_GRALLOC_DRM_HEADERS
>> +
>> +#include <gralloc_drm.h>
>> +#include <gralloc_drm_handle.h>
>> +
>> +#else
>> +
>> +#define GRALLOC_MODULE_PERFORM_GET_DRM_FD 0x0FD4DEAD
>
> This leaves things a bit broken as droid_open_device can never work
> with HAS_GRALLOC_DRM_HEADERS undefined.

Yeah, I mostly intended to make it possible to just build the code
without those headers for build testing at least. According to the
discussion from my previous patch set, the private interface to
gralloc was preferred, but I think this needs a bit more discussion,
so I decided to just drop that part for a while.

> As we're both aligned in using
> the render nodes, I'd like to be able to use the same fix. Since with
> render nodes, it doesn't have to be the same fd now, the following
> works for me:
>
> droid_open_device(void)
> {
> #ifdef HAS_GRALLOC_DRM_HEADERS
>   // existing code
> #else
>   return loader_open_device("/dev/dri/renderD128");
> #endif
> }
>
> I can provide that patch, but just want to throw it out there for
> context. We probably want to get the device path from a property or
> something rather than hardcoding.

I would still prefer some simple probing here, it would then also work
for us and anyone else with a different setup than, for some reason
"blessed", drm_gralloc.

Still, I guess it's at least a good start... Especially considering
that this time I intended this thing to just build successfully
without the custom APIs.

Best regards,
Tomasz


More information about the mesa-dev mailing list