<div dir="ltr"><div>Fairly straightforward and nothing seems amiss.<br><br></div>Reviewed-by: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>><br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Mar 9, 2017 at 5:49 PM, Ben Widawsky <span dir="ltr"><<a href="mailto:ben@bwidawsk.net" target="_blank">ben@bwidawsk.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">This patch originally had i965 specific code and was named:<br>
commit 61cd3c52b868cf8cb90b06e53a382a<wbr>921eb42754<br>
Author: Ben Widawsky <<a href="mailto:ben@bwidawsk.net">ben@bwidawsk.net</a>><br>
Date: Thu Oct 20 18:21:24 2016 -0700<br>
<br>
gbm: Get modifiers from DRI<br>
<br>
To accomplish this, two new query tokens are added to the extension:<br>
__DRI_IMAGE_ATTRIB_MODIFIER_<wbr>UPPER<br>
__DRI_IMAGE_ATTRIB_MODIFIER_<wbr>LOWER<br>
<br>
The query extension only supported 32b queries, and modifiers are 64b,<br>
so we needed two of them.<br>
<br>
NOTE: The extension version is still set to 13, so none of this will<br>
actually be called.<br>
<br>
Signed-off-by: Ben Widawsky <<a href="mailto:ben@bwidawsk.net">ben@bwidawsk.net</a>><br>
---<br>
src/gbm/backends/dri/gbm_dri.c | 36 ++++++++++++++++++++++++++++++<wbr>++++++<br>
src/gbm/gbm-symbols-check | 1 +<br>
src/gbm/main/gbm.c | 19 +++++++++++++++++++<br>
src/gbm/main/gbm.h | 3 +++<br>
src/gbm/main/gbmint.h | 1 +<br>
5 files changed, 60 insertions(+)<br>
<br>
diff --git a/src/gbm/backends/dri/gbm_<wbr>dri.c b/src/gbm/backends/dri/gbm_<wbr>dri.c<br>
index d45ba94080..2c467127c2 100644<br>
--- a/src/gbm/backends/dri/gbm_<wbr>dri.c<br>
+++ b/src/gbm/backends/dri/gbm_<wbr>dri.c<br>
@@ -39,6 +39,7 @@<br>
#include <unistd.h><br>
#include <dlfcn.h><br>
#include <xf86drm.h><br>
+#include <drm_fourcc.h><br>
<br>
#include <GL/gl.h> /* dri_interface needs GL types */<br>
#include <GL/internal/dri_interface.h><br>
@@ -53,6 +54,14 @@<br>
#include "../../../egl/wayland/wayland-<wbr>drm/wayland-drm.h"<br>
#endif<br>
<br>
+#ifndef DRM_FORMAT_MOD_INVALID<br>
+#define DRM_FORMAT_MOD_INVALID ((1ULL<<56) - 1)<br>
+#endif<br>
+<br>
+#ifndef DRM_FORMAT_MOD_LINEAR<br>
+#define DRM_FORMAT_MOD_LINEAR 0<br>
+#endif<br>
+<br>
static __DRIimage *<br>
dri_lookup_egl_image(__<wbr>DRIscreen *screen, void *image, void *data)<br>
{<br>
@@ -735,6 +744,32 @@ gbm_dri_bo_get_offset(struct gbm_bo *_bo, int plane)<br>
return (uint32_t)offset;<br>
}<br>
<br>
+static uint64_t<br>
+gbm_dri_bo_get_modifier(<wbr>struct gbm_bo *_bo)<br>
+{<br>
+ struct gbm_dri_device *dri = gbm_dri_device(_bo->gbm);<br>
+ struct gbm_dri_bo *bo = gbm_dri_bo(_bo);<br>
+<br>
+ if (!dri->image || dri->image->base.version < 14) {<br>
+ errno = ENOSYS;<br>
+ return DRM_FORMAT_MOD_INVALID;<br>
+ }<br>
+<br>
+ /* Dumb buffers have no modifiers */<br>
+ if (!bo->image)<br>
+ return DRM_FORMAT_MOD_LINEAR;<br>
+<br>
+ uint64_t ret = 0;<br>
+ int mod;<br>
+ dri->image->queryImage(bo-><wbr>image, __DRI_IMAGE_ATTRIB_MODIFIER_<wbr>UPPER, &mod);<br>
+ ret = (uint64_t)mod << 32;<br>
+<br>
+ dri->image->queryImage(bo-><wbr>image, __DRI_IMAGE_ATTRIB_MODIFIER_<wbr>LOWER, &mod);<br>
+ ret |= mod;<br>
+<br>
+ return ret;<br>
+}<br>
+<br>
static void<br>
gbm_dri_bo_destroy(struct gbm_bo *_bo)<br>
{<br>
@@ -1259,6 +1294,7 @@ dri_device_create(int fd)<br>
dri->base.base.bo_get_handle = gbm_dri_bo_get_handle_for_<wbr>plane;<br>
dri->base.base.bo_get_stride = gbm_dri_bo_get_stride;<br>
dri->base.base.bo_get_offset = gbm_dri_bo_get_offset;<br>
+ dri->base.base.bo_get_modifier = gbm_dri_bo_get_modifier;<br>
dri->base.base.bo_destroy = gbm_dri_bo_destroy;<br>
dri->base.base.destroy = dri_destroy;<br>
dri->base.base.surface_create = gbm_dri_surface_create;<br>
diff --git a/src/gbm/gbm-symbols-check b/src/gbm/gbm-symbols-check<br>
index c137c6cd93..c72fb66b03 100755<br>
--- a/src/gbm/gbm-symbols-check<br>
+++ b/src/gbm/gbm-symbols-check<br>
@@ -23,6 +23,7 @@ gbm_bo_get_handle<br>
gbm_bo_get_fd<br>
gbm_bo_get_plane_count<br>
gbm_bo_get_handle_for_plane<br>
+gbm_bo_get_modifier<br>
gbm_bo_write<br>
gbm_bo_set_user_data<br>
gbm_bo_get_user_data<br>
diff --git a/src/gbm/main/gbm.c b/src/gbm/main/gbm.c<br>
index 0fb62657ed..7ceaccdc21 100644<br>
--- a/src/gbm/main/gbm.c<br>
+++ b/src/gbm/main/gbm.c<br>
@@ -280,6 +280,25 @@ gbm_bo_get_handle_for_plane(<wbr>struct gbm_bo *bo, int plane)<br>
return bo->gbm->bo_get_handle(bo, plane);<br>
}<br>
<br>
+/**<br>
+ * Get the chosen modifier for the buffer object<br>
+ *<br>
+ * This function returns the modifier that was chosen for the object. These<br>
+ * properties may be generic, or platform/implementation dependent.<br>
+ *<br>
+ * \param bo The buffer object<br>
+ * \return Returns the selected modifier (chosen by the implementation) for the<br>
+ * BO.<br>
+ * \sa gbm_bo_create_with_modifiers() where possible modifiers are set<br>
+ * \sa gbm_surface_create_with_<wbr>modifiers() where possible modifiers are set<br>
+ * \sa define DRM_FORMAT_MOD_* in drm_fourcc.h for possible modifiers<br>
+ */<br>
+GBM_EXPORT uint64_t<br>
+gbm_bo_get_modifier(struct gbm_bo *bo)<br>
+{<br>
+ return bo->gbm->bo_get_modifier(bo);<br>
+}<br>
+<br>
/** Write data into the buffer object<br>
*<br>
* If the buffer object was created with the GBM_BO_USE_WRITE flag,<br>
diff --git a/src/gbm/main/gbm.h b/src/gbm/main/gbm.h<br>
index 5f588dab58..a774b50951 100644<br>
--- a/src/gbm/main/gbm.h<br>
+++ b/src/gbm/main/gbm.h<br>
@@ -327,6 +327,9 @@ gbm_bo_get_handle(struct gbm_bo *bo);<br>
int<br>
gbm_bo_get_fd(struct gbm_bo *bo);<br>
<br>
+uint64_t<br>
+gbm_bo_get_modifier(struct gbm_bo *bo);<br>
+<br>
int<br>
gbm_bo_get_plane_count(struct gbm_bo *bo);<br>
<br>
diff --git a/src/gbm/main/gbmint.h b/src/gbm/main/gbmint.h<br>
index d8c9f6e5d7..5ad85cc80f 100644<br>
--- a/src/gbm/main/gbmint.h<br>
+++ b/src/gbm/main/gbmint.h<br>
@@ -82,6 +82,7 @@ struct gbm_device {<br>
union gbm_bo_handle (*bo_get_handle)(struct gbm_bo *bo, int plane);<br>
uint32_t (*bo_get_stride)(struct gbm_bo *bo, int plane);<br>
int64_t (*bo_get_offset)(struct gbm_bo *bo, int plane);<br>
+ uint64_t (*bo_get_modifier)(struct gbm_bo *bo);<br>
void (*bo_destroy)(struct gbm_bo *bo);<br>
<br>
struct gbm_surface *(*surface_create)(struct gbm_device *gbm,<br>
<span class="HOEnZb"><font color="#888888">--<br>
2.12.0<br>
<br>
</font></span></blockquote></div><br></div>