mirror of
https://src.fedoraproject.org/rpms/mesa.git
synced 2024-11-28 11:06:25 +00:00
Fix glXGetDriverConfig not working with glvnd (rhbz#1429894)
Fix indirect rendering, add libGLX_indirect.so.0 symlink (rhbz#1427174)
This commit is contained in:
parent
c53f6ecbd3
commit
956bc1d0e3
2 changed files with 99 additions and 1 deletions
|
@ -0,0 +1,88 @@
|
||||||
|
From efa4f2ebc1e788c3f1cfcf3842058cf838171653 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Hans de Goede <hdegoede@redhat.com>
|
||||||
|
Date: Mon, 20 Mar 2017 08:41:26 +0100
|
||||||
|
Subject: [PATCH] glxglvnddispatch: Add missing dispatch for GetDriverConfig
|
||||||
|
|
||||||
|
Together with some fixes to xdriinfo this fixes xdriinfo not working
|
||||||
|
with glvnd.
|
||||||
|
|
||||||
|
Since apps (xdriinfo) expect GetDriverConfig to work without going to
|
||||||
|
need through the dance to setup a glxcontext (which is a reasonable
|
||||||
|
expectation IMHO), the dispatch for this ends up significantly different
|
||||||
|
then any other dispatch function.
|
||||||
|
|
||||||
|
This patch gets the job done, but I'm not really happy with how this
|
||||||
|
patch turned out, suggestions for a better fix are welcome.
|
||||||
|
|
||||||
|
Cc: Kyle Brenneman <kbrenneman@nvidia.com>
|
||||||
|
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
||||||
|
---
|
||||||
|
src/glx/g_glxglvnddispatchfuncs.c | 18 ++++++++++++++++++
|
||||||
|
src/glx/g_glxglvnddispatchindices.h | 1 +
|
||||||
|
2 files changed, 19 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/glx/g_glxglvnddispatchfuncs.c b/src/glx/g_glxglvnddispatchfuncs.c
|
||||||
|
index b5e3398..040cdf8 100644
|
||||||
|
--- a/src/glx/g_glxglvnddispatchfuncs.c
|
||||||
|
+++ b/src/glx/g_glxglvnddispatchfuncs.c
|
||||||
|
@@ -4,6 +4,7 @@
|
||||||
|
*/
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
+#include "glxclient.h"
|
||||||
|
#include "glxglvnd.h"
|
||||||
|
#include "glxglvnddispatchfuncs.h"
|
||||||
|
#include "g_glxglvnddispatchindices.h"
|
||||||
|
@@ -50,6 +51,7 @@ const char * const __glXDispatchTableStrings[DI_LAST_INDEX] = {
|
||||||
|
__ATTRIB(GetCurrentDisplayEXT),
|
||||||
|
// glXGetCurrentDrawable implemented by libglvnd
|
||||||
|
// glXGetCurrentReadDrawable implemented by libglvnd
|
||||||
|
+ __ATTRIB(GetDriverConfig),
|
||||||
|
// glXGetFBConfigAttrib implemented by libglvnd
|
||||||
|
__ATTRIB(GetFBConfigAttribSGIX),
|
||||||
|
__ATTRIB(GetFBConfigFromVisualSGIX),
|
||||||
|
@@ -334,6 +336,21 @@ static Display *dispatch_GetCurrentDisplayEXT(void)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
+static const char *dispatch_GetDriverConfig(const char *driverName)
|
||||||
|
+{
|
||||||
|
+ /*
|
||||||
|
+ * The options are constant for a given driverName, so we do not need
|
||||||
|
+ * a context (and apps expect to be able to call this without one).
|
||||||
|
+ */
|
||||||
|
+#if defined(GLX_DIRECT_RENDERING) && !defined(GLX_USE_APPLEGL)
|
||||||
|
+ return glXGetDriverConfig(driverName);
|
||||||
|
+#else
|
||||||
|
+ return NULL;
|
||||||
|
+#endif
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+
|
||||||
|
static int dispatch_GetFBConfigAttribSGIX(Display *dpy, GLXFBConfigSGIX config,
|
||||||
|
int attribute, int *value_return)
|
||||||
|
{
|
||||||
|
@@ -939,6 +956,7 @@ const void * const __glXDispatchFunctions[DI_LAST_INDEX + 1] = {
|
||||||
|
__ATTRIB(DestroyGLXPbufferSGIX),
|
||||||
|
__ATTRIB(GetContextIDEXT),
|
||||||
|
__ATTRIB(GetCurrentDisplayEXT),
|
||||||
|
+ __ATTRIB(GetDriverConfig),
|
||||||
|
__ATTRIB(GetFBConfigAttribSGIX),
|
||||||
|
__ATTRIB(GetFBConfigFromVisualSGIX),
|
||||||
|
__ATTRIB(GetMscRateOML),
|
||||||
|
diff --git a/src/glx/g_glxglvnddispatchindices.h b/src/glx/g_glxglvnddispatchindices.h
|
||||||
|
index 05a2c8c..3ba50a7 100644
|
||||||
|
--- a/src/glx/g_glxglvnddispatchindices.h
|
||||||
|
+++ b/src/glx/g_glxglvnddispatchindices.h
|
||||||
|
@@ -39,6 +39,7 @@ typedef enum __GLXdispatchIndex {
|
||||||
|
DI_GetCurrentDisplayEXT,
|
||||||
|
// GetCurrentDrawable implemented by libglvnd
|
||||||
|
// GetCurrentReadDrawable implemented by libglvnd
|
||||||
|
+ DI_GetDriverConfig,
|
||||||
|
// GetFBConfigAttrib implemented by libglvnd
|
||||||
|
DI_GetFBConfigAttribSGIX,
|
||||||
|
DI_GetFBConfigFromVisualSGIX,
|
||||||
|
--
|
||||||
|
2.9.3
|
||||||
|
|
12
mesa.spec
12
mesa.spec
|
@ -59,7 +59,7 @@
|
||||||
Name: mesa
|
Name: mesa
|
||||||
Summary: Mesa graphics libraries
|
Summary: Mesa graphics libraries
|
||||||
Version: 13.0.4
|
Version: 13.0.4
|
||||||
Release: 2%{?rctag:.%{rctag}}%{?dist}
|
Release: 3%{?rctag:.%{rctag}}%{?dist}
|
||||||
|
|
||||||
License: MIT
|
License: MIT
|
||||||
URL: http://www.mesa3d.org
|
URL: http://www.mesa3d.org
|
||||||
|
@ -89,6 +89,7 @@ Patch14: 0001-glapi-Link-with-glapi-when-built-shared.patch
|
||||||
|
|
||||||
# submitted upstream
|
# submitted upstream
|
||||||
Patch15: 0001-glx-glvnd-Fix-GLXdispatchIndex-sorting.patch
|
Patch15: 0001-glx-glvnd-Fix-GLXdispatchIndex-sorting.patch
|
||||||
|
Patch16: 0001-glxglvnddispatch-Add-missing-dispatch-for-GetDriverC.patch
|
||||||
|
|
||||||
BuildRequires: gcc
|
BuildRequires: gcc
|
||||||
BuildRequires: gcc-c++
|
BuildRequires: gcc-c++
|
||||||
|
@ -458,6 +459,10 @@ rm -f %{buildroot}%{_libdir}/libEGL_mesa.so
|
||||||
# XXX can we just not build this
|
# XXX can we just not build this
|
||||||
rm -f %{buildroot}%{_libdir}/libGLES*
|
rm -f %{buildroot}%{_libdir}/libGLES*
|
||||||
|
|
||||||
|
# glvnd needs a default provider for indirect rendering where it cannot
|
||||||
|
# determine the vendor
|
||||||
|
ln -s %{_libdir}/libGLX_mesa.so.0 %{buildroot}%{_libdir}/libGLX_indirect.so.0
|
||||||
|
|
||||||
# strip out useless headers
|
# strip out useless headers
|
||||||
rm -f %{buildroot}%{_includedir}/GL/w*.h
|
rm -f %{buildroot}%{_includedir}/GL/w*.h
|
||||||
|
|
||||||
|
@ -488,6 +493,7 @@ popd
|
||||||
|
|
||||||
%files libGL
|
%files libGL
|
||||||
%{_libdir}/libGLX_mesa.so.0*
|
%{_libdir}/libGLX_mesa.so.0*
|
||||||
|
%{_libdir}/libGLX_indirect.so.0*
|
||||||
%files libGL-devel
|
%files libGL-devel
|
||||||
%{_includedir}/GL/gl.h
|
%{_includedir}/GL/gl.h
|
||||||
%{_includedir}/GL/gl_mangle.h
|
%{_includedir}/GL/gl_mangle.h
|
||||||
|
@ -686,6 +692,10 @@ popd
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Mar 20 2017 Hans de Goede <hdegoede@redhat.com> - 13.0.4-3
|
||||||
|
- Fix glXGetDriverConfig not working with glvnd (rhbz#1429894)
|
||||||
|
- Fix indirect rendering, add libGLX_indirect.so.0 symlink (rhbz#1427174)
|
||||||
|
|
||||||
* Mon Mar 06 2017 Dave Airlie <airlied@redhat.com> - 13.0.4-2
|
* Mon Mar 06 2017 Dave Airlie <airlied@redhat.com> - 13.0.4-2
|
||||||
- rebuild for llvm 3.9
|
- rebuild for llvm 3.9
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue