configure: Look for Khronos OpenGL spec files using pkg-config
Look for Khronos OpenGL spec files using pkg-config, rather than downloading them Also add a --with-khronos-spec-dir=PATH configure option so XWin can be directed where to find these files without using the khronos-spec-files package XWin with AIGLX requires OpenGL spec files in order to generate wrapper code which: (1) thunks from the glapi dispatch table which uses the default cdecl calling convention to native GL functions using the stdcall calling convention. (2) performs function address lookup for OpenGL 1.2+ functions, which are treated as extensions and so not directly linkable. v2: KHRONOS_SPEC_DIR is only valid when XWIN_GLX_WINDOWS is defined. Avoid 'make dist' seeing invalid dependencies by only including rules using KHRONOS_SPEC_DIR if XWIN_GLX_WINDOWS is defined Signed-off-by: Jon TURNEY <jon.turney@dronecode.org.uk> Reviewed-by: Colin Harrison <colin.harrison@virgin.net> Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
This commit is contained in:
		
							parent
							
								
									c5a612fc18
								
							
						
					
					
						commit
						a50878682c
					
				
							
								
								
									
										13
									
								
								configure.ac
								
								
								
								
							
							
						
						
									
										13
									
								
								configure.ac
								
								
								
								
							|  | @ -598,6 +598,9 @@ AC_ARG_ENABLE(glx-tls,        AS_HELP_STRING([--enable-glx-tls], [Build GLX with | ||||||
|                                    GLX_USE_TLS=yes |                                    GLX_USE_TLS=yes | ||||||
|                                  fi]) |                                  fi]) | ||||||
| AC_SUBST(GLX_TLS, ${GLX_USE_TLS}) | AC_SUBST(GLX_TLS, ${GLX_USE_TLS}) | ||||||
|  | AC_ARG_WITH(khronos-spec-dir, AS_HELP_STRING([--with-khronos-spec-dir=PATH], [Path to Khronos OpenGL registry database files (default: auto)]), | ||||||
|  | 				[KHRONOS_SPEC_DIR="${withval}"], | ||||||
|  | 				[KHRONOS_SPEC_DIR=auto]) | ||||||
| 
 | 
 | ||||||
| dnl Extensions. | dnl Extensions. | ||||||
| AC_ARG_ENABLE(registry,       AS_HELP_STRING([--disable-registry], [Build string registry module (default: enabled)]), [XREGISTRY=$enableval], [XREGISTRY=yes]) | AC_ARG_ENABLE(registry,       AS_HELP_STRING([--disable-registry], [Build string registry module (default: enabled)]), [XREGISTRY=$enableval], [XREGISTRY=yes]) | ||||||
|  | @ -1854,6 +1857,16 @@ if test "x$XWIN" = xyes; then | ||||||
| 
 | 
 | ||||||
| 	AC_DEFINE(DDXOSVERRORF, 1, [Use OsVendorVErrorF]) | 	AC_DEFINE(DDXOSVERRORF, 1, [Use OsVendorVErrorF]) | ||||||
| 	AC_DEFINE(DDXBEFORERESET, 1, [Use ddxBeforeReset ]) | 	AC_DEFINE(DDXBEFORERESET, 1, [Use ddxBeforeReset ]) | ||||||
|  | 
 | ||||||
|  | dnl XWin with AIGLX requires OpenGL spec files in order to generate wrapper code for native GL functions | ||||||
|  | 	if [test "x$XWIN" = xyes && test "x$AIGLX" = xyes] ; then | ||||||
|  |            if test "x$KHRONOS_SPEC_DIR" = "xauto" ; then | ||||||
|  | 		PKG_CHECK_MODULES([KHRONOS_OPENGL_REGISTRY], [khronos-opengl-registry]) | ||||||
|  | 		KHRONOS_SPEC_DIR=`pkg-config khronos-opengl-registry --variable=specdir` | ||||||
|  |            fi | ||||||
|  |            AC_SUBST(KHRONOS_SPEC_DIR) | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
| fi | fi | ||||||
| AM_CONDITIONAL(XWIN, [test "x$XWIN" = xyes]) | AM_CONDITIONAL(XWIN, [test "x$XWIN" = xyes]) | ||||||
| AM_CONDITIONAL(XWIN_MULTIWINDOW, [test "x$XWIN" = xyes]) | AM_CONDITIONAL(XWIN_MULTIWINDOW, [test "x$XWIN" = xyes]) | ||||||
|  |  | ||||||
|  | @ -1,8 +1,4 @@ | ||||||
| # ignore downloaded and generated files | # ignore downloaded and generated files | ||||||
| generated_gl_wrappers.c | generated_gl_wrappers.c | ||||||
| generated_wgl_wrappers.c | generated_wgl_wrappers.c | ||||||
| gl.spec |  | ||||||
| gl.tm |  | ||||||
| wgl.tm |  | ||||||
| wglext.spec |  | ||||||
| wglext.h | wglext.h | ||||||
|  |  | ||||||
|  | @ -25,36 +25,19 @@ AM_CFLAGS = -DHAVE_XWIN_CONFIG_H $(DIX_CFLAGS) \ | ||||||
|             -I$(top_srcdir) \
 |             -I$(top_srcdir) \
 | ||||||
|             -I$(top_srcdir)/hw/xwin/ |             -I$(top_srcdir)/hw/xwin/ | ||||||
| 
 | 
 | ||||||
| glwrap.c: generated_gl_wrappers.c | if XWIN_GLX_WINDOWS | ||||||
| wgl_ext_api.c: generated_wgl_wrappers.c wglext.h | generated_gl_wrappers.c: gen_gl_wrappers.py $(KHRONOS_SPEC_DIR)/gl.spec $(KHRONOS_SPEC_DIR)/gl.tm | ||||||
| wgl_ext_api.h: wglext.h | 	$(srcdir)/gen_gl_wrappers.py --spec=$(KHRONOS_SPEC_DIR)/gl.spec --typemap=$(KHRONOS_SPEC_DIR)/gl.tm --dispatch-header=$(top_srcdir)/glx/dispatch.h --staticwrappers >generated_gl_wrappers.c | ||||||
| indirect.c: wgl_ext_api.h |  | ||||||
| 
 | 
 | ||||||
| SPEC_FILES = gl.spec gl.tm wglext.spec wgl.tm | generated_wgl_wrappers.c: gen_gl_wrappers.py $(KHRONOS_SPEC_DIR)/wglext.spec $(KHRONOS_SPEC_DIR)/wgl.tm | ||||||
| 
 | 	$(srcdir)/gen_gl_wrappers.py --spec=$(KHRONOS_SPEC_DIR)/wglext.spec --typemap=$(KHRONOS_SPEC_DIR)/wgl.tm --prefix=wgl --preresolve >generated_wgl_wrappers.c | ||||||
| gl.spec: | endif | ||||||
| 	wget http://www.opengl.org/registry/api/gl.spec |  | ||||||
| 
 |  | ||||||
| gl.tm: |  | ||||||
| 	wget http://www.opengl.org/registry/api/gl.tm |  | ||||||
| 
 |  | ||||||
| wglext.spec: |  | ||||||
| 	wget http://www.opengl.org/registry/api/wglext.spec |  | ||||||
| 
 |  | ||||||
| wgl.tm: |  | ||||||
| 	wget http://www.opengl.org/registry/api/wgl.tm |  | ||||||
| 
 |  | ||||||
| generated_gl_wrappers.c: gen_gl_wrappers.py gl.spec gl.tm |  | ||||||
| 	$(srcdir)/gen_gl_wrappers.py --spec=`test -e gl.spec || echo $(srcdir)/`gl.spec --typemap=`test -e gl.tm || echo $(srcdir)/`gl.tm --dispatch-header=$(top_srcdir)/glx/dispatch.h --staticwrappers >generated_gl_wrappers.c |  | ||||||
| 
 |  | ||||||
| generated_wgl_wrappers.c: gen_gl_wrappers.py wglext.spec wgl.tm |  | ||||||
| 	$(srcdir)/gen_gl_wrappers.py --spec=`test -e wglext.spec || echo $(srcdir)/`wglext.spec --typemap=`test -e wgl.tm || echo $(srcdir)/`wgl.tm --prefix=wgl --preresolve >generated_wgl_wrappers.c |  | ||||||
| 
 | 
 | ||||||
| wglext.h: | wglext.h: | ||||||
| 	wget http://www.opengl.org/registry/api/wglext.h | 	wget http://www.opengl.org/registry/api/wglext.h | ||||||
| 
 | 
 | ||||||
| BUILT_SOURCES = generated_gl_wrappers.c generated_wgl_wrappers.c | BUILT_SOURCES = generated_gl_wrappers.c generated_wgl_wrappers.c | ||||||
| CLEANFILES = $(BUILT_SOURCES) | CLEANFILES = $(BUILT_SOURCES) | ||||||
| DISTCLEANFILES = $(SPEC_FILES) wglext.h | DISTCLEANFILES = wglext.h | ||||||
| 
 | 
 | ||||||
| EXTRA_DIST = gen_gl_wrappers.py $(SPEC_FILES) wglext.h | EXTRA_DIST = gen_gl_wrappers.py wglext.h | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue