glx: implement GLX part of interop interface (v2)
authorMarek Olšák <marek.olsak@amd.com>
Thu, 3 Mar 2016 17:43:53 +0000 (18:43 +0100)
committerMarek Olšák <marek.olsak@amd.com>
Wed, 20 Apr 2016 10:18:47 +0000 (12:18 +0200)
v2: - use const

src/glx/Makefile.am
src/glx/dri2_glx.c
src/glx/dri2_priv.h
src/glx/dri3_glx.c
src/glx/dri3_priv.h
src/glx/dri_common_interop.c [new file with mode: 0644]
src/glx/glxclient.h
src/glx/glxcmds.c

index 00925455b07abebd4b2662c85949b4af36d8ec60..d65fb8162565e2fc2e17a1e9f582cbb5b46c7cdf 100644 (file)
@@ -113,6 +113,7 @@ libglx_la_SOURCES += \
        dri_common.c \
        dri_common.h \
        dri_common_query_renderer.c \
+       dri_common_interop.c \
        xfont.c
 endif
 
index 77103492a4fa27486033a1d2b5a4bc20b28cd98e..cc162f2d1ee971a6ce1606686f385c31a7f237ea 100644 (file)
@@ -77,12 +77,6 @@ struct dri2_display
    const __DRIextension *loader_extensions[4];
 };
 
-struct dri2_context
-{
-   struct glx_context base;
-   __DRIcontext *driContext;
-};
-
 struct dri2_drawable
 {
    __GLXDRIdrawable base;
@@ -1061,6 +1055,8 @@ static const struct glx_context_vtable dri2_context_vtable = {
    .bind_tex_image      = dri2_bind_tex_image,
    .release_tex_image   = dri2_release_tex_image,
    .get_proc_address    = NULL,
+   .interop_query_device_info = dri2_interop_query_device_info,
+   .interop_export_object = dri2_interop_export_object
 };
 
 static void
@@ -1145,6 +1141,9 @@ dri2BindExtensions(struct dri2_screen *psc, struct glx_display * priv,
          psc->rendererQuery = (__DRI2rendererQueryExtension *) extensions[i];
          __glXEnableDirectExtension(&psc->base, "GLX_MESA_query_renderer");
       }
+
+      if (strcmp(extensions[i]->name, __DRI2_INTEROP) == 0)
+        psc->interop = (__DRI2interopExtension*)extensions[i];
    }
 }
 
index b93d1587aae95e72a8604672136859ef46429d0b..e81b1bf416d933f213413779f383967168afd4b3 100644 (file)
@@ -43,6 +43,7 @@ struct dri2_screen {
    const __DRItexBufferExtension *texBuffer;
    const __DRI2throttleExtension *throttle;
    const __DRI2rendererQueryExtension *rendererQuery;
+   const __DRI2interopExtension *interop;
    const __DRIconfig **driver_configs;
 
    void *driver;
@@ -51,6 +52,12 @@ struct dri2_screen {
    int show_fps_interval;
 };
 
+struct dri2_context
+{
+   struct glx_context base;
+   __DRIcontext *driContext;
+};
+
 _X_HIDDEN int
 dri2_query_renderer_integer(struct glx_screen *base, int attribute,
                             unsigned int *value);
@@ -58,3 +65,12 @@ dri2_query_renderer_integer(struct glx_screen *base, int attribute,
 _X_HIDDEN int
 dri2_query_renderer_string(struct glx_screen *base, int attribute,
                            const char **value);
+
+_X_HIDDEN int
+dri2_interop_query_device_info(struct glx_context *ctx,
+                               mesa_glinterop_device_info *out);
+
+_X_HIDDEN int
+dri2_interop_export_object(struct glx_context *ctx,
+                           const mesa_glinterop_export_in *in,
+                           mesa_glinterop_export_out *out);
index 6054ffc3dc198e55c6289ff3bb1b4c071664d485..6729357bb3cabbc0e3055fa65af9a3c68a9176d7 100644 (file)
@@ -638,6 +638,8 @@ static const struct glx_context_vtable dri3_context_vtable = {
    .bind_tex_image      = dri3_bind_tex_image,
    .release_tex_image   = dri3_release_tex_image,
    .get_proc_address    = NULL,
+   .interop_query_device_info = dri3_interop_query_device_info,
+   .interop_export_object = dri3_interop_export_object
 };
 
 /** dri3_bind_extensions
@@ -704,6 +706,9 @@ dri3_bind_extensions(struct dri3_screen *psc, struct glx_display * priv,
          psc->rendererQuery = (__DRI2rendererQueryExtension *) extensions[i];
          __glXEnableDirectExtension(&psc->base, "GLX_MESA_query_renderer");
       }
+
+      if (strcmp(extensions[i]->name, __DRI2_INTEROP) == 0)
+        psc->interop = (__DRI2interopExtension*)extensions[i];
    }
 }
 
index 56a63309f36b608f7a629df31eeb32778a6bb026..d4ecdf7a58e203d501cd3b910ad9f3baef1709dd 100644 (file)
@@ -96,6 +96,7 @@ struct dri3_screen {
    const __DRI2configQueryExtension *config;
    const __DRItexBufferExtension *texBuffer;
    const __DRI2rendererQueryExtension *rendererQuery;
+   const __DRI2interopExtension *interop;
    const __DRIconfig **driver_configs;
 
    void *driver;
@@ -131,3 +132,12 @@ dri3_query_renderer_integer(struct glx_screen *base, int attribute,
 _X_HIDDEN int
 dri3_query_renderer_string(struct glx_screen *base, int attribute,
                            const char **value);
+
+_X_HIDDEN int
+dri3_interop_query_device_info(struct glx_context *ctx,
+                               mesa_glinterop_device_info *out);
+
+_X_HIDDEN int
+dri3_interop_export_object(struct glx_context *ctx,
+                           const mesa_glinterop_export_in *in,
+                           mesa_glinterop_export_out *out);
diff --git a/src/glx/dri_common_interop.c b/src/glx/dri_common_interop.c
new file mode 100644 (file)
index 0000000..4733f3c
--- /dev/null
@@ -0,0 +1,92 @@
+/*
+ * Copyright © 2013 Intel Corporation
+ *
+ * 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.
+ */
+
+#if defined(GLX_DIRECT_RENDERING) && !defined(GLX_USE_APPLEGL)
+
+#include "glxclient.h"
+#include "glx_error.h"
+#include "dri_interface.h"
+#include "dri2_priv.h"
+#if defined(HAVE_DRI3)
+#include "dri3_priv.h"
+#endif
+#include "GL/mesa_glinterop.h"
+
+_X_HIDDEN int
+dri2_interop_query_device_info(struct glx_context *ctx,
+                               mesa_glinterop_device_info *out)
+{
+   struct dri2_screen *psc = (struct dri2_screen*)ctx->psc;
+   struct dri2_context *drictx = (struct dri2_context*)ctx;
+
+   if (!psc->interop)
+      return MESA_GLINTEROP_UNSUPPORTED;
+
+   return psc->interop->query_device_info(drictx->driContext, out);
+}
+
+_X_HIDDEN int
+dri2_interop_export_object(struct glx_context *ctx,
+                           const mesa_glinterop_export_in *in,
+                           mesa_glinterop_export_out *out)
+{
+   struct dri2_screen *psc = (struct dri2_screen*)ctx->psc;
+   struct dri2_context *drictx = (struct dri2_context*)ctx;
+
+   if (!psc->interop)
+      return MESA_GLINTEROP_UNSUPPORTED;
+
+   return psc->interop->export_object(drictx->driContext, in, out);
+}
+
+#if defined(HAVE_DRI3)
+
+_X_HIDDEN int
+dri3_interop_query_device_info(struct glx_context *ctx,
+                               mesa_glinterop_device_info *out)
+{
+   struct dri3_screen *psc = (struct dri3_screen*)ctx->psc;
+   struct dri3_context *drictx = (struct dri3_context*)ctx;
+
+   if (!psc->interop)
+      return MESA_GLINTEROP_UNSUPPORTED;
+
+   return psc->interop->query_device_info(drictx->driContext, out);
+}
+
+_X_HIDDEN int
+dri3_interop_export_object(struct glx_context *ctx,
+                           const mesa_glinterop_export_in *in,
+                           mesa_glinterop_export_out *out)
+{
+   struct dri3_screen *psc = (struct dri3_screen*)ctx->psc;
+   struct dri3_context *drictx = (struct dri3_context*)ctx;
+
+   if (!psc->interop)
+      return MESA_GLINTEROP_UNSUPPORTED;
+
+   return psc->interop->export_object(drictx->driContext, in, out);
+}
+
+#endif /* HAVE_DRI3 */
+#endif /* defined(GLX_DIRECT_RENDERING) && !defined(GLX_USE_APPLEGL) */
index 2776b44a9e5650bdeaf2dcd697f6fe9d30f86cd9..7a249281081d0319eb5242f47d52c44e4f25e2eb 100644 (file)
@@ -208,6 +208,10 @@ typedef struct __GLXattributeMachineRec
    __GLXattribute **stackPointer;
 } __GLXattributeMachine;
 
+typedef struct _mesa_glinterop_device_info mesa_glinterop_device_info;
+typedef struct _mesa_glinterop_export_in mesa_glinterop_export_in;
+typedef struct _mesa_glinterop_export_out mesa_glinterop_export_out;
+
 struct glx_context_vtable {
    void (*destroy)(struct glx_context *ctx);
    int (*bind)(struct glx_context *context, struct glx_context *old,
@@ -222,6 +226,11 @@ struct glx_context_vtable {
                          int buffer, const int *attrib_list);
    void (*release_tex_image)(Display * dpy, GLXDrawable drawable, int buffer);
    void * (*get_proc_address)(const char *symbol);
+   int (*interop_query_device_info)(struct glx_context *ctx,
+                                    mesa_glinterop_device_info *out);
+   int (*interop_export_object)(struct glx_context *ctx,
+                                const mesa_glinterop_export_in *in,
+                                mesa_glinterop_export_out *out);
 };
 
 /**
index 93e8db5a367da96263812bea312617324f349828..63f492128bce8f2ce8662289aa6eae6bb5f90c72 100644 (file)
@@ -54,6 +54,7 @@
 #include <X11/Xlib-xcb.h>
 #include <xcb/xcb.h>
 #include <xcb/glx.h>
+#include "GL/mesa_glinterop.h"
 
 static const char __glXGLXClientVendorName[] = "Mesa Project and SGI";
 static const char __glXGLXClientVersion[] = "1.4";
@@ -2691,3 +2692,56 @@ __glXGetUST(int64_t * ust)
    }
 }
 #endif /* GLX_DIRECT_RENDERING */
+
+#if defined(GLX_DIRECT_RENDERING) && !defined(GLX_USE_APPLEGL)
+
+GLAPI int GLAPIENTRY
+MesaGLInteropGLXQueryDeviceInfo(Display *dpy, GLXContext context,
+                                mesa_glinterop_device_info *out)
+{
+   struct glx_context *gc = (struct glx_context*)context;
+   int ret;
+
+   __glXLock();
+
+   if (!gc || gc->xid == None || !gc->isDirect) {
+      __glXUnlock();
+      return MESA_GLINTEROP_INVALID_CONTEXT;
+   }
+
+   if (!gc->vtable->interop_query_device_info) {
+      __glXUnlock();
+      return MESA_GLINTEROP_UNSUPPORTED;
+   }
+
+   ret = gc->vtable->interop_query_device_info(gc, out);
+   __glXUnlock();
+   return ret;
+}
+
+GLAPI int GLAPIENTRY
+MesaGLInteropGLXExportObject(Display *dpy, GLXContext context,
+                             const mesa_glinterop_export_in *in,
+                             mesa_glinterop_export_out *out)
+{
+   struct glx_context *gc = (struct glx_context*)context;
+   int ret;
+
+   __glXLock();
+
+   if (!gc || gc->xid == None || !gc->isDirect) {
+      __glXUnlock();
+      return MESA_GLINTEROP_INVALID_CONTEXT;
+   }
+
+   if (!gc->vtable->interop_export_object) {
+      __glXUnlock();
+      return MESA_GLINTEROP_UNSUPPORTED;
+   }
+
+   ret = gc->vtable->interop_export_object(gc, in, out);
+   __glXUnlock();
+   return ret;
+}
+
+#endif /* defined(GLX_DIRECT_RENDERING) && !defined(GLX_USE_APPLEGL) */