diff options
Diffstat (limited to 'mesalib')
55 files changed, 821 insertions, 298 deletions
| diff --git a/mesalib/configure.ac b/mesalib/configure.ac index b78eb1555..46265a221 100644 --- a/mesalib/configure.ac +++ b/mesalib/configure.ac @@ -1610,6 +1610,12 @@ AC_ARG_WITH([libclc-path],     [LIBCLC_PATH="$withval"],     [LIBCLC_PATH=""]) +AC_ARG_WITH([clang-libdir], +   [AS_HELP_STRING([--with-clang-libdir], +         [Path to Clang libraries @<:@default=llvm-config --libdir@:>@])], +   [CLANG_LIBDIR="$withval"], +   [CLANG_LIBDIR=""]) +  AC_SUBST([LIBCLC_PATH])  if test "x$enable_opencl" = xyes; then @@ -1696,6 +1702,7 @@ AC_SUBST([LLVM_LIBS])  AC_SUBST([LLVM_LDFLAGS])  AC_SUBST([LLVM_INCLUDEDIR])  AC_SUBST([LLVM_VERSION]) +AC_SUBST([CLANG_RESOURCE_DIR])  case "x$enable_opengl$enable_gles1$enable_gles2" in  x*yes*) @@ -1870,6 +1877,16 @@ if test "x$enable_gallium_llvm" = xyes; then  	LLVM_LIBDIR=`$LLVM_CONFIG --libdir`  	DEFINES="${DEFINES} -DHAVE_LLVM=`echo $LLVM_VERSION | sed -e 's/\([[0-9]]\)\.\([[0-9]]\)/0x0\10\2/g'`"  	MESA_LLVM=1 + +	dnl Check for Clang interanl headers +        if test "x$enable_opencl" = xyes; then +            if test "x$CLANG_LIBDIR" = x; then +                CLANG_LIBDIR=${LLVM_LIBDIR} +            fi +            CLANG_RESOURCE_DIR=$CLANG_LIBDIR/clang/${LLVM_VERSION} +            AC_CHECK_FILE("$CLANG_RESOURCE_DIR/include/stddef.h",, +                AC_MSG_ERROR([Could not find clang internal header stddef.h in $CLANG_RESOURCE_DIR Use --with-clang-libdir to specify the correct path to the clang libraries.])) +        fi      else  	MESA_LLVM=0      fi diff --git a/mesalib/docs/GL3.txt b/mesalib/docs/GL3.txt index 89b46c0a4..36d24725d 100644 --- a/mesalib/docs/GL3.txt +++ b/mesalib/docs/GL3.txt @@ -72,15 +72,16 @@ GLX_ARB_create_context_profile                        DONE  GL 3.3: -GLSL 3.30                                             not started +GLSL 3.30                                             new features in this version pretty much done  GL_ARB_blend_func_extended                            DONE (i965, r600, softpipe)  GL_ARB_explicit_attrib_location                       DONE (i915, i965, r300, r600, swrast)  GL_ARB_occlusion_query2                               DONE (r300, r600, swrast)  GL_ARB_sampler_objects                                DONE (i965, r300, r600) +GL_ARB_shader_bit_encoding                            DONE  GL_ARB_texture_rgb10_a2ui                             DONE (r600)  GL_ARB_texture_swizzle                                DONE (same as EXT version) (i965, r300, r600, swrast)  GL_ARB_timer_query                                    ~60% done (the EXT variant) -GL_ARB_instanced_arrays                               DONE (r300, r600) +GL_ARB_instanced_arrays                               DONE (i965, r300, r600)  GL_ARB_vertex_type_2_10_10_10_rev                     DONE (r600) diff --git a/mesalib/docs/autoconf.html b/mesalib/docs/autoconf.html index 4f1ad8d64..4fa96c3c6 100644 --- a/mesalib/docs/autoconf.html +++ b/mesalib/docs/autoconf.html @@ -10,18 +10,18 @@  <h1>Compilation and Installation using Autoconf</h1>  <ol> -<li><p ><a href="#basic">Basic Usage</a></li> -<li><p ><a href="#driver">Driver Options</a> +<li><p><a href="#basic">Basic Usage</a></li> +<li><p><a href="#driver">Driver Options</a>    <ul>    <li><a href="#xlib">Xlib Driver Options</a></li>    <li><a href="#dri">DRI Driver Options</a></li>    <li><a href="#osmesa">OSMesa Driver Options</a></li>    </ul> -<li><p ><a href="#library">Library Options</a> +<li><p><a href="#library">Library Options</a>    <ul>    <li><a href="#glu">GLU</a></li>    </ul> -<li><p ><a href="#demos">Demo Program Options</a> +<li><p><a href="#demos">Demo Program Options</a>  </ol> @@ -149,13 +149,13 @@ configure option --with-driver. There are currently three supported  options in the configure script.  </p> -<h3 id="xlib">Xlib</h3 ><p >This is the default mode for building Mesa. +<h3 id="xlib">Xlib</h3><p>This is the default mode for building Mesa.  It uses Xlib as a software renderer to do all rendering. It corresponds  to the option <code>--with-driver=xlib</code>. The libX11 and libXext  libraries, as well as the X11 development headers, will be need to  support the Xlib driver. -<h3 id="dri">DRI </h3 ><p >This mode uses the DRI hardware drivers for +<h3 id="dri">DRI</h3><p>This mode uses the DRI hardware drivers for  accelerated OpenGL rendering. Enable the DRI drivers with the option  <code>--with-driver=dri</code>. See the <a href="install.html">basic  installation instructions</a> for details on prerequisites for the DRI @@ -163,12 +163,12 @@ drivers.  <!-- DRI specific options -->  <dl> -<dt><code>--with-dri-driverdir=DIR</code>  -<dd ><p > This option specifies the +<dt><code>--with-dri-driverdir=DIR</code> +<dd><p> This option specifies the  location the DRI drivers will be installed to and the location libGL  will search for DRI drivers. The default is <code>${libdir}/dri</code>. -<dt><code>--with-dri-drivers=DRIVER,DRIVER,...</code>  -<dd ><p > This option +<dt><code>--with-dri-drivers=DRIVER,DRIVER,...</code> +<dd><p> This option  allows a specific set of DRI drivers to be built. For example,  <code>--with-dri-drivers="swrast,i965,radeon,nouveau"</code>. By  default, the drivers will be chosen depending on the target platform. @@ -177,16 +177,16 @@ for available drivers. Beware that the swrast DRI driver is used by both  libGL and the X.Org xserver GLX module to do software rendering, so you  may run into problems if it is not available.  <!-- This explanation might be totally bogus. Kristian? --> -<dt><code>--disable-driglx-direct</code>  -<dd ><p > Disable direct rendering in +<dt><code>--disable-driglx-direct</code> +<dd><p> Disable direct rendering in  GLX. Normally, direct hardware rendering through the DRI drivers and  indirect software rendering are enabled in GLX. This option disables  direct rendering entirely. It can be useful on architectures where  kernel DRM modules are not available. -<dt><code>--enable-glx-tls</code> <dd ><p >  +<dt><code>--enable-glx-tls</code> <dd><p>  Enable Thread Local Storage (TLS) in  GLX. -<dt><code>--with-expat=DIR</code> <dd > The DRI-enabled libGL uses expat to +<dt><code>--with-expat=DIR</code> <dd> The DRI-enabled libGL uses expat to  parse the DRI configuration files in <code>/etc/drirc</code> and  <code>~/.drirc</code>. This option allows a specific expat installation  to be used. For example, <code>--with-expat=/usr/local</code> will @@ -201,7 +201,7 @@ page for more details.  <!-- OSMesa specific options -->  <dl> -<dt><code>--with-osmesa-bits=BITS</code>  +<dt><code>--with-osmesa-bits=BITS</code>  <dd><p> This option allows the size  of the color channel in bits to be specified. By default, an 8-bit  channel will be used, and the driver will be named libOSMesa. Other @@ -235,7 +235,7 @@ the programs will be built depending on the driver and library options  chosen. See the directory <code>progs</code> for the full set of demos.  <dl> -<dt><code>--with-demos=DEMOS,DEMOS,...</code>  +<dt><code>--with-demos=DEMOS,DEMOS,...</code>  <dd><p> This option allows a  specific set of demo programs to be built. For example,  <code>--with-demos="xdemos,slang"</code>. Beware that if this option is diff --git a/mesalib/docs/devinfo.html b/mesalib/docs/devinfo.html index 4828cc61d..a469cbaa6 100644 --- a/mesalib/docs/devinfo.html +++ b/mesalib/docs/devinfo.html @@ -163,36 +163,33 @@ branch is relevant.  <h3>Verify and update version info</h3> -<p> -Create/edit the docs/relnotes-x.y.html file to document what's new in the release. -Add the new relnotes-x.y.html file to <a href="relnotes.html">relnotes.html</a>. -</p> -<p> -Update the MESA_MAJOR, MESA_MINOR and MESA_TINY version numbers in -configs/default. -Also update the VERSION line in the top-level Makefile. -</p> - -<p> -Make sure the values in src/mesa/main/version.h are correct. -</p> - -<p> -Update docs/news.html. -</p> +<dl> +  <dt>configs/default</dt> +  <dd>MESA_MAJOR, MESA_MINOR and MESA_TINY</dd> +  <dt>Makefile.am</dt> +  <dd>PACKAGE_VERSION</dd> +  <dt>autoconf.ac</dt> +  <dd>AC_INIT</dd> +  <dt>src/mesa/main/version.h</dt> +  <dd>MESA_MAJOR, MESA_MINOR, MESA_PATCH and MESA_VERSION_STRING</dd> +</dl>  <p>  Create a docs/relnotes-x.y.z.html file.  The bin/shortlog_mesa.sh script can be used to create a HTML-formatted list  of changes to include in the file. -Link the new docs/relnotes-x.y.z.html file into the main relnotes.html file. +Link the new docs/relnotes-x.y.z.html file into the main <a href="relnotes.html">relnotes.html</a> file. +</p> + +<p> +Update <a href="news.html">docs/news.html</a>.  </p>  <p> -Tag the files with the release name (in the form <b>mesa_X_Y</b>) -with: <code>git tag -a mesa_X_Y</code> -Then: <code>git push origin mesa_X_Y</code> +Tag the files with the release name (in the form <b>mesa-x.y</b>) +with: <code>git tag -a mesa-x.y</code> +Then: <code>git push origin mesa-x.y</code>  </p> @@ -206,7 +203,7 @@ Make the distribution files.  From inside the Mesa directory:  <p>  After the tarballs are created, the md5 checksums for the files will  be computed. -Add them to the docs/relnotes-X.Y.html file. +Add them to the docs/relnotes-x.y.html file.  </p>  <p> diff --git a/mesalib/docs/envvars.html b/mesalib/docs/envvars.html index fffb50a47..89f71739c 100644 --- a/mesalib/docs/envvars.html +++ b/mesalib/docs/envvars.html @@ -42,6 +42,8 @@ sometimes be useful for debugging end-user issues.     printed to stderr.<br>     If the value of MESA_DEBUG is 'FP' floating point arithmetic errors will     generate exceptions. +<li>MESA_LOG_FILE - specifies a file name for logging all errors, warnings, +etc., rather than stderr  <li>MESA_TEX_PROG - if set, implement conventional texture env modes with  fragment programs (intended for developers only)  <li>MESA_TNL_PROG - if set, implement conventional vertex transformation @@ -119,6 +121,8 @@ Mesa EGL supports different sets of environment variables.  See the  <h2>Gallium environment variables</h2>  <ul> +<li>GALLIUM_LOG_FILE - specifies a file for logging all errors, warnings, etc. +    rather than stderr.  <li>GALLIUM_PRINT_OPTIONS - if non-zero, print all the Gallium environment      variables which are used, and their current values.  <li>GALLIUM_NOSSE - if non-zero, do not use SSE runtime code generation for diff --git a/mesalib/docs/faq.html b/mesalib/docs/faq.html index dbef6a58c..fa90d5bfe 100644 --- a/mesalib/docs/faq.html +++ b/mesalib/docs/faq.html @@ -389,7 +389,7 @@ algorithms).  </p>  <p>  In the mean time, a 3rd party <a href= -"http://homepage.hispeed.ch/rscheidegger/dri_experimental/s3tc_index.html" +"http://dri.freedesktop.org/wiki/S3TC"  target="_parent">plug-in library</a> is available.  </p> diff --git a/mesalib/docs/games.html b/mesalib/docs/games.html index eaa7f4073..812c21d44 100644 --- a/mesalib/docs/games.html +++ b/mesalib/docs/games.html @@ -15,7 +15,7 @@  	- battle game  	</li><li><a href="http://bzflag.sourceforge.net/" target="_parent">BZFLAG</a> - 3-D tank  	battle game -	</li><li><a href="http://www.speakeasy.org/%7Emorse/copter-commander">Copter Commander</a> - 2d multiplayer side scroller +	</li><li><a href="http://www.speakeasy.org/%7Emorse/copter-commander" target="_parent">Copter Commander</a> - 2d multiplayer side scroller  	</li><li><a href="http://www.crystalspace.org/" target="_parent">CrystalSpace</a> - Free  	3d game engine  	</li><li><a href="http://www.afn.org/%7Ecthugha/" target="_parent">Cthugha</a> - music-sync'ed @@ -40,7 +40,7 @@  	</li><li><a href="http://jongl.home.pages.de/" target="_parent">JONGL</a> - Juggling simulator  	</li><li><a href="http://samba.anu.edu.au/KnightCap/" target="_parent">KnightCap</a> -  	chess game -	</li><li><a href="http://www.hackcraft.de/games/linwarrior_3d/">LinWarrior 3D</a> - A Battle Mech Simulator +	</li><li><a href="http://www.hackcraft.de/games/linwarrior_3d/" target="_parent">LinWarrior 3D</a> - A Battle Mech Simulator  	</li><li><a href="http://www.nada.kth.se/%7Ef96-lfo/lunar/" target="_parent">Lunar Lander  	2000</a> - 3D version of the classis lunar lander game  	</li><li><a href="http://www.majik3d.org/" target="_parent">Majik 3D</a> - an online role-playing diff --git a/mesalib/docs/helpwanted.html b/mesalib/docs/helpwanted.html index 444c12b5a..6d6058eb5 100644 --- a/mesalib/docs/helpwanted.html +++ b/mesalib/docs/helpwanted.html @@ -17,36 +17,48 @@ Here are some specific ideas and areas where help would be appreciated:  <ol>  <li>  <b>Driver patching and testing.</b> -Patches are often posted to the mesa3d-dev mailing list, but aren't +Patches are often posted to the <a href="http://lists.freedesktop.org/mailman/listinfo/mesa-dev" target="_parent">mesa-dev mailing list</a>, but aren't  immediately checked into git because not enough people are testing them.  Just applying patches, testing and reporting back is helpful.  <li>  <b>Driver debugging.</b> -There are plenty of open bugs in the bug database. +There are plenty of open bugs in the <a href="https://bugs.freedesktop.org/describecomponents.cgi?product=Mesa" target="_parent">bug database</a>.  <li>  <b>Remove aliasing warnings.</b>  Enable gcc -Wstrict-aliasing=2 -fstrict-aliasing and track down aliasing  issues in the code.  <li>  <b>Windows driver building, testing and maintenance.</b> -The Visual Studio project files aren't always updated in a timely manner -when new source files are added or old ones are removed. -Fixing these tends to delay new Mesa releases. +Fixing MSVC builds.  <li>  <b>Maintenance and testing of lesser-used drivers.</b> -Drivers such as DOS/DJGPP, GGI, etc that aren't being maintained are being -deprecated starting in Mesa 7.3. +Drivers such as i810, mach64, mga, r128, savage, sis, tdfx, unichrome, etc that aren't being maintained are being +deprecated starting in Mesa 8.0.<br> +They have to be ported to DRI2 to be accepted in mesa master again.  <li>  <b>Contribute more tests to -<a href="http://glean.sourceforge.net/" target="_parent">glean</a>.</b> +<a href="http://people.freedesktop.org/~nh/piglit/" target="_parent">Piglit</a>.</b>  <li>  <b>Automatic testing.  </b>  It would be great if someone would set up an automated system for grabbing -the latest Mesa code and run tests (such as glean) then report issues to +the latest Mesa code and run tests (such as piglit) then report issues to  the mailing list.  </ol> +<p> +You can find some further To-do lists here: +</p> +<ul> +  <li><a href="http://cgit.freedesktop.org/mesa/mesa/tree/docs/GL3.txt" +    target="_parent"><b>GL3.txt</b></a></li> +  <li><a href="http://cgit.freedesktop.org/mesa/mesa/tree/src/gallium/docs/llvm-todo.txt" +    target="_parent"><b>LLVMpipe - todo</b></a></li> +  <li><a href="http://dri.freedesktop.org/wiki/MissingFunctionality" +    target="_parent"><b>MissingFunctionality</b></a></li> +  <li><a href="http://dri.freedesktop.org/wiki/R300ToDo" +    target="_parent"><b>R300ToDo</b></a></li> +</ul>  <p>  If you want to do something new in Mesa, first join the Mesa developer's diff --git a/mesalib/docs/libraries.html b/mesalib/docs/libraries.html index e9db42790..b410bc1c2 100644 --- a/mesalib/docs/libraries.html +++ b/mesalib/docs/libraries.html @@ -10,7 +10,7 @@  <h1>Libraries and Toolkits</h1>  <ul> -<li><a href="http://mrpowers.com/Apprentice/">Apprentice</a> - free OpenInventor work-alike +<li><a href="http://mrpowers.com/Apprentice/" target="_parent">Apprentice</a> - free OpenInventor work-alike  <li><a href="http://www.coin3d.org/coin.html" target="_parent">Coin</a> - OSS Open Inventor clone  <li><a href="http://www.softintegration.com/products/toolkit/opengl/" target="_parent">Ch</a> - OpenGL bindings for the Ch C/C++ interpreter  <li><a href="http://www.cfdrc.com/FOX/fox.html" target="_parent">FOX</a> - GUI Library diff --git a/mesalib/docs/lists.html b/mesalib/docs/lists.html index d89bcffbd..e415fc9b1 100644 --- a/mesalib/docs/lists.html +++ b/mesalib/docs/lists.html @@ -32,6 +32,9 @@ In general, people should not post to this list.</p>  target="_parent">mesa-announce</a> - announcements of new Mesa  versions are sent to this list.  Very low traffic.</p>  </li> +<li><p><a href="http://lists.freedesktop.org/mailman/listinfo/piglit" +target="_parent">piglit</a> - for Piglit (OpenGL driver testing framework) discussion.</p> +</li>  </ul>  <p> diff --git a/mesalib/docs/perf.html b/mesalib/docs/perf.html index ec400c613..82e6b5988 100644 --- a/mesalib/docs/perf.html +++ b/mesalib/docs/perf.html @@ -52,7 +52,7 @@ Performance tips for software rendering:           GL_COLOR_MATERIAL is disabled           No spot lights are used (all GL_SPOT_CUTOFFs are 180.0)           No local lights are used (all position W's are 0.0) -         All material and light coefficients are >= zero +         All material and light coefficients are >= zero  <li> XFree86 users:  if you want to use 24-bit color try starting your        X server in 32-bit per pixel mode for better performance.  That is,        start your X server with diff --git a/mesalib/docs/repository.html b/mesalib/docs/repository.html index 3e05871fd..adbfcf909 100644 --- a/mesalib/docs/repository.html +++ b/mesalib/docs/repository.html @@ -10,7 +10,7 @@  <h1>Code Repository</h1>  <p> -Mesa uses <a href="http://git.or.cz/"target="_parent">git</a> +Mesa uses <a href="http://git-scm.com"target="_parent">git</a>  as its source code management system.  </p> @@ -95,7 +95,7 @@ Once your account is established:  <h2>Windows Users</h2>  <p> -If you're <a href="http://git.or.cz/gitwiki/WindowsInstall" target="_parent"> +If you're <a href="http://git.wiki.kernel.org/index.php/WindowsInstall" target="_parent">  using git on Windows</a> you'll want to enable automatic CR/LF conversion in  your local copy of the repository:  </p> diff --git a/mesalib/docs/shading.html b/mesalib/docs/shading.html index 175e02460..a9b7cfc4b 100644 --- a/mesalib/docs/shading.html +++ b/mesalib/docs/shading.html @@ -209,30 +209,30 @@ struct gl_shader_state  };  </pre> -<ul> -<li>EmitHighLevelInstructions -<br> +<dl> +<dt>EmitHighLevelInstructions</dt> +<dd>  This option controls instruction selection for loops and conditionals.  If the option is set high-level IF/ELSE/ENDIF, LOOP/ENDLOOP, CONT/BRK  instructions will be emitted.  Otherwise, those constructs will be implemented with BRA instructions. -</li> +</dd> -<li>EmitCondCodes -<br> +<dt>EmitCondCodes</dt> +<dd>  If set, condition codes (ala GL_NV_fragment_program) will be used for  branching and looping.  Otherwise, ordinary registers will be used (the IF instruction will  examine the first operand's X component and do the if-part if non-zero).  This option is only relevant if EmitHighLevelInstructions is set. -</li> +</dd> -<li>EmitComments -<br> +<dt>EmitComments</dt> +<dd>  If set, instructions will be annoted with comments to help with debugging.  Extra NOP instructions will also be inserted. -</li> -</ul> +</dd> +</dl>  <h2 id="validation">Compiler Validation</h2> @@ -243,7 +243,7 @@ regressions.  </p>  <p> -The <a href="http://people.freedesktop.org/~nh/piglit/">Piglit</a> project +The <a href="http://people.freedesktop.org/~nh/piglit/" target="_parent">Piglit</a> project  has many GLSL tests and the  <a href="http://glean.sf.net" target="_parent">Glean</a> glsl1 test   tests GLSL features. diff --git a/mesalib/docs/sourcedocs.html b/mesalib/docs/sourcedocs.html index 2b1633c67..898ecac74 100644 --- a/mesalib/docs/sourcedocs.html +++ b/mesalib/docs/sourcedocs.html @@ -24,7 +24,7 @@ the <code>doxygen</code> directory and run <code>make</code>.  <p>  For an example of Doxygen usage in Mesa, see a recent source file -such as <a href="http://webcvs.freedesktop.org/mesa/Mesa/src/mesa/main/bufferobj.c?view=markup" target="_parent">bufferobj.c</a>. +such as <a href="http://cgit.freedesktop.org/mesa/mesa/tree/src/mesa/main/bufferobj.c" target="_parent">bufferobj.c</a>.  </p> diff --git a/mesalib/docs/sourcetree.html b/mesalib/docs/sourcetree.html index abc5e3986..42675d9bb 100644 --- a/mesalib/docs/sourcetree.html +++ b/mesalib/docs/sourcetree.html @@ -43,6 +43,8 @@ each directory.  	   <li><b>common</b> - code shared by all DRI drivers  	   <li><b>i915</b> - driver for Intel i915/i945  	   <li><b>i965</b> - driver for Intel i965 +	   <li><b>radeon</b> - driver for ATI R100 +	   <li><b>r200</b> - driver for ATI R200  	   <li>XXX more             </ul>          <li><b>x11</b> - Xlib-based software driver @@ -90,7 +92,9 @@ each directory.        <li><b>i915</b> - Driver for Intel i915/i945.        <li><b>llvmpipe</b> - Software driver using LLVM for runtime code generation.        <li><b>nv*</b> - Drivers for NVIDIA GPUs. -      <li><b>r300</b> - Driver for ATI/AMD R300. +      <li><b>radeonsi</b> - Driver for AMD Southern Island. +      <li><b>r300</b> - Driver for ATI R300 - R500. +      <li><b>r600</b> - Driver for ATI/AMD R600 - Northern Island.        <li><b>softpipe</b> - Software reference driver.        <li><b>svga</b> - Driver for VMware's SVGA virtual GPU.        <li><b>trace</b> - Driver for tracing Gallium calls. @@ -127,9 +131,8 @@ each directory.         <li><b>dri</b> - Meta state tracker for DRI drivers         <li><b>egl</b> - Meta state tracker for EGL drivers         <li><b>es</b> - OpenGL ES 1.x and 2.x state trackers -       <li><b>g3dvl</b> -         <li><b>glx</b> - Meta state tracker for GLX -       <li><b>python</b> - +       <li><b>vdpau</b> - VDPAU state tracker         <li><b>vega</b> - OpenVG 1.x state tracker         <li><b>wgl</b> -         <li><b>xorg</b> - Meta state tracker for Xorg video drivers @@ -137,7 +140,6 @@ each directory.      <li><b>winsys</b> -         <ul>         <li><b>drm</b> - -       <li><b>g3dvl</b> -         <li><b>gdi</b> -         <li><b>xlib</b> -         </ul> diff --git a/mesalib/docs/systems.html b/mesalib/docs/systems.html index 999975183..171d12813 100644 --- a/mesalib/docs/systems.html +++ b/mesalib/docs/systems.html @@ -26,12 +26,14 @@ and ES 2, OpenVG and the EGL interface.  Hardware drivers include:  </p>  <ul> -<li>Intel i965, i945, i915. +  <li>Intel i965, i945, i915.      See <a href="http://intellinuxgraphics.org/index.html" target="_parent"> -    Intel's website</a> -<li>AMD Radeon series -<li>Some NVIDIA GPus. -<li>VMware virtual GPU +      Intel's website</a></li> +  <li>AMD Radeon series. +  See <a href="http://www.x.org/wiki/RadeonFeature" target="_parent">RadeonFeature</a></li> +  <li>NVIDIA GPUs. +  See <a href="http://nouveau.freedesktop.org" target="_parent">Nouveau Wiki</a></li> +  <li><a href="http://www.x.org/wiki/vmware" target="_parent">VMware virtual GPU</a></li>  </ul>  <p> diff --git a/mesalib/docs/thanks.html b/mesalib/docs/thanks.html index b9a2b27cb..6b658e3b4 100644 --- a/mesalib/docs/thanks.html +++ b/mesalib/docs/thanks.html @@ -33,7 +33,7 @@ Tungsten Graphics, Inc. have supported the ongoing development of Mesa.  <br>  <br>  <li>The -<a href="http://sourceforge.net/projects/mesa3d" target="_parent">Mesa</a> +<a href="http://www.mesa3d.org" target="_parent">Mesa</a>  website is hosted by  <a href="http://sourceforge.net" target="_parent">  <img src="http://sourceforge.net/sflogo.php?group_id=3&type=1" diff --git a/mesalib/docs/utilities.html b/mesalib/docs/utilities.html index c74816944..8dd1df08e 100644 --- a/mesalib/docs/utilities.html +++ b/mesalib/docs/utilities.html @@ -17,7 +17,7 @@ progs/util/ directory  <li>Allen Akin's <a href="http://glean.sourceforge.net/"  target="_parent">glean</a> is a framework for OpenGL testing. -<li><a href="http://developer.kde.org/~sewardj/" +<li><a href="http://www.valgrind.org"  target="_parent">Valgrind</a> is a very useful tool for tracking down  memory-related problems in your code. diff --git a/mesalib/include/GL/glext.h b/mesalib/include/GL/glext.h index 113241e77..8fce0f6f0 100644 --- a/mesalib/include/GL/glext.h +++ b/mesalib/include/GL/glext.h @@ -6,7 +6,7 @@ extern "C" {  #endif  /* -** Copyright (c) 2007-2011 The Khronos Group Inc. +** Copyright (c) 2007-2012 The Khronos Group Inc.  **   ** Permission is hereby granted, free of charge, to any person obtaining a  ** copy of this software and/or associated documentation files (the @@ -29,9 +29,9 @@ extern "C" {  */  /* Header file version number, required by OpenGL ABI for Linux */ -/* glext.h last updated $Date: 2011-08-08 00:34:29 -0700 (Mon, 08 Aug 2011) $ */ +/* glext.h last updated $Date: 2012-04-26 00:59:42 -0700 (Thu, 26 Apr 2012) $ */  /* Current version at http://www.opengl.org/registry/ */ -#define GL_GLEXT_VERSION 72 +#define GL_GLEXT_VERSION 81  /* Function declaration macros - to move into glplatform.h */  #if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) && !defined(__SCITECH_SNAP__) @@ -516,8 +516,6 @@ extern "C" {  #define GL_MINOR_VERSION                  0x821C  #define GL_NUM_EXTENSIONS                 0x821D  #define GL_CONTEXT_FLAGS                  0x821E -#define GL_DEPTH_BUFFER                   0x8223 -#define GL_STENCIL_BUFFER                 0x8224  #define GL_COMPRESSED_RED                 0x8225  #define GL_COMPRESSED_RG                  0x8226  #define GL_CONTEXT_FLAG_FORWARD_COMPATIBLE_BIT 0x0001 @@ -1021,6 +1019,7 @@ extern "C" {  /* reuse GL_MAX_VERTEX_UNIFORM_VECTORS */  /* reuse GL_MAX_VARYING_VECTORS */  /* reuse GL_MAX_FRAGMENT_UNIFORM_VECTORS */ +/* reuse GL_RGB565 */  /* Reuse tokens from ARB_get_program_binary */  /* reuse GL_PROGRAM_BINARY_RETRIEVABLE_HINT */  /* reuse GL_PROGRAM_BINARY_LENGTH */ @@ -1884,8 +1883,10 @@ extern "C" {  #endif  #ifndef GL_ARB_copy_buffer -#define GL_COPY_READ_BUFFER               0x8F36 -#define GL_COPY_WRITE_BUFFER              0x8F37 +#define GL_COPY_READ_BUFFER_BINDING       0x8F36 +#define GL_COPY_READ_BUFFER               GL_COPY_READ_BUFFER_BINDING +#define GL_COPY_WRITE_BUFFER_BINDING      0x8F37 +#define GL_COPY_WRITE_BUFFER              GL_COPY_WRITE_BUFFER_BINDING  #endif  #ifndef GL_ARB_shader_texture_lod @@ -2133,8 +2134,10 @@ extern "C" {  #ifndef GL_ARB_transform_feedback2  #define GL_TRANSFORM_FEEDBACK             0x8E22 -#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED 0x8E23 -#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE 0x8E24 +#define GL_TRANSFORM_FEEDBACK_PAUSED      0x8E23 +#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED GL_TRANSFORM_FEEDBACK_PAUSED +#define GL_TRANSFORM_FEEDBACK_ACTIVE      0x8E24 +#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE GL_TRANSFORM_FEEDBACK_ACTIVE  #define GL_TRANSFORM_FEEDBACK_BINDING     0x8E25  #endif @@ -2158,6 +2161,7 @@ extern "C" {  #define GL_MAX_VERTEX_UNIFORM_VECTORS     0x8DFB  #define GL_MAX_VARYING_VECTORS            0x8DFC  #define GL_MAX_FRAGMENT_UNIFORM_VECTORS   0x8DFD +#define GL_RGB565                         0x8D62  #endif  #ifndef GL_ARB_get_program_binary @@ -5313,6 +5317,167 @@ extern "C" {  #define GL_SCALED_RESOLVE_NICEST_EXT      0x90BB  #endif +#ifndef GL_NV_path_rendering +#define GL_PATH_FORMAT_SVG_NV             0x9070 +#define GL_PATH_FORMAT_PS_NV              0x9071 +#define GL_STANDARD_FONT_NAME_NV          0x9072 +#define GL_SYSTEM_FONT_NAME_NV            0x9073 +#define GL_FILE_NAME_NV                   0x9074 +#define GL_PATH_STROKE_WIDTH_NV           0x9075 +#define GL_PATH_END_CAPS_NV               0x9076 +#define GL_PATH_INITIAL_END_CAP_NV        0x9077 +#define GL_PATH_TERMINAL_END_CAP_NV       0x9078 +#define GL_PATH_JOIN_STYLE_NV             0x9079 +#define GL_PATH_MITER_LIMIT_NV            0x907A +#define GL_PATH_DASH_CAPS_NV              0x907B +#define GL_PATH_INITIAL_DASH_CAP_NV       0x907C +#define GL_PATH_TERMINAL_DASH_CAP_NV      0x907D +#define GL_PATH_DASH_OFFSET_NV            0x907E +#define GL_PATH_CLIENT_LENGTH_NV          0x907F +#define GL_PATH_FILL_MODE_NV              0x9080 +#define GL_PATH_FILL_MASK_NV              0x9081 +#define GL_PATH_FILL_COVER_MODE_NV        0x9082 +#define GL_PATH_STROKE_COVER_MODE_NV      0x9083 +#define GL_PATH_STROKE_MASK_NV            0x9084 +#define GL_PATH_SAMPLE_QUALITY_NV         0x9085 +#define GL_PATH_STROKE_BOUND_NV           0x9086 +#define GL_PATH_STROKE_OVERSAMPLE_COUNT_NV 0x9087 +#define GL_COUNT_UP_NV                    0x9088 +#define GL_COUNT_DOWN_NV                  0x9089 +#define GL_PATH_OBJECT_BOUNDING_BOX_NV    0x908A +#define GL_CONVEX_HULL_NV                 0x908B +#define GL_MULTI_HULLS_NV                 0x908C +#define GL_BOUNDING_BOX_NV                0x908D +#define GL_TRANSLATE_X_NV                 0x908E +#define GL_TRANSLATE_Y_NV                 0x908F +#define GL_TRANSLATE_2D_NV                0x9090 +#define GL_TRANSLATE_3D_NV                0x9091 +#define GL_AFFINE_2D_NV                   0x9092 +#define GL_PROJECTIVE_2D_NV               0x9093 +#define GL_AFFINE_3D_NV                   0x9094 +#define GL_PROJECTIVE_3D_NV               0x9095 +#define GL_TRANSPOSE_AFFINE_2D_NV         0x9096 +#define GL_TRANSPOSE_PROJECTIVE_2D_NV     0x9097 +#define GL_TRANSPOSE_AFFINE_3D_NV         0x9098 +#define GL_TRANSPOSE_PROJECTIVE_3D_NV     0x9099 +#define GL_UTF8_NV                        0x909A +#define GL_UTF16_NV                       0x909B +#define GL_BOUNDING_BOX_OF_BOUNDING_BOXES_NV 0x909C +#define GL_PATH_COMMAND_COUNT_NV          0x909D +#define GL_PATH_COORD_COUNT_NV            0x909E +#define GL_PATH_DASH_ARRAY_COUNT_NV       0x909F +#define GL_PATH_COMPUTED_LENGTH_NV        0x90A0 +#define GL_PATH_FILL_BOUNDING_BOX_NV      0x90A1 +#define GL_PATH_STROKE_BOUNDING_BOX_NV    0x90A2 +#define GL_SQUARE_NV                      0x90A3 +#define GL_ROUND_NV                       0x90A4 +#define GL_TRIANGULAR_NV                  0x90A5 +#define GL_BEVEL_NV                       0x90A6 +#define GL_MITER_REVERT_NV                0x90A7 +#define GL_MITER_TRUNCATE_NV              0x90A8 +#define GL_SKIP_MISSING_GLYPH_NV          0x90A9 +#define GL_USE_MISSING_GLYPH_NV           0x90AA +#define GL_PATH_ERROR_POSITION_NV         0x90AB +#define GL_PATH_FOG_GEN_MODE_NV           0x90AC +#define GL_ACCUM_ADJACENT_PAIRS_NV        0x90AD +#define GL_ADJACENT_PAIRS_NV              0x90AE +#define GL_FIRST_TO_REST_NV               0x90AF +#define GL_PATH_GEN_MODE_NV               0x90B0 +#define GL_PATH_GEN_COEFF_NV              0x90B1 +#define GL_PATH_GEN_COLOR_FORMAT_NV       0x90B2 +#define GL_PATH_GEN_COMPONENTS_NV         0x90B3 +#define GL_PATH_STENCIL_FUNC_NV           0x90B7 +#define GL_PATH_STENCIL_REF_NV            0x90B8 +#define GL_PATH_STENCIL_VALUE_MASK_NV     0x90B9 +#define GL_PATH_STENCIL_DEPTH_OFFSET_FACTOR_NV 0x90BD +#define GL_PATH_STENCIL_DEPTH_OFFSET_UNITS_NV 0x90BE +#define GL_PATH_COVER_DEPTH_FUNC_NV       0x90BF +#define GL_PATH_DASH_OFFSET_RESET_NV      0x90B4 +#define GL_MOVE_TO_RESETS_NV              0x90B5 +#define GL_MOVE_TO_CONTINUES_NV           0x90B6 +#define GL_CLOSE_PATH_NV                  0x00 +#define GL_MOVE_TO_NV                     0x02 +#define GL_RELATIVE_MOVE_TO_NV            0x03 +#define GL_LINE_TO_NV                     0x04 +#define GL_RELATIVE_LINE_TO_NV            0x05 +#define GL_HORIZONTAL_LINE_TO_NV          0x06 +#define GL_RELATIVE_HORIZONTAL_LINE_TO_NV 0x07 +#define GL_VERTICAL_LINE_TO_NV            0x08 +#define GL_RELATIVE_VERTICAL_LINE_TO_NV   0x09 +#define GL_QUADRATIC_CURVE_TO_NV          0x0A +#define GL_RELATIVE_QUADRATIC_CURVE_TO_NV 0x0B +#define GL_CUBIC_CURVE_TO_NV              0x0C +#define GL_RELATIVE_CUBIC_CURVE_TO_NV     0x0D +#define GL_SMOOTH_QUADRATIC_CURVE_TO_NV   0x0E +#define GL_RELATIVE_SMOOTH_QUADRATIC_CURVE_TO_NV 0x0F +#define GL_SMOOTH_CUBIC_CURVE_TO_NV       0x10 +#define GL_RELATIVE_SMOOTH_CUBIC_CURVE_TO_NV 0x11 +#define GL_SMALL_CCW_ARC_TO_NV            0x12 +#define GL_RELATIVE_SMALL_CCW_ARC_TO_NV   0x13 +#define GL_SMALL_CW_ARC_TO_NV             0x14 +#define GL_RELATIVE_SMALL_CW_ARC_TO_NV    0x15 +#define GL_LARGE_CCW_ARC_TO_NV            0x16 +#define GL_RELATIVE_LARGE_CCW_ARC_TO_NV   0x17 +#define GL_LARGE_CW_ARC_TO_NV             0x18 +#define GL_RELATIVE_LARGE_CW_ARC_TO_NV    0x19 +#define GL_RESTART_PATH_NV                0xF0 +#define GL_DUP_FIRST_CUBIC_CURVE_TO_NV    0xF2 +#define GL_DUP_LAST_CUBIC_CURVE_TO_NV     0xF4 +#define GL_RECT_NV                        0xF6 +#define GL_CIRCULAR_CCW_ARC_TO_NV         0xF8 +#define GL_CIRCULAR_CW_ARC_TO_NV          0xFA +#define GL_CIRCULAR_TANGENT_ARC_TO_NV     0xFC +#define GL_ARC_TO_NV                      0xFE +#define GL_RELATIVE_ARC_TO_NV             0xFF +#define GL_BOLD_BIT_NV                    0x01 +#define GL_ITALIC_BIT_NV                  0x02 +#define GL_GLYPH_WIDTH_BIT_NV             0x01 +#define GL_GLYPH_HEIGHT_BIT_NV            0x02 +#define GL_GLYPH_HORIZONTAL_BEARING_X_BIT_NV 0x04 +#define GL_GLYPH_HORIZONTAL_BEARING_Y_BIT_NV 0x08 +#define GL_GLYPH_HORIZONTAL_BEARING_ADVANCE_BIT_NV 0x10 +#define GL_GLYPH_VERTICAL_BEARING_X_BIT_NV 0x20 +#define GL_GLYPH_VERTICAL_BEARING_Y_BIT_NV 0x40 +#define GL_GLYPH_VERTICAL_BEARING_ADVANCE_BIT_NV 0x80 +#define GL_GLYPH_HAS_KERNING_NV           0x100 +#define GL_FONT_X_MIN_BOUNDS_NV           0x00010000 +#define GL_FONT_Y_MIN_BOUNDS_NV           0x00020000 +#define GL_FONT_X_MAX_BOUNDS_NV           0x00040000 +#define GL_FONT_Y_MAX_BOUNDS_NV           0x00080000 +#define GL_FONT_UNITS_PER_EM_NV           0x00100000 +#define GL_FONT_ASCENDER_NV               0x00200000 +#define GL_FONT_DESCENDER_NV              0x00400000 +#define GL_FONT_HEIGHT_NV                 0x00800000 +#define GL_FONT_MAX_ADVANCE_WIDTH_NV      0x01000000 +#define GL_FONT_MAX_ADVANCE_HEIGHT_NV     0x02000000 +#define GL_FONT_UNDERLINE_POSITION_NV     0x04000000 +#define GL_FONT_UNDERLINE_THICKNESS_NV    0x08000000 +#define GL_FONT_HAS_KERNING_NV            0x10000000 +#endif + +#ifndef GL_AMD_pinned_memory +#define GL_EXTERNAL_VIRTUAL_MEMORY_BUFFER_AMD 0x9160 +#endif + +#ifndef GL_AMD_stencil_operation_extended +#define GL_SET_AMD                        0x874A +#define GL_REPLACE_VALUE_AMD              0x874B +#define GL_STENCIL_OP_VALUE_AMD           0x874C +#define GL_STENCIL_BACK_OP_VALUE_AMD      0x874D +#endif + +#ifndef GL_AMD_vertex_shader_viewport_index +#endif + +#ifndef GL_AMD_vertex_shader_layer +#endif + +#ifndef GL_NV_bindless_texture +#endif + +#ifndef GL_NV_shader_atomic_float +#endif +  /*************************************************************/ @@ -5419,14 +5584,14 @@ typedef GLintptr GLvdpauSurfaceNV;  #ifndef GL_VERSION_1_2  #define GL_VERSION_1_2 1  #ifdef GL_GLEXT_PROTOTYPES -GLAPI void APIENTRY glBlendColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +GLAPI void APIENTRY glBlendColor (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);  GLAPI void APIENTRY glBlendEquation (GLenum mode);  GLAPI void APIENTRY glDrawRangeElements (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices);  GLAPI void APIENTRY glTexImage3D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels);  GLAPI void APIENTRY glTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels);  GLAPI void APIENTRY glCopyTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height);  #endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRYP PFNGLBLENDCOLORPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +typedef void (APIENTRYP PFNGLBLENDCOLORPROC) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);  typedef void (APIENTRYP PFNGLBLENDEQUATIONPROC) (GLenum mode);  typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices);  typedef void (APIENTRYP PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); @@ -5508,7 +5673,7 @@ typedef void (APIENTRYP PFNGLRESETMINMAXPROC) (GLenum target);  #define GL_VERSION_1_3 1  #ifdef GL_GLEXT_PROTOTYPES  GLAPI void APIENTRY glActiveTexture (GLenum texture); -GLAPI void APIENTRY glSampleCoverage (GLclampf value, GLboolean invert); +GLAPI void APIENTRY glSampleCoverage (GLfloat value, GLboolean invert);  GLAPI void APIENTRY glCompressedTexImage3D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data);  GLAPI void APIENTRY glCompressedTexImage2D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data);  GLAPI void APIENTRY glCompressedTexImage1D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); @@ -5518,7 +5683,7 @@ GLAPI void APIENTRY glCompressedTexSubImage1D (GLenum target, GLint level, GLint  GLAPI void APIENTRY glGetCompressedTexImage (GLenum target, GLint level, GLvoid *img);  #endif /* GL_GLEXT_PROTOTYPES */  typedef void (APIENTRYP PFNGLACTIVETEXTUREPROC) (GLenum texture); -typedef void (APIENTRYP PFNGLSAMPLECOVERAGEPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEPROC) (GLfloat value, GLboolean invert);  typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data);  typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data);  typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); @@ -5613,7 +5778,7 @@ typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXDPROC) (const GLdouble *m);  #ifdef GL_GLEXT_PROTOTYPES  GLAPI void APIENTRY glBlendFuncSeparate (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha);  GLAPI void APIENTRY glMultiDrawArrays (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); -GLAPI void APIENTRY glMultiDrawElements (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount); +GLAPI void APIENTRY glMultiDrawElements (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* const *indices, GLsizei primcount);  GLAPI void APIENTRY glPointParameterf (GLenum pname, GLfloat param);  GLAPI void APIENTRY glPointParameterfv (GLenum pname, const GLfloat *params);  GLAPI void APIENTRY glPointParameteri (GLenum pname, GLint param); @@ -5621,7 +5786,7 @@ GLAPI void APIENTRY glPointParameteriv (GLenum pname, const GLint *params);  #endif /* GL_GLEXT_PROTOTYPES */  typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha);  typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); -typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* const *indices, GLsizei primcount);  typedef void (APIENTRYP PFNGLPOINTPARAMETERFPROC) (GLenum pname, GLfloat param);  typedef void (APIENTRYP PFNGLPOINTPARAMETERFVPROC) (GLenum pname, const GLfloat *params);  typedef void (APIENTRYP PFNGLPOINTPARAMETERIPROC) (GLenum pname, GLint param); @@ -5791,7 +5956,7 @@ GLAPI void APIENTRY glGetVertexAttribPointerv (GLuint index, GLenum pname, GLvoi  GLAPI GLboolean APIENTRY glIsProgram (GLuint program);  GLAPI GLboolean APIENTRY glIsShader (GLuint shader);  GLAPI void APIENTRY glLinkProgram (GLuint program); -GLAPI void APIENTRY glShaderSource (GLuint shader, GLsizei count, const GLchar* *string, const GLint *length); +GLAPI void APIENTRY glShaderSource (GLuint shader, GLsizei count, const GLchar* const *string, const GLint *length);  GLAPI void APIENTRY glUseProgram (GLuint program);  GLAPI void APIENTRY glUniform1f (GLint location, GLfloat v0);  GLAPI void APIENTRY glUniform2f (GLint location, GLfloat v0, GLfloat v1); @@ -5885,7 +6050,7 @@ typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVPROC) (GLuint index, GLenum  typedef GLboolean (APIENTRYP PFNGLISPROGRAMPROC) (GLuint program);  typedef GLboolean (APIENTRYP PFNGLISSHADERPROC) (GLuint shader);  typedef void (APIENTRYP PFNGLLINKPROGRAMPROC) (GLuint program); -typedef void (APIENTRYP PFNGLSHADERSOURCEPROC) (GLuint shader, GLsizei count, const GLchar* *string, const GLint *length); +typedef void (APIENTRYP PFNGLSHADERSOURCEPROC) (GLuint shader, GLsizei count, const GLchar* const *string, const GLint *length);  typedef void (APIENTRYP PFNGLUSEPROGRAMPROC) (GLuint program);  typedef void (APIENTRYP PFNGLUNIFORM1FPROC) (GLint location, GLfloat v0);  typedef void (APIENTRYP PFNGLUNIFORM2FPROC) (GLint location, GLfloat v0, GLfloat v1); @@ -5981,7 +6146,7 @@ GLAPI void APIENTRY glBeginTransformFeedback (GLenum primitiveMode);  GLAPI void APIENTRY glEndTransformFeedback (void);  GLAPI void APIENTRY glBindBufferRange (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size);  GLAPI void APIENTRY glBindBufferBase (GLenum target, GLuint index, GLuint buffer); -GLAPI void APIENTRY glTransformFeedbackVaryings (GLuint program, GLsizei count, const GLchar* *varyings, GLenum bufferMode); +GLAPI void APIENTRY glTransformFeedbackVaryings (GLuint program, GLsizei count, const GLchar* const *varyings, GLenum bufferMode);  GLAPI void APIENTRY glGetTransformFeedbackVarying (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name);  GLAPI void APIENTRY glClampColor (GLenum target, GLenum clamp);  GLAPI void APIENTRY glBeginConditionalRender (GLuint id, GLenum mode); @@ -6040,7 +6205,7 @@ typedef void (APIENTRYP PFNGLBEGINTRANSFORMFEEDBACKPROC) (GLenum primitiveMode);  typedef void (APIENTRYP PFNGLENDTRANSFORMFEEDBACKPROC) (void);  typedef void (APIENTRYP PFNGLBINDBUFFERRANGEPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size);  typedef void (APIENTRYP PFNGLBINDBUFFERBASEPROC) (GLenum target, GLuint index, GLuint buffer); -typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKVARYINGSPROC) (GLuint program, GLsizei count, const GLchar* *varyings, GLenum bufferMode); +typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKVARYINGSPROC) (GLuint program, GLsizei count, const GLchar* const *varyings, GLenum bufferMode);  typedef void (APIENTRYP PFNGLGETTRANSFORMFEEDBACKVARYINGPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name);  typedef void (APIENTRYP PFNGLCLAMPCOLORPROC) (GLenum target, GLenum clamp);  typedef void (APIENTRYP PFNGLBEGINCONDITIONALRENDERPROC) (GLuint id, GLenum mode); @@ -6157,13 +6322,13 @@ typedef void (APIENTRYP PFNGLVERTEXATTRIBDIVISORPROC) (GLuint index, GLuint divi  /* ARB_transform_feedback2 */  /* ARB_transform_feedback3 */  #ifdef GL_GLEXT_PROTOTYPES -GLAPI void APIENTRY glMinSampleShading (GLclampf value); +GLAPI void APIENTRY glMinSampleShading (GLfloat value);  GLAPI void APIENTRY glBlendEquationi (GLuint buf, GLenum mode);  GLAPI void APIENTRY glBlendEquationSeparatei (GLuint buf, GLenum modeRGB, GLenum modeAlpha);  GLAPI void APIENTRY glBlendFunci (GLuint buf, GLenum src, GLenum dst);  GLAPI void APIENTRY glBlendFuncSeparatei (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha);  #endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRYP PFNGLMINSAMPLESHADINGPROC) (GLclampf value); +typedef void (APIENTRYP PFNGLMINSAMPLESHADINGPROC) (GLfloat value);  typedef void (APIENTRYP PFNGLBLENDEQUATIONIPROC) (GLuint buf, GLenum mode);  typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEIPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha);  typedef void (APIENTRYP PFNGLBLENDFUNCIPROC) (GLuint buf, GLenum src, GLenum dst); @@ -6288,9 +6453,9 @@ typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXDARBPROC) (const GLdouble *m);  #ifndef GL_ARB_multisample  #define GL_ARB_multisample 1  #ifdef GL_GLEXT_PROTOTYPES -GLAPI void APIENTRY glSampleCoverageARB (GLclampf value, GLboolean invert); +GLAPI void APIENTRY glSampleCoverageARB (GLfloat value, GLboolean invert);  #endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRYP PFNGLSAMPLECOVERAGEARBPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEARBPROC) (GLfloat value, GLboolean invert);  #endif  #ifndef GL_ARB_texture_env_add @@ -6909,7 +7074,7 @@ typedef GLboolean (APIENTRYP PFNGLISVERTEXARRAYPROC) (GLuint array);  #ifndef GL_ARB_uniform_buffer_object  #define GL_ARB_uniform_buffer_object 1  #ifdef GL_GLEXT_PROTOTYPES -GLAPI void APIENTRY glGetUniformIndices (GLuint program, GLsizei uniformCount, const GLchar* *uniformNames, GLuint *uniformIndices); +GLAPI void APIENTRY glGetUniformIndices (GLuint program, GLsizei uniformCount, const GLchar* const *uniformNames, GLuint *uniformIndices);  GLAPI void APIENTRY glGetActiveUniformsiv (GLuint program, GLsizei uniformCount, const GLuint *uniformIndices, GLenum pname, GLint *params);  GLAPI void APIENTRY glGetActiveUniformName (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformName);  GLAPI GLuint APIENTRY glGetUniformBlockIndex (GLuint program, const GLchar *uniformBlockName); @@ -6917,7 +7082,7 @@ GLAPI void APIENTRY glGetActiveUniformBlockiv (GLuint program, GLuint uniformBlo  GLAPI void APIENTRY glGetActiveUniformBlockName (GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformBlockName);  GLAPI void APIENTRY glUniformBlockBinding (GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding);  #endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRYP PFNGLGETUNIFORMINDICESPROC) (GLuint program, GLsizei uniformCount, const GLchar* *uniformNames, GLuint *uniformIndices); +typedef void (APIENTRYP PFNGLGETUNIFORMINDICESPROC) (GLuint program, GLsizei uniformCount, const GLchar* const *uniformNames, GLuint *uniformIndices);  typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMSIVPROC) (GLuint program, GLsizei uniformCount, const GLuint *uniformIndices, GLenum pname, GLint *params);  typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMNAMEPROC) (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformName);  typedef GLuint (APIENTRYP PFNGLGETUNIFORMBLOCKINDEXPROC) (GLuint program, const GLchar *uniformBlockName); @@ -6952,12 +7117,12 @@ typedef void (APIENTRYP PFNGLCOPYBUFFERSUBDATAPROC) (GLenum readTarget, GLenum w  GLAPI void APIENTRY glDrawElementsBaseVertex (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLint basevertex);  GLAPI void APIENTRY glDrawRangeElementsBaseVertex (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices, GLint basevertex);  GLAPI void APIENTRY glDrawElementsInstancedBaseVertex (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount, GLint basevertex); -GLAPI void APIENTRY glMultiDrawElementsBaseVertex (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount, const GLint *basevertex); +GLAPI void APIENTRY glMultiDrawElementsBaseVertex (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* const *indices, GLsizei primcount, const GLint *basevertex);  #endif /* GL_GLEXT_PROTOTYPES */  typedef void (APIENTRYP PFNGLDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLint basevertex);  typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices, GLint basevertex);  typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount, GLint basevertex); -typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount, const GLint *basevertex); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* const *indices, GLsizei primcount, const GLint *basevertex);  #endif  #ifndef GL_ARB_fragment_coord_conventions @@ -7031,9 +7196,9 @@ typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEIARBPROC) (GLuint buf, GLenum srcR  #ifndef GL_ARB_sample_shading  #define GL_ARB_sample_shading 1  #ifdef GL_GLEXT_PROTOTYPES -GLAPI void APIENTRY glMinSampleShadingARB (GLclampf value); +GLAPI void APIENTRY glMinSampleShadingARB (GLfloat value);  #endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRYP PFNGLMINSAMPLESHADINGARBPROC) (GLclampf value); +typedef void (APIENTRYP PFNGLMINSAMPLESHADINGARBPROC) (GLfloat value);  #endif  #ifndef GL_ARB_texture_cube_map_array @@ -7360,14 +7525,14 @@ typedef void (APIENTRYP PFNGLGETQUERYINDEXEDIVPROC) (GLenum target, GLuint index  GLAPI void APIENTRY glReleaseShaderCompiler (void);  GLAPI void APIENTRY glShaderBinary (GLsizei count, const GLuint *shaders, GLenum binaryformat, const GLvoid *binary, GLsizei length);  GLAPI void APIENTRY glGetShaderPrecisionFormat (GLenum shadertype, GLenum precisiontype, GLint *range, GLint *precision); -GLAPI void APIENTRY glDepthRangef (GLclampf n, GLclampf f); -GLAPI void APIENTRY glClearDepthf (GLclampf d); +GLAPI void APIENTRY glDepthRangef (GLfloat n, GLfloat f); +GLAPI void APIENTRY glClearDepthf (GLfloat d);  #endif /* GL_GLEXT_PROTOTYPES */  typedef void (APIENTRYP PFNGLRELEASESHADERCOMPILERPROC) (void);  typedef void (APIENTRYP PFNGLSHADERBINARYPROC) (GLsizei count, const GLuint *shaders, GLenum binaryformat, const GLvoid *binary, GLsizei length);  typedef void (APIENTRYP PFNGLGETSHADERPRECISIONFORMATPROC) (GLenum shadertype, GLenum precisiontype, GLint *range, GLint *precision); -typedef void (APIENTRYP PFNGLDEPTHRANGEFPROC) (GLclampf n, GLclampf f); -typedef void (APIENTRYP PFNGLCLEARDEPTHFPROC) (GLclampf d); +typedef void (APIENTRYP PFNGLDEPTHRANGEFPROC) (GLfloat n, GLfloat f); +typedef void (APIENTRYP PFNGLCLEARDEPTHFPROC) (GLfloat d);  #endif  #ifndef GL_ARB_get_program_binary @@ -7387,7 +7552,7 @@ typedef void (APIENTRYP PFNGLPROGRAMPARAMETERIPROC) (GLuint program, GLenum pnam  #ifdef GL_GLEXT_PROTOTYPES  GLAPI void APIENTRY glUseProgramStages (GLuint pipeline, GLbitfield stages, GLuint program);  GLAPI void APIENTRY glActiveShaderProgram (GLuint pipeline, GLuint program); -GLAPI GLuint APIENTRY glCreateShaderProgramv (GLenum type, GLsizei count, const GLchar* *strings); +GLAPI GLuint APIENTRY glCreateShaderProgramv (GLenum type, GLsizei count, const GLchar* const *strings);  GLAPI void APIENTRY glBindProgramPipeline (GLuint pipeline);  GLAPI void APIENTRY glDeleteProgramPipelines (GLsizei n, const GLuint *pipelines);  GLAPI void APIENTRY glGenProgramPipelines (GLsizei n, GLuint *pipelines); @@ -7448,7 +7613,7 @@ GLAPI void APIENTRY glGetProgramPipelineInfoLog (GLuint pipeline, GLsizei bufSiz  #endif /* GL_GLEXT_PROTOTYPES */  typedef void (APIENTRYP PFNGLUSEPROGRAMSTAGESPROC) (GLuint pipeline, GLbitfield stages, GLuint program);  typedef void (APIENTRYP PFNGLACTIVESHADERPROGRAMPROC) (GLuint pipeline, GLuint program); -typedef GLuint (APIENTRYP PFNGLCREATESHADERPROGRAMVPROC) (GLenum type, GLsizei count, const GLchar* *strings); +typedef GLuint (APIENTRYP PFNGLCREATESHADERPROGRAMVPROC) (GLenum type, GLsizei count, const GLchar* const *strings);  typedef void (APIENTRYP PFNGLBINDPROGRAMPIPELINEPROC) (GLuint pipeline);  typedef void (APIENTRYP PFNGLDELETEPROGRAMPIPELINESPROC) (GLsizei n, const GLuint *pipelines);  typedef void (APIENTRYP PFNGLGENPROGRAMPIPELINESPROC) (GLsizei n, GLuint *pipelines); @@ -7543,8 +7708,8 @@ GLAPI void APIENTRY glViewportIndexedfv (GLuint index, const GLfloat *v);  GLAPI void APIENTRY glScissorArrayv (GLuint first, GLsizei count, const GLint *v);  GLAPI void APIENTRY glScissorIndexed (GLuint index, GLint left, GLint bottom, GLsizei width, GLsizei height);  GLAPI void APIENTRY glScissorIndexedv (GLuint index, const GLint *v); -GLAPI void APIENTRY glDepthRangeArrayv (GLuint first, GLsizei count, const GLclampd *v); -GLAPI void APIENTRY glDepthRangeIndexed (GLuint index, GLclampd n, GLclampd f); +GLAPI void APIENTRY glDepthRangeArrayv (GLuint first, GLsizei count, const GLdouble *v); +GLAPI void APIENTRY glDepthRangeIndexed (GLuint index, GLdouble n, GLdouble f);  GLAPI void APIENTRY glGetFloati_v (GLenum target, GLuint index, GLfloat *data);  GLAPI void APIENTRY glGetDoublei_v (GLenum target, GLuint index, GLdouble *data);  #endif /* GL_GLEXT_PROTOTYPES */ @@ -7554,8 +7719,8 @@ typedef void (APIENTRYP PFNGLVIEWPORTINDEXEDFVPROC) (GLuint index, const GLfloat  typedef void (APIENTRYP PFNGLSCISSORARRAYVPROC) (GLuint first, GLsizei count, const GLint *v);  typedef void (APIENTRYP PFNGLSCISSORINDEXEDPROC) (GLuint index, GLint left, GLint bottom, GLsizei width, GLsizei height);  typedef void (APIENTRYP PFNGLSCISSORINDEXEDVPROC) (GLuint index, const GLint *v); -typedef void (APIENTRYP PFNGLDEPTHRANGEARRAYVPROC) (GLuint first, GLsizei count, const GLclampd *v); -typedef void (APIENTRYP PFNGLDEPTHRANGEINDEXEDPROC) (GLuint index, GLclampd n, GLclampd f); +typedef void (APIENTRYP PFNGLDEPTHRANGEARRAYVPROC) (GLuint first, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLDEPTHRANGEINDEXEDPROC) (GLuint index, GLdouble n, GLdouble f);  typedef void (APIENTRYP PFNGLGETFLOATI_VPROC) (GLenum target, GLuint index, GLfloat *data);  typedef void (APIENTRYP PFNGLGETDOUBLEI_VPROC) (GLenum target, GLuint index, GLdouble *data);  #endif @@ -7573,12 +7738,12 @@ typedef GLsync (APIENTRYP PFNGLCREATESYNCFROMCLEVENTARBPROC) (struct _cl_context  #ifdef GL_GLEXT_PROTOTYPES  GLAPI void APIENTRY glDebugMessageControlARB (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled);  GLAPI void APIENTRY glDebugMessageInsertARB (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); -GLAPI void APIENTRY glDebugMessageCallbackARB (GLDEBUGPROCARB callback, GLvoid *userParam); +GLAPI void APIENTRY glDebugMessageCallbackARB (GLDEBUGPROCARB callback, const GLvoid *userParam);  GLAPI GLuint APIENTRY glGetDebugMessageLogARB (GLuint count, GLsizei bufsize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog);  #endif /* GL_GLEXT_PROTOTYPES */  typedef void (APIENTRYP PFNGLDEBUGMESSAGECONTROLARBPROC) (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled);  typedef void (APIENTRYP PFNGLDEBUGMESSAGEINSERTARBPROC) (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); -typedef void (APIENTRYP PFNGLDEBUGMESSAGECALLBACKARBPROC) (GLDEBUGPROCARB callback, GLvoid *userParam); +typedef void (APIENTRYP PFNGLDEBUGMESSAGECALLBACKARBPROC) (GLDEBUGPROCARB callback, const GLvoid *userParam);  typedef GLuint (APIENTRYP PFNGLGETDEBUGMESSAGELOGARBPROC) (GLuint count, GLsizei bufsize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog);  #endif @@ -7725,9 +7890,9 @@ typedef void (APIENTRYP PFNGLTEXTURESTORAGE3DEXTPROC) (GLuint texture, GLenum ta  #ifndef GL_EXT_blend_color  #define GL_EXT_blend_color 1  #ifdef GL_GLEXT_PROTOTYPES -GLAPI void APIENTRY glBlendColorEXT (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +GLAPI void APIENTRY glBlendColorEXT (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);  #endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRYP PFNGLBLENDCOLOREXTPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +typedef void (APIENTRYP PFNGLBLENDCOLOREXTPROC) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);  #endif  #ifndef GL_EXT_polygon_offset @@ -11480,6 +11645,166 @@ typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSINDIRECTAMDPROC) (GLenum mode, GLe  #define GL_EXT_framebuffer_multisample_blit_scaled 1  #endif +#ifndef GL_NV_path_rendering +#define GL_NV_path_rendering 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint APIENTRY glGenPathsNV (GLsizei range); +GLAPI void APIENTRY glDeletePathsNV (GLuint path, GLsizei range); +GLAPI GLboolean APIENTRY glIsPathNV (GLuint path); +GLAPI void APIENTRY glPathCommandsNV (GLuint path, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +GLAPI void APIENTRY glPathCoordsNV (GLuint path, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +GLAPI void APIENTRY glPathSubCommandsNV (GLuint path, GLsizei commandStart, GLsizei commandsToDelete, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +GLAPI void APIENTRY glPathSubCoordsNV (GLuint path, GLsizei coordStart, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +GLAPI void APIENTRY glPathStringNV (GLuint path, GLenum format, GLsizei length, const GLvoid *pathString); +GLAPI void APIENTRY glPathGlyphsNV (GLuint firstPathName, GLenum fontTarget, const GLvoid *fontName, GLbitfield fontStyle, GLsizei numGlyphs, GLenum type, const GLvoid *charcodes, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +GLAPI void APIENTRY glPathGlyphRangeNV (GLuint firstPathName, GLenum fontTarget, const GLvoid *fontName, GLbitfield fontStyle, GLuint firstGlyph, GLsizei numGlyphs, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +GLAPI void APIENTRY glWeightPathsNV (GLuint resultPath, GLsizei numPaths, const GLuint *paths, const GLfloat *weights); +GLAPI void APIENTRY glCopyPathNV (GLuint resultPath, GLuint srcPath); +GLAPI void APIENTRY glInterpolatePathsNV (GLuint resultPath, GLuint pathA, GLuint pathB, GLfloat weight); +GLAPI void APIENTRY glTransformPathNV (GLuint resultPath, GLuint srcPath, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glPathParameterivNV (GLuint path, GLenum pname, const GLint *value); +GLAPI void APIENTRY glPathParameteriNV (GLuint path, GLenum pname, GLint value); +GLAPI void APIENTRY glPathParameterfvNV (GLuint path, GLenum pname, const GLfloat *value); +GLAPI void APIENTRY glPathParameterfNV (GLuint path, GLenum pname, GLfloat value); +GLAPI void APIENTRY glPathDashArrayNV (GLuint path, GLsizei dashCount, const GLfloat *dashArray); +GLAPI void APIENTRY glPathStencilFuncNV (GLenum func, GLint ref, GLuint mask); +GLAPI void APIENTRY glPathStencilDepthOffsetNV (GLfloat factor, GLfloat units); +GLAPI void APIENTRY glStencilFillPathNV (GLuint path, GLenum fillMode, GLuint mask); +GLAPI void APIENTRY glStencilStrokePathNV (GLuint path, GLint reference, GLuint mask); +GLAPI void APIENTRY glStencilFillPathInstancedNV (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLenum fillMode, GLuint mask, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glStencilStrokePathInstancedNV (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLint reference, GLuint mask, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glPathCoverDepthFuncNV (GLenum func); +GLAPI void APIENTRY glPathColorGenNV (GLenum color, GLenum genMode, GLenum colorFormat, const GLfloat *coeffs); +GLAPI void APIENTRY glPathTexGenNV (GLenum texCoordSet, GLenum genMode, GLint components, const GLfloat *coeffs); +GLAPI void APIENTRY glPathFogGenNV (GLenum genMode); +GLAPI void APIENTRY glCoverFillPathNV (GLuint path, GLenum coverMode); +GLAPI void APIENTRY glCoverStrokePathNV (GLuint path, GLenum coverMode); +GLAPI void APIENTRY glCoverFillPathInstancedNV (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glCoverStrokePathInstancedNV (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glGetPathParameterivNV (GLuint path, GLenum pname, GLint *value); +GLAPI void APIENTRY glGetPathParameterfvNV (GLuint path, GLenum pname, GLfloat *value); +GLAPI void APIENTRY glGetPathCommandsNV (GLuint path, GLubyte *commands); +GLAPI void APIENTRY glGetPathCoordsNV (GLuint path, GLfloat *coords); +GLAPI void APIENTRY glGetPathDashArrayNV (GLuint path, GLfloat *dashArray); +GLAPI void APIENTRY glGetPathMetricsNV (GLbitfield metricQueryMask, GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLsizei stride, GLfloat *metrics); +GLAPI void APIENTRY glGetPathMetricRangeNV (GLbitfield metricQueryMask, GLuint firstPathName, GLsizei numPaths, GLsizei stride, GLfloat *metrics); +GLAPI void APIENTRY glGetPathSpacingNV (GLenum pathListMode, GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLfloat advanceScale, GLfloat kerningScale, GLenum transformType, GLfloat *returnedSpacing); +GLAPI void APIENTRY glGetPathColorGenivNV (GLenum color, GLenum pname, GLint *value); +GLAPI void APIENTRY glGetPathColorGenfvNV (GLenum color, GLenum pname, GLfloat *value); +GLAPI void APIENTRY glGetPathTexGenivNV (GLenum texCoordSet, GLenum pname, GLint *value); +GLAPI void APIENTRY glGetPathTexGenfvNV (GLenum texCoordSet, GLenum pname, GLfloat *value); +GLAPI GLboolean APIENTRY glIsPointInFillPathNV (GLuint path, GLuint mask, GLfloat x, GLfloat y); +GLAPI GLboolean APIENTRY glIsPointInStrokePathNV (GLuint path, GLfloat x, GLfloat y); +GLAPI GLfloat APIENTRY glGetPathLengthNV (GLuint path, GLsizei startSegment, GLsizei numSegments); +GLAPI GLboolean APIENTRY glPointAlongPathNV (GLuint path, GLsizei startSegment, GLsizei numSegments, GLfloat distance, GLfloat *x, GLfloat *y, GLfloat *tangentX, GLfloat *tangentY); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLuint (APIENTRYP PFNGLGENPATHSNVPROC) (GLsizei range); +typedef void (APIENTRYP PFNGLDELETEPATHSNVPROC) (GLuint path, GLsizei range); +typedef GLboolean (APIENTRYP PFNGLISPATHNVPROC) (GLuint path); +typedef void (APIENTRYP PFNGLPATHCOMMANDSNVPROC) (GLuint path, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +typedef void (APIENTRYP PFNGLPATHCOORDSNVPROC) (GLuint path, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +typedef void (APIENTRYP PFNGLPATHSUBCOMMANDSNVPROC) (GLuint path, GLsizei commandStart, GLsizei commandsToDelete, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +typedef void (APIENTRYP PFNGLPATHSUBCOORDSNVPROC) (GLuint path, GLsizei coordStart, GLsizei numCoords, GLenum coordType, const GLvoid *coords); +typedef void (APIENTRYP PFNGLPATHSTRINGNVPROC) (GLuint path, GLenum format, GLsizei length, const GLvoid *pathString); +typedef void (APIENTRYP PFNGLPATHGLYPHSNVPROC) (GLuint firstPathName, GLenum fontTarget, const GLvoid *fontName, GLbitfield fontStyle, GLsizei numGlyphs, GLenum type, const GLvoid *charcodes, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +typedef void (APIENTRYP PFNGLPATHGLYPHRANGENVPROC) (GLuint firstPathName, GLenum fontTarget, const GLvoid *fontName, GLbitfield fontStyle, GLuint firstGlyph, GLsizei numGlyphs, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +typedef void (APIENTRYP PFNGLWEIGHTPATHSNVPROC) (GLuint resultPath, GLsizei numPaths, const GLuint *paths, const GLfloat *weights); +typedef void (APIENTRYP PFNGLCOPYPATHNVPROC) (GLuint resultPath, GLuint srcPath); +typedef void (APIENTRYP PFNGLINTERPOLATEPATHSNVPROC) (GLuint resultPath, GLuint pathA, GLuint pathB, GLfloat weight); +typedef void (APIENTRYP PFNGLTRANSFORMPATHNVPROC) (GLuint resultPath, GLuint srcPath, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLPATHPARAMETERIVNVPROC) (GLuint path, GLenum pname, const GLint *value); +typedef void (APIENTRYP PFNGLPATHPARAMETERINVPROC) (GLuint path, GLenum pname, GLint value); +typedef void (APIENTRYP PFNGLPATHPARAMETERFVNVPROC) (GLuint path, GLenum pname, const GLfloat *value); +typedef void (APIENTRYP PFNGLPATHPARAMETERFNVPROC) (GLuint path, GLenum pname, GLfloat value); +typedef void (APIENTRYP PFNGLPATHDASHARRAYNVPROC) (GLuint path, GLsizei dashCount, const GLfloat *dashArray); +typedef void (APIENTRYP PFNGLPATHSTENCILFUNCNVPROC) (GLenum func, GLint ref, GLuint mask); +typedef void (APIENTRYP PFNGLPATHSTENCILDEPTHOFFSETNVPROC) (GLfloat factor, GLfloat units); +typedef void (APIENTRYP PFNGLSTENCILFILLPATHNVPROC) (GLuint path, GLenum fillMode, GLuint mask); +typedef void (APIENTRYP PFNGLSTENCILSTROKEPATHNVPROC) (GLuint path, GLint reference, GLuint mask); +typedef void (APIENTRYP PFNGLSTENCILFILLPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLenum fillMode, GLuint mask, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLSTENCILSTROKEPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLint reference, GLuint mask, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLPATHCOVERDEPTHFUNCNVPROC) (GLenum func); +typedef void (APIENTRYP PFNGLPATHCOLORGENNVPROC) (GLenum color, GLenum genMode, GLenum colorFormat, const GLfloat *coeffs); +typedef void (APIENTRYP PFNGLPATHTEXGENNVPROC) (GLenum texCoordSet, GLenum genMode, GLint components, const GLfloat *coeffs); +typedef void (APIENTRYP PFNGLPATHFOGGENNVPROC) (GLenum genMode); +typedef void (APIENTRYP PFNGLCOVERFILLPATHNVPROC) (GLuint path, GLenum coverMode); +typedef void (APIENTRYP PFNGLCOVERSTROKEPATHNVPROC) (GLuint path, GLenum coverMode); +typedef void (APIENTRYP PFNGLCOVERFILLPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLCOVERSTROKEPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLGETPATHPARAMETERIVNVPROC) (GLuint path, GLenum pname, GLint *value); +typedef void (APIENTRYP PFNGLGETPATHPARAMETERFVNVPROC) (GLuint path, GLenum pname, GLfloat *value); +typedef void (APIENTRYP PFNGLGETPATHCOMMANDSNVPROC) (GLuint path, GLubyte *commands); +typedef void (APIENTRYP PFNGLGETPATHCOORDSNVPROC) (GLuint path, GLfloat *coords); +typedef void (APIENTRYP PFNGLGETPATHDASHARRAYNVPROC) (GLuint path, GLfloat *dashArray); +typedef void (APIENTRYP PFNGLGETPATHMETRICSNVPROC) (GLbitfield metricQueryMask, GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLsizei stride, GLfloat *metrics); +typedef void (APIENTRYP PFNGLGETPATHMETRICRANGENVPROC) (GLbitfield metricQueryMask, GLuint firstPathName, GLsizei numPaths, GLsizei stride, GLfloat *metrics); +typedef void (APIENTRYP PFNGLGETPATHSPACINGNVPROC) (GLenum pathListMode, GLsizei numPaths, GLenum pathNameType, const GLvoid *paths, GLuint pathBase, GLfloat advanceScale, GLfloat kerningScale, GLenum transformType, GLfloat *returnedSpacing); +typedef void (APIENTRYP PFNGLGETPATHCOLORGENIVNVPROC) (GLenum color, GLenum pname, GLint *value); +typedef void (APIENTRYP PFNGLGETPATHCOLORGENFVNVPROC) (GLenum color, GLenum pname, GLfloat *value); +typedef void (APIENTRYP PFNGLGETPATHTEXGENIVNVPROC) (GLenum texCoordSet, GLenum pname, GLint *value); +typedef void (APIENTRYP PFNGLGETPATHTEXGENFVNVPROC) (GLenum texCoordSet, GLenum pname, GLfloat *value); +typedef GLboolean (APIENTRYP PFNGLISPOINTINFILLPATHNVPROC) (GLuint path, GLuint mask, GLfloat x, GLfloat y); +typedef GLboolean (APIENTRYP PFNGLISPOINTINSTROKEPATHNVPROC) (GLuint path, GLfloat x, GLfloat y); +typedef GLfloat (APIENTRYP PFNGLGETPATHLENGTHNVPROC) (GLuint path, GLsizei startSegment, GLsizei numSegments); +typedef GLboolean (APIENTRYP PFNGLPOINTALONGPATHNVPROC) (GLuint path, GLsizei startSegment, GLsizei numSegments, GLfloat distance, GLfloat *x, GLfloat *y, GLfloat *tangentX, GLfloat *tangentY); +#endif + +#ifndef GL_AMD_pinned_memory +#define GL_AMD_pinned_memory 1 +#endif + +#ifndef GL_AMD_stencil_operation_extended +#define GL_AMD_stencil_operation_extended 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glStencilOpValueAMD (GLenum face, GLuint value); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (APIENTRYP PFNGLSTENCILOPVALUEAMDPROC) (GLenum face, GLuint value); +#endif + +#ifndef GL_AMD_vertex_shader_viewport_index +#define GL_AMD_vertex_shader_viewport_index 1 +#endif + +#ifndef GL_AMD_vertex_shader_layer +#define GL_AMD_vertex_shader_layer 1 +#endif + +#ifndef GL_NV_bindless_texture +#define GL_NV_bindless_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint64 APIENTRY glGetTextureHandleNV (GLuint texture); +GLAPI GLuint64 APIENTRY glGetTextureSamplerHandleNV (GLuint texture, GLuint sampler); +GLAPI void APIENTRY glMakeTextureHandleResidentNV (GLuint64 handle); +GLAPI void APIENTRY glMakeTextureHandleNonResidentNV (GLuint64 handle); +GLAPI GLuint64 APIENTRY glGetImageHandleNV (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); +GLAPI void APIENTRY glMakeImageHandleResidentNV (GLuint64 handle, GLenum access); +GLAPI void APIENTRY glMakeImageHandleNonResidentNV (GLuint64 handle); +GLAPI void APIENTRY glUniformHandleui64NV (GLint location, GLuint64 value); +GLAPI void APIENTRY glUniformHandleui64vNV (GLint location, GLsizei count, const GLuint64 *value); +GLAPI void APIENTRY glProgramUniformHandleui64NV (GLuint program, GLint location, GLuint64 value); +GLAPI void APIENTRY glProgramUniformHandleui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64 *values); +GLAPI GLboolean APIENTRY glIsTextureHandleResidentNV (GLuint64 handle); +GLAPI GLboolean APIENTRY glIsImageHandleResidentNV (GLuint64 handle); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef GLuint64 (APIENTRYP PFNGLGETTEXTUREHANDLENVPROC) (GLuint texture); +typedef GLuint64 (APIENTRYP PFNGLGETTEXTURESAMPLERHANDLENVPROC) (GLuint texture, GLuint sampler); +typedef void (APIENTRYP PFNGLMAKETEXTUREHANDLERESIDENTNVPROC) (GLuint64 handle); +typedef void (APIENTRYP PFNGLMAKETEXTUREHANDLENONRESIDENTNVPROC) (GLuint64 handle); +typedef GLuint64 (APIENTRYP PFNGLGETIMAGEHANDLENVPROC) (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); +typedef void (APIENTRYP PFNGLMAKEIMAGEHANDLERESIDENTNVPROC) (GLuint64 handle, GLenum access); +typedef void (APIENTRYP PFNGLMAKEIMAGEHANDLENONRESIDENTNVPROC) (GLuint64 handle); +typedef void (APIENTRYP PFNGLUNIFORMHANDLEUI64NVPROC) (GLint location, GLuint64 value); +typedef void (APIENTRYP PFNGLUNIFORMHANDLEUI64VNVPROC) (GLint location, GLsizei count, const GLuint64 *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMHANDLEUI64NVPROC) (GLuint program, GLint location, GLuint64 value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMHANDLEUI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64 *values); +typedef GLboolean (APIENTRYP PFNGLISTEXTUREHANDLERESIDENTNVPROC) (GLuint64 handle); +typedef GLboolean (APIENTRYP PFNGLISIMAGEHANDLERESIDENTNVPROC) (GLuint64 handle); +#endif + +#ifndef GL_NV_shader_atomic_float +#define GL_NV_shader_atomic_float 1 +#endif +  #ifdef __cplusplus  } diff --git a/mesalib/include/GL/glxext.h b/mesalib/include/GL/glxext.h index 3c47dc363..e640ff7e3 100644 --- a/mesalib/include/GL/glxext.h +++ b/mesalib/include/GL/glxext.h @@ -6,7 +6,7 @@ extern "C" {  #endif  /* -** Copyright (c) 2007-2010 The Khronos Group Inc. +** Copyright (c) 2007-2012 The Khronos Group Inc.  **   ** Permission is hereby granted, free of charge, to any person obtaining a  ** copy of this software and/or associated documentation files (the @@ -48,9 +48,9 @@ extern "C" {  /*************************************************************/  /* Header file version number, required by OpenGL ABI for Linux */ -/* glxext.h last updated 2010/08/06 */ +/* glxext.h last updated 2012/02/29 */  /* Current version at http://www.opengl.org/registry/ */ -#define GLX_GLXEXT_VERSION 32 +#define GLX_GLXEXT_VERSION 33  #ifndef GLX_VERSION_1_3  #define GLX_WINDOW_BIT                     0x00000001 @@ -440,6 +440,10 @@ extern "C" {  #define GLX_CONTEXT_ES2_PROFILE_BIT_EXT    0x00000004  #endif +#ifndef GLX_EXT_swap_control_tear +#define GLX_LATE_SWAPS_TEAR_EXT            0x20F3 +#endif +  /*************************************************************/ @@ -964,9 +968,9 @@ typedef void ( * PFNGLXRELEASEVIDEOCAPTUREDEVICENVPROC) (Display *dpy, GLXVideoC  #ifndef GLX_EXT_swap_control  #define GLX_EXT_swap_control 1  #ifdef GLX_GLXEXT_PROTOTYPES -extern int glXSwapIntervalEXT (Display *dpy, GLXDrawable drawable, int interval); +extern void glXSwapIntervalEXT (Display *dpy, GLXDrawable drawable, int interval);  #endif /* GLX_GLXEXT_PROTOTYPES */ -typedef int ( * PFNGLXSWAPINTERVALEXTPROC) (Display *dpy, GLXDrawable drawable, int interval); +typedef void ( * PFNGLXSWAPINTERVALEXTPROC) (Display *dpy, GLXDrawable drawable, int interval);  #endif  #ifndef GLX_NV_copy_image @@ -985,6 +989,10 @@ typedef void ( * PFNGLXCOPYIMAGESUBDATANVPROC) (Display *dpy, GLXContext srcCtx,  #define GLX_NV_multisample_coverage 1  #endif +#ifndef GLX_EXT_swap_control_tear +#define GLX_EXT_swap_control_tear 1 +#endif +  #ifdef __cplusplus  } diff --git a/mesalib/src/gallium/auxiliary/util/u_blitter.c b/mesalib/src/gallium/auxiliary/util/u_blitter.c index d0b9187d1..4b4734a21 100644 --- a/mesalib/src/gallium/auxiliary/util/u_blitter.c +++ b/mesalib/src/gallium/auxiliary/util/u_blitter.c @@ -815,6 +815,8 @@ static void util_blitter_clear_custom(struct blitter_context *blitter,     pipe->bind_vs_state(pipe, ctx->vs);     if (ctx->has_geometry_shader)        pipe->bind_gs_state(pipe, NULL); +   if (ctx->has_stream_out) +      pipe->set_stream_output_targets(pipe, 0, NULL, 0);     blitter_set_dst_dimensions(ctx, width, height);     blitter->draw_rectangle(blitter, 0, 0, width, height, depth, @@ -1013,6 +1015,8 @@ void util_blitter_copy_texture_view(struct blitter_context *blitter,     pipe->bind_vs_state(pipe, ctx->vs);     if (ctx->has_geometry_shader)        pipe->bind_gs_state(pipe, NULL); +   if (ctx->has_stream_out) +      pipe->set_stream_output_targets(pipe, 0, NULL, 0);     pipe->bind_fragment_sampler_states(pipe, 1, &ctx->sampler_state);     pipe->bind_vertex_elements_state(pipe, ctx->velem_state);     pipe->set_fragment_sampler_views(pipe, 1, &src); @@ -1098,6 +1102,8 @@ void util_blitter_clear_render_target(struct blitter_context *blitter,     pipe->bind_vs_state(pipe, ctx->vs);     if (ctx->has_geometry_shader)        pipe->bind_gs_state(pipe, NULL); +   if (ctx->has_stream_out) +      pipe->set_stream_output_targets(pipe, 0, NULL, 0);     pipe->bind_vertex_elements_state(pipe, ctx->velem_state);     /* set a framebuffer state */ @@ -1166,6 +1172,8 @@ void util_blitter_clear_depth_stencil(struct blitter_context *blitter,     pipe->bind_vs_state(pipe, ctx->vs);     if (ctx->has_geometry_shader)        pipe->bind_gs_state(pipe, NULL); +   if (ctx->has_stream_out) +      pipe->set_stream_output_targets(pipe, 0, NULL, 0);     pipe->bind_vertex_elements_state(pipe, ctx->velem_state);     /* set a framebuffer state */ @@ -1215,6 +1223,8 @@ void util_blitter_custom_depth_stencil(struct blitter_context *blitter,     pipe->bind_vs_state(pipe, ctx->vs);     if (ctx->has_geometry_shader)        pipe->bind_gs_state(pipe, NULL); +   if (ctx->has_stream_out) +      pipe->set_stream_output_targets(pipe, 0, NULL, 0);     pipe->bind_vertex_elements_state(pipe, ctx->velem_state);     /* set a framebuffer state */ diff --git a/mesalib/src/gallium/auxiliary/util/u_debug.c b/mesalib/src/gallium/auxiliary/util/u_debug.c index 0a350cae7..bf98f222e 100644 --- a/mesalib/src/gallium/auxiliary/util/u_debug.c +++ b/mesalib/src/gallium/auxiliary/util/u_debug.c @@ -204,7 +204,7 @@ static boolean str_has_option(const char *str, const char *name)         * we compare 'start' up to 'str-1' with 'name'. */        while (1) { -         if (!*str || !isalnum(*str)) { +         if (!*str || !(isalnum(*str) || *str == '_')) {              if (str-start == name_len &&                  !memcmp(start, name, name_len)) {                 return TRUE; diff --git a/mesalib/src/glsl/SConscript b/mesalib/src/glsl/SConscript index f8e872368..2fc57c6dd 100644 --- a/mesalib/src/glsl/SConscript +++ b/mesalib/src/glsl/SConscript @@ -14,8 +14,8 @@ env.Prepend(CPPPATH = [      '#src/glsl/glcpp',  ]) -# Make glcpp/glcpp-parse.h and glsl_parser.h reacheable from the include path -env.Append(CPPPATH = [Dir('.').abspath]) +# Make glcpp-parse.h and glsl_parser.h reachable from the include path. +env.Append(CPPPATH = [Dir('.').abspath, Dir('glcpp').abspath])  env.Append(YACCFLAGS = '-d') diff --git a/mesalib/src/glsl/glcpp/glcpp-lex.l b/mesalib/src/glsl/glcpp/glcpp-lex.l index b34f2c0e9..7ab58cb28 100644 --- a/mesalib/src/glsl/glcpp/glcpp-lex.l +++ b/mesalib/src/glsl/glcpp/glcpp-lex.l @@ -40,12 +40,18 @@ void glcpp_set_column (int  column_no , yyscan_t yyscanner);  #define YY_NO_INPUT -#define YY_USER_ACTION                                          \ -   do {                                                         \ -      yylloc->first_column = yycolumn + 1;                      \ -      yylloc->first_line = yylineno;                            \ -      yycolumn += yyleng;                                       \ -   } while(0); +#define YY_USER_ACTION							\ +	do {								\ +		if (parser->has_new_line_number)			\ +			yylineno = parser->new_line_number;		\ +		if (parser->has_new_source_number)			\ +			yylloc->source = parser->new_source_number;	\ +		yylloc->first_column = yycolumn + 1;			\ +		yylloc->first_line = yylineno;				\ +		yycolumn += yyleng;					\ +		parser->has_new_line_number = 0;			\ +		parser->has_new_source_number = 0;			\ + } while(0);  #define YY_USER_INIT			\  	do {				\ @@ -129,35 +135,8 @@ HEXADECIMAL_INTEGER	0[xX][0-9a-fA-F]+[uU]?  	return OTHER;  } -{HASH}line{HSPACE}+{DIGITS}{HSPACE}+{DIGITS}{HSPACE}*$ { -	/* Eat characters until the first digit is -	 * encountered -	 */ -	char *ptr = yytext; -	while (!isdigit(*ptr)) -		ptr++; - -	/* Subtract one from the line number because -	 * yylineno is zero-based instead of -	 * one-based. -	 */ -	yylineno = strtol(ptr, &ptr, 0) - 1; -	yylloc->source = strtol(ptr, NULL, 0); -} - -{HASH}line{HSPACE}+{DIGITS}{HSPACE}*$ { -	/* Eat characters until the first digit is -	 * encountered -	 */ -	char *ptr = yytext; -	while (!isdigit(*ptr)) -		ptr++; - -	/* Subtract one from the line number because -	 * yylineno is zero-based instead of -	 * one-based. -	 */ -	yylineno = strtol(ptr, &ptr, 0) - 1; +{HASH}line { +	return HASH_LINE;  }  <SKIP,INITIAL>{ diff --git a/mesalib/src/glsl/glcpp/glcpp-parse.y b/mesalib/src/glsl/glcpp/glcpp-parse.y index 9e8f9b2d6..cc4af1689 100644 --- a/mesalib/src/glsl/glcpp/glcpp-parse.y +++ b/mesalib/src/glsl/glcpp/glcpp-parse.y @@ -105,9 +105,15 @@ _parser_active_list_pop (glcpp_parser_t *parser);  static int  _parser_active_list_contains (glcpp_parser_t *parser, const char *identifier); +/* Expand list, and begin lexing from the result (after first + * prefixing a token of type 'head_token_type'). + */  static void -_glcpp_parser_expand_if (glcpp_parser_t *parser, int type, token_list_t *list); +_glcpp_parser_expand_and_lex_from (glcpp_parser_t *parser, +				   int head_token_type, +				   token_list_t *list); +/* Perform macro expansion in-place on the given list. */  static void  _glcpp_parser_expand_token_list (glcpp_parser_t *parser,  				 token_list_t *list); @@ -156,7 +162,7 @@ add_builtin_define(glcpp_parser_t *parser, const char *name, int value);  %lex-param {glcpp_parser_t *parser}  %expect 0 -%token COMMA_FINAL DEFINED ELIF_EXPANDED HASH HASH_DEFINE_FUNC HASH_DEFINE_OBJ HASH_ELIF HASH_ELSE HASH_ENDIF HASH_IF HASH_IFDEF HASH_IFNDEF HASH_UNDEF HASH_VERSION IDENTIFIER IF_EXPANDED INTEGER INTEGER_STRING NEWLINE OTHER PLACEHOLDER SPACE +%token COMMA_FINAL DEFINED ELIF_EXPANDED HASH HASH_DEFINE_FUNC HASH_DEFINE_OBJ HASH_ELIF HASH_ELSE HASH_ENDIF HASH_IF HASH_IFDEF HASH_IFNDEF HASH_LINE HASH_UNDEF HASH_VERSION IDENTIFIER IF_EXPANDED INTEGER INTEGER_STRING LINE_EXPANDED NEWLINE OTHER PLACEHOLDER SPACE  %token PASTE  %type <ival> expression INTEGER operator SPACE integer_constant  %type <str> IDENTIFIER INTEGER_STRING OTHER @@ -202,6 +208,24 @@ expanded_line:  |	ELIF_EXPANDED expression NEWLINE {  		_glcpp_parser_skip_stack_change_if (parser, & @1, "elif", $2);  	} +|	LINE_EXPANDED integer_constant NEWLINE { +		parser->has_new_line_number = 1; +		parser->new_line_number = $2; +		ralloc_asprintf_rewrite_tail (&parser->output, +					      &parser->output_length, +					      "#line %" PRIiMAX, +					      $2); +	} +|	LINE_EXPANDED integer_constant integer_constant NEWLINE { +		parser->has_new_line_number = 1; +		parser->new_line_number = $2; +		parser->has_new_source_number = 1; +		parser->new_source_number = $3; +		ralloc_asprintf_rewrite_tail (&parser->output, +					      &parser->output_length, +					      "#line %" PRIiMAX " %" PRIiMAX, +					      $2, $3); +	}  ;  control_line: @@ -222,6 +246,14 @@ control_line:  		}  		ralloc_free ($2);  	} +|	HASH_LINE pp_tokens NEWLINE { +		if (parser->skip_stack == NULL || +		    parser->skip_stack->type == SKIP_NO_SKIP) +		{ +			_glcpp_parser_expand_and_lex_from (parser, +							   LINE_EXPANDED, $2); +		} +	}  |	HASH_IF conditional_tokens NEWLINE {  		/* Be careful to only evaluate the 'if' expression if  		 * we are not skipping. When we are skipping, we @@ -233,7 +265,8 @@ control_line:  		if (parser->skip_stack == NULL ||  		    parser->skip_stack->type == SKIP_NO_SKIP)  		{ -			_glcpp_parser_expand_if (parser, IF_EXPANDED, $2); +			_glcpp_parser_expand_and_lex_from (parser, +							   IF_EXPANDED, $2);  		}	  		else  		{ @@ -272,7 +305,8 @@ control_line:  		if (parser->skip_stack &&  		    parser->skip_stack->type == SKIP_TO_ELSE)  		{ -			_glcpp_parser_expand_if (parser, ELIF_EXPANDED, $2); +			_glcpp_parser_expand_and_lex_from (parser, +							   ELIF_EXPANDED, $2);  		}  		else  		{ @@ -341,6 +375,9 @@ integer_constant:  expression:  	integer_constant +|	IDENTIFIER { +		$$ = 0; +	}  |	expression OR expression {  		$$ = $1 || $3;  	} @@ -1109,6 +1146,11 @@ glcpp_parser_create (const struct gl_extensions *extensions, int api)  	parser->info_log_length = 0;  	parser->error = 0; +	parser->has_new_line_number = 0; +	parser->new_line_number = 1; +	parser->has_new_source_number = 0; +	parser->new_source_number = 0; +  	/* Add pre-defined macros. */  	add_builtin_define(parser, "GL_ARB_draw_buffers", 1);  	add_builtin_define(parser, "GL_ARB_texture_rectangle", 1); @@ -1269,14 +1311,21 @@ _token_list_create_with_one_space (void *ctx)  	return list;  } +/* Perform macro expansion on 'list', placing the resulting tokens + * into a new list which is initialized with a first token of type + * 'head_token_type'. Then begin lexing from the resulting list, + * (return to the current lexing source when this list is exhausted). + */  static void -_glcpp_parser_expand_if (glcpp_parser_t *parser, int type, token_list_t *list) +_glcpp_parser_expand_and_lex_from (glcpp_parser_t *parser, +				   int head_token_type, +				   token_list_t *list)  {  	token_list_t *expanded;  	token_t *token;  	expanded = _token_list_create (parser); -	token = _token_create_ival (parser, type, type); +	token = _token_create_ival (parser, head_token_type, head_token_type);  	_token_list_append (expanded, token);  	_glcpp_parser_expand_token_list (parser, list);  	_token_list_append_list (expanded, list); diff --git a/mesalib/src/glsl/glcpp/glcpp.h b/mesalib/src/glsl/glcpp/glcpp.h index 2d7cad2e6..a13ade69e 100644 --- a/mesalib/src/glsl/glcpp/glcpp.h +++ b/mesalib/src/glsl/glcpp/glcpp.h @@ -25,6 +25,7 @@  #define GLCPP_H  #include <stdint.h> +#include <stdbool.h>  #include "../ralloc.h" @@ -177,6 +178,10 @@ struct glcpp_parser {  	size_t output_length;  	size_t info_log_length;  	int error; +	bool has_new_line_number; +	int new_line_number; +	bool has_new_source_number; +	int new_source_number;  };  struct gl_extensions; diff --git a/mesalib/src/glsl/glcpp/pp.c b/mesalib/src/glsl/glcpp/pp.c index 3640896a2..9170d14a3 100644 --- a/mesalib/src/glsl/glcpp/pp.c +++ b/mesalib/src/glsl/glcpp/pp.c @@ -33,15 +33,20 @@ glcpp_error (YYLTYPE *locp, glcpp_parser_t *parser, const char *fmt, ...)  	va_list ap;  	parser->error = 1; -	ralloc_asprintf_append(&parser->info_log, "%u:%u(%u): " -						  "preprocessor error: ", -						  locp->source, -						  locp->first_line, -						  locp->first_column); +	ralloc_asprintf_rewrite_tail(&parser->info_log, +				     &parser->info_log_length, +				     "%u:%u(%u): " +				     "preprocessor error: ", +				     locp->source, +				     locp->first_line, +				     locp->first_column);  	va_start(ap, fmt); -	ralloc_vasprintf_append(&parser->info_log, fmt, ap); +	ralloc_vasprintf_rewrite_tail(&parser->info_log, +				      &parser->info_log_length, +				      fmt, ap);  	va_end(ap); -	ralloc_strcat(&parser->info_log, "\n"); +	ralloc_asprintf_rewrite_tail(&parser->info_log, +				     &parser->info_log_length, "\n");  }  void @@ -49,15 +54,20 @@ glcpp_warning (YYLTYPE *locp, glcpp_parser_t *parser, const char *fmt, ...)  {  	va_list ap; -	ralloc_asprintf_append(&parser->info_log, "%u:%u(%u): " -						  "preprocessor warning: ", -						  locp->source, -						  locp->first_line, -						  locp->first_column); +	ralloc_asprintf_rewrite_tail(&parser->info_log, +				     &parser->info_log_length, +				     "%u:%u(%u): " +				     "preprocessor warning: ", +				     locp->source, +				     locp->first_line, +				     locp->first_column);  	va_start(ap, fmt); -	ralloc_vasprintf_append(&parser->info_log, fmt, ap); +	ralloc_vasprintf_rewrite_tail(&parser->info_log, +				      &parser->info_log_length, +				      fmt, ap);  	va_end(ap); -	ralloc_strcat(&parser->info_log, "\n"); +	ralloc_asprintf_rewrite_tail(&parser->info_log, +				     &parser->info_log_length, "\n");  }  /* Searches backwards for '^ *#' from a given starting point. */ diff --git a/mesalib/src/glsl/ir.h b/mesalib/src/glsl/ir.h index 014f3630d..505d2e74b 100644 --- a/mesalib/src/glsl/ir.h +++ b/mesalib/src/glsl/ir.h @@ -353,7 +353,7 @@ public:     const struct glsl_type *type;     /** -    * Delcared name of the variable +    * Declared name of the variable      */     const char *name; diff --git a/mesalib/src/glsl/ir_set_program_inouts.cpp b/mesalib/src/glsl/ir_set_program_inouts.cpp index 8f3edb969..a7415c7e3 100644 --- a/mesalib/src/glsl/ir_set_program_inouts.cpp +++ b/mesalib/src/glsl/ir_set_program_inouts.cpp @@ -26,7 +26,8 @@   *   * Sets the InputsRead and OutputsWritten of Mesa programs.   * - * Additionally, for fragment shaders, sets the InterpQualifier array. + * Additionally, for fragment shaders, sets the InterpQualifier array and + * IsCentroid bitfield.   *   * Mesa programs (gl_program, not gl_shader_program) have a set of   * flags indicating which varyings are read and written.  Computing @@ -88,6 +89,8 @@ mark(struct gl_program *prog, ir_variable *var, int offset, int len,              gl_fragment_program *fprog = (gl_fragment_program *) prog;              fprog->InterpQualifier[var->location + var->index + offset + i] =                 (glsl_interp_qualifier) var->interpolation; +            if (var->centroid) +               fprog->IsCentroid |= bitfield;           }        } else if (var->mode == ir_var_system_value) {           prog->SystemValuesRead |= bitfield; @@ -178,6 +181,7 @@ do_set_program_inouts(exec_list *instructions, struct gl_program *prog,     if (is_fragment_shader) {        memset(((gl_fragment_program *) prog)->InterpQualifier, 0,               sizeof(((gl_fragment_program *) prog)->InterpQualifier)); +      ((gl_fragment_program *) prog)->IsCentroid = 0;     }     visit_list_elements(&v, instructions);  } diff --git a/mesalib/src/glsl/linker.cpp b/mesalib/src/glsl/linker.cpp index bdab499f0..310944752 100644 --- a/mesalib/src/glsl/linker.cpp +++ b/mesalib/src/glsl/linker.cpp @@ -1859,6 +1859,32 @@ assign_varying_location(ir_variable *input_var, ir_variable *output_var,  /** + * Is the given variable a varying variable to be counted against the + * limit in ctx->Const.MaxVarying? + * This includes variables such as texcoords, colors and generic + * varyings, but excludes variables such as gl_FrontFacing and gl_FragCoord. + */ +static bool +is_varying_var(GLenum shaderType, const ir_variable *var) +{ +   /* Only fragment shaders will take a varying variable as an input */ +   if (shaderType == GL_FRAGMENT_SHADER && +       var->mode == ir_var_in && +       var->explicit_location) { +      switch (var->location) { +      case FRAG_ATTRIB_WPOS: +      case FRAG_ATTRIB_FACE: +      case FRAG_ATTRIB_PNTC: +         return false; +      default: +         return true; +      } +   } +   return false; +} + + +/**   * Assign locations for all variables that are produced in one pipeline stage   * (the "producer") and consumed in the next stage (the "consumer").   * @@ -1966,7 +1992,7 @@ assign_varying_locations(struct gl_context *ctx,               * value is written by the previous stage.               */              var->mode = ir_var_auto; -         } else { +         } else if (is_varying_var(consumer->Type, var)) {              /* The packing rules are used for vertex shader inputs are also               * used for fragment shader inputs.               */ diff --git a/mesalib/src/mapi/glapi/gen/ARB_debug_output.xml b/mesalib/src/mapi/glapi/gen/ARB_debug_output.xml index f2877a4f7..11f268dc6 100644 --- a/mesalib/src/mapi/glapi/gen/ARB_debug_output.xml +++ b/mesalib/src/mapi/glapi/gen/ARB_debug_output.xml @@ -72,7 +72,7 @@      <function name="DebugMessageCallbackARB" offset="assign">          <param name="callback" type="GLDEBUGPROCARB"/> -        <param name="userParam" type="GLvoid *"/> +        <param name="userParam" type="const GLvoid *"/>      </function>      <function name="GetDebugMessageLogARB" offset="assign"> diff --git a/mesalib/src/mapi/glapi/gen/ARB_draw_elements_base_vertex.xml b/mesalib/src/mapi/glapi/gen/ARB_draw_elements_base_vertex.xml index a697ea509..851f1faec 100644 --- a/mesalib/src/mapi/glapi/gen/ARB_draw_elements_base_vertex.xml +++ b/mesalib/src/mapi/glapi/gen/ARB_draw_elements_base_vertex.xml @@ -30,7 +30,7 @@          <param name="mode" type="GLenum"/>          <param name="count" type="const GLsizei *"/>          <param name="type" type="GLenum"/> -        <param name="indices" type="const GLvoid **"/> +        <param name="indices" type="const GLvoid * const *"/>          <param name="primcount" type="GLsizei"/>          <param name="basevertex" type="const GLint *"/>      </function> diff --git a/mesalib/src/mapi/glapi/gen/ARB_uniform_buffer_object.xml b/mesalib/src/mapi/glapi/gen/ARB_uniform_buffer_object.xml index cbcd339e7..80541a821 100644 --- a/mesalib/src/mapi/glapi/gen/ARB_uniform_buffer_object.xml +++ b/mesalib/src/mapi/glapi/gen/ARB_uniform_buffer_object.xml @@ -42,7 +42,7 @@  <function name="GetUniformIndices" offset="assign">      <param name="program" type="GLuint" />      <param name="uniformCount" type="GLsizei" /> -    <param name="uniformNames" type="const GLchar **" /> +    <param name="uniformNames" type="const GLchar * const *" />      <param name="uniformIndices" type="GLuint *" />  </function> diff --git a/mesalib/src/mapi/glapi/gen/GL3x.xml b/mesalib/src/mapi/glapi/gen/GL3x.xml index f3d782ca4..d287ac2b0 100644 --- a/mesalib/src/mapi/glapi/gen/GL3x.xml +++ b/mesalib/src/mapi/glapi/gen/GL3x.xml @@ -231,7 +231,7 @@    <function name="TransformFeedbackVaryings" alias="TransformFeedbackVaryingsEXT">      <param name="program" type="GLuint"/>      <param name="count" type="GLsizei"/> -    <param name="varyings" type="const GLchar* *"/> +    <param name="varyings" type="const GLchar * const *"/>      <param name="bufferMode" type="GLenum"/>    </function> diff --git a/mesalib/src/mapi/glapi/gen/gl_API.xml b/mesalib/src/mapi/glapi/gen/gl_API.xml index af0513556..af74c909b 100644 --- a/mesalib/src/mapi/glapi/gen/gl_API.xml +++ b/mesalib/src/mapi/glapi/gen/gl_API.xml @@ -4677,7 +4677,7 @@          <param name="mode" type="GLenum"/>          <param name="count" type="const GLsizei *"/>          <param name="type" type="GLenum"/> -        <param name="indices" type="const GLvoid **"/> +        <param name="indices" type="const GLvoid * const *"/>          <param name="primcount" type="GLsizei"/>      </function> @@ -5363,7 +5363,7 @@      <function name="ShaderSource" alias="ShaderSourceARB">          <param name="shader" type="GLuint"/>          <param name="count" type="GLsizei"/> -        <param name="string" type="const GLchar **"/> +        <param name="string" type="const GLchar * const *"/>          <param name="length" type="const GLint *"/>          <glx ignore="true"/>      </function> diff --git a/mesalib/src/mesa/main/APIspec.xml b/mesalib/src/mesa/main/APIspec.xml index 64e666eff..f870cf7db 100644 --- a/mesalib/src/mesa/main/APIspec.xml +++ b/mesalib/src/mesa/main/APIspec.xml @@ -2946,7 +2946,7 @@  		<return type="void"/>  		<param name="shader" type="GLuint"/>  		<param name="count" type="GLsizei"/> -		<param name="string" type="const GLchar **"/> +		<param name="string" type="const GLchar * const *"/>  		<param name="length" type="const int *"/>  	</proto>  </template> diff --git a/mesalib/src/mesa/main/arrayobj.c b/mesalib/src/mesa/main/arrayobj.c index 4c50066de..3439ab6b5 100644 --- a/mesalib/src/mesa/main/arrayobj.c +++ b/mesalib/src/mesa/main/arrayobj.c @@ -123,14 +123,15 @@ _mesa_delete_array_object( struct gl_context *ctx, struct gl_array_object *obj )  /**   * Set ptr to arrayObj w/ reference counting. + * Note: this should only be called from the _mesa_reference_array_object() + * inline function.   */  void -_mesa_reference_array_object(struct gl_context *ctx, -                             struct gl_array_object **ptr, -                             struct gl_array_object *arrayObj) +_mesa_reference_array_object_(struct gl_context *ctx, +                              struct gl_array_object **ptr, +                              struct gl_array_object *arrayObj)  { -   if (*ptr == arrayObj) -      return; +   assert(*ptr != arrayObj);     if (*ptr) {        /* Unreference the old array object */ diff --git a/mesalib/src/mesa/main/arrayobj.h b/mesalib/src/mesa/main/arrayobj.h index 717c7916e..e5270fa2c 100644 --- a/mesalib/src/mesa/main/arrayobj.h +++ b/mesalib/src/mesa/main/arrayobj.h @@ -52,9 +52,19 @@ extern void  _mesa_delete_array_object( struct gl_context *ctx, struct gl_array_object *obj );  extern void +_mesa_reference_array_object_(struct gl_context *ctx, +                              struct gl_array_object **ptr, +                              struct gl_array_object *arrayObj); + +static inline void  _mesa_reference_array_object(struct gl_context *ctx,                               struct gl_array_object **ptr, -                             struct gl_array_object *arrayObj); +                             struct gl_array_object *arrayObj) +{ +   if (*ptr != arrayObj) +      _mesa_reference_array_object_(ctx, ptr, arrayObj); +} +  extern void  _mesa_initialize_array_object( struct gl_context *ctx, diff --git a/mesalib/src/mesa/main/bufferobj.c b/mesalib/src/mesa/main/bufferobj.c index 5f724ace3..ea48af97e 100644 --- a/mesalib/src/mesa/main/bufferobj.c +++ b/mesalib/src/mesa/main/bufferobj.c @@ -2021,8 +2021,11 @@ set_ubo_binding(struct gl_context *ctx,  }  /** - * Specify a buffer object to receive vertex shader results.  Plus, - * specify the starting offset to place the results, and max size. + * Bind a region of a buffer object to a uniform block binding point. + * \param index  the uniform buffer binding point index + * \param bufObj  the buffer object + * \param offset  offset to the start of buffer object region + * \param size  size of the buffer object region   */  static void  bind_buffer_range_uniform_buffer(struct gl_context *ctx, @@ -2054,8 +2057,8 @@ bind_buffer_range_uniform_buffer(struct gl_context *ctx,  /** - * Specify a buffer object to receive vertex shader results. - * As above, but start at offset = 0. + * Bind a buffer object to a uniform block binding point. + * As above, but offset = 0.   */  static void  bind_buffer_base_uniform_buffer(struct gl_context *ctx, diff --git a/mesalib/src/mesa/main/dd.h b/mesalib/src/mesa/main/dd.h index 5bcf36bfa..687a38f44 100644 --- a/mesalib/src/mesa/main/dd.h +++ b/mesalib/src/mesa/main/dd.h @@ -1024,7 +1024,7 @@ typedef struct {     void (GLAPIENTRYP MultiDrawElementsBaseVertex)( GLenum mode,  						   const GLsizei *count,  						   GLenum type, -						   const GLvoid **indices, +						   const GLvoid * const *indices,  						   GLsizei primcount,  						   const GLint *basevertex);     void (GLAPIENTRYP DrawArraysInstanced)(GLenum mode, GLint first, diff --git a/mesalib/src/mesa/main/enable.c b/mesalib/src/mesa/main/enable.c index d0b462580..c811f2a9c 100644 --- a/mesalib/src/mesa/main/enable.c +++ b/mesalib/src/mesa/main/enable.c @@ -161,8 +161,8 @@ client_state(struct gl_context *ctx, GLenum cap, GLboolean state)     return;  invalid_enum_error: -   _mesa_error(ctx, GL_INVALID_ENUM, "gl%sClientState(0x%x)", -               state ? "Enable" : "Disable", cap); +   _mesa_error(ctx, GL_INVALID_ENUM, "gl%sClientState(%s)", +               state ? "Enable" : "Disable", _mesa_lookup_enum_by_nr(cap));  } @@ -937,8 +937,8 @@ _mesa_set_enable(struct gl_context *ctx, GLenum cap, GLboolean state)     return;  invalid_enum_error: -   _mesa_error(ctx, GL_INVALID_ENUM, "gl%s(0x%x)", -               state ? "Enable" : "Disable", cap); +   _mesa_error(ctx, GL_INVALID_ENUM, "gl%s(%s)", +               state ? "Enable" : "Disable", _mesa_lookup_enum_by_nr(cap));  } @@ -1441,6 +1441,7 @@ _mesa_IsEnabled( GLenum cap )     return GL_FALSE;  invalid_enum_error: -   _mesa_error(ctx, GL_INVALID_ENUM, "glIsEnabled(0x%x)", (int) cap); +   _mesa_error(ctx, GL_INVALID_ENUM, "glIsEnabled(%s)", +               _mesa_lookup_enum_by_nr(cap));     return GL_FALSE;  } diff --git a/mesalib/src/mesa/main/errors.c b/mesalib/src/mesa/main/errors.c index 69dbb65cf..8b96319ce 100644 --- a/mesalib/src/mesa/main/errors.c +++ b/mesalib/src/mesa/main/errors.c @@ -718,11 +718,11 @@ _mesa_DebugMessageControlARB(GLenum source, GLenum type, GLenum severity,  }  static void GLAPIENTRY -_mesa_DebugMessageCallbackARB(GLDEBUGPROCARB callback, GLvoid *userParam) +_mesa_DebugMessageCallbackARB(GLDEBUGPROCARB callback, const GLvoid *userParam)  {     GET_CURRENT_CONTEXT(ctx);     ctx->Debug.Callback = callback; -   ctx->Debug.CallbackData = userParam; +   ctx->Debug.CallbackData = (void *) userParam;  }  void @@ -801,12 +801,21 @@ output_if_debug(const char *prefixString, const char *outputString,                  GLboolean newline)  {     static int debug = -1; +   static FILE *fout = NULL;     /* Init the local 'debug' var once.      * Note: the _mesa_init_debug() function should have been called      * by now so MESA_DEBUG_FLAGS will be initialized.      */     if (debug == -1) { +      /* If MESA_LOG_FILE env var is set, log Mesa errors, warnings, +       * etc to the named file.  Otherwise, output to stderr. +       */ +      const char *logFile = _mesa_getenv("MESA_LOG_FILE"); +      if (logFile) +         fout = fopen(logFile, "w"); +      if (!fout) +         fout = stderr;  #ifdef DEBUG        /* in debug builds, print messages unless MESA_DEBUG="silent" */        if (MESA_DEBUG_FLAGS & DEBUG_SILENT) @@ -821,9 +830,10 @@ output_if_debug(const char *prefixString, const char *outputString,     /* Now only print the string if we're required to do so. */     if (debug) { -      fprintf(stderr, "%s: %s", prefixString, outputString); +      fprintf(fout, "%s: %s", prefixString, outputString);        if (newline) -         fprintf(stderr, "\n"); +         fprintf(fout, "\n"); +      fflush(fout);  #if defined(_WIN32) && !defined(_WIN32_WCE)        /* stderr from windows applications without console is not usually  diff --git a/mesalib/src/mesa/main/ffvertex_prog.c b/mesalib/src/mesa/main/ffvertex_prog.c index f1ab75333..557768311 100644 --- a/mesalib/src/mesa/main/ffvertex_prog.c +++ b/mesalib/src/mesa/main/ffvertex_prog.c @@ -181,7 +181,7 @@ static void make_state_key( struct gl_context *ctx, struct state_key *key )  	 key->light_twoside = 1;        if (ctx->Light.ColorMaterialEnabled) { -	 key->light_color_material_mask = ctx->Light.ColorMaterialBitmask; +	 key->light_color_material_mask = ctx->Light._ColorMaterialBitmask;        }        for (i = 0; i < MAX_LIGHTS; i++) { diff --git a/mesalib/src/mesa/main/imports.h b/mesalib/src/mesa/main/imports.h index c0b6cecea..9fb6ae8f1 100644 --- a/mesalib/src/mesa/main/imports.h +++ b/mesalib/src/mesa/main/imports.h @@ -646,6 +646,16 @@ _mesa_vsnprintf(char *str, size_t size, const char *fmt, va_list arg);  #endif +/** + * On Mingw32 we need to use __mingw_fprintf() to parse formats such + * as "0x%llx", and possibly others + */ +#ifdef __MINGW32__ +#define fprintf __mingw_fprintf +#endif + + +  #ifdef __cplusplus  }  #endif diff --git a/mesalib/src/mesa/main/light.c b/mesalib/src/mesa/main/light.c index 38ec1b6e8..d6fbcd9be 100644 --- a/mesalib/src/mesa/main/light.c +++ b/mesalib/src/mesa/main/light.c @@ -693,13 +693,13 @@ _mesa_update_material( struct gl_context *ctx, GLuint bitmask )  /*   * Update the current materials from the given rgba color - * according to the bitmask in ColorMaterialBitmask, which is + * according to the bitmask in _ColorMaterialBitmask, which is   * set by glColorMaterial().   */  void  _mesa_update_color_material( struct gl_context *ctx, const GLfloat color[4] )  { -   GLuint bitmask = ctx->Light.ColorMaterialBitmask; +   const GLbitfield bitmask = ctx->Light._ColorMaterialBitmask;     struct gl_material *mat = &ctx->Light.Material;     int i; @@ -731,13 +731,13 @@ _mesa_ColorMaterial( GLenum face, GLenum mode )     if (bitmask == 0)        return; /* error was recorded */ -   if (ctx->Light.ColorMaterialBitmask == bitmask && +   if (ctx->Light._ColorMaterialBitmask == bitmask &&         ctx->Light.ColorMaterialFace == face &&         ctx->Light.ColorMaterialMode == mode)        return;     FLUSH_VERTICES(ctx, _NEW_LIGHT); -   ctx->Light.ColorMaterialBitmask = bitmask; +   ctx->Light._ColorMaterialBitmask = bitmask;     ctx->Light.ColorMaterialFace = face;     ctx->Light.ColorMaterialMode = mode; @@ -1188,7 +1188,7 @@ _mesa_init_lighting( struct gl_context *ctx )     ctx->Light.Enabled = GL_FALSE;     ctx->Light.ColorMaterialFace = GL_FRONT_AND_BACK;     ctx->Light.ColorMaterialMode = GL_AMBIENT_AND_DIFFUSE; -   ctx->Light.ColorMaterialBitmask = _mesa_material_bitmask( ctx, +   ctx->Light._ColorMaterialBitmask = _mesa_material_bitmask( ctx,                                                 GL_FRONT_AND_BACK,                                                 GL_AMBIENT_AND_DIFFUSE, ~0,                                                 NULL ); diff --git a/mesalib/src/mesa/main/mtypes.h b/mesalib/src/mesa/main/mtypes.h index def0db1aa..d37c1f3de 100644 --- a/mesalib/src/mesa/main/mtypes.h +++ b/mesalib/src/mesa/main/mtypes.h @@ -630,6 +630,26 @@ struct gl_config  /** + * Material state. + */ +struct gl_material +{ +   GLfloat Attrib[MAT_ATTRIB_MAX][4]; +}; + + +/** + * Light state flags. + */ +/*@{*/ +#define LIGHT_SPOT         0x1 +#define LIGHT_LOCAL_VIEWER 0x2 +#define LIGHT_POSITIONAL   0x4 +#define LIGHT_NEED_VERTICES (LIGHT_POSITIONAL|LIGHT_LOCAL_VIEWER) +/*@}*/ + + +/**   * Light source state.   */  struct gl_light @@ -654,7 +674,7 @@ struct gl_light      * \name Derived fields      */     /*@{*/ -   GLbitfield _Flags;		/**< State */ +   GLbitfield _Flags;		/**< Mask of LIGHT_x bits defined above */     GLfloat _Position[4];	/**< position in eye/obj coordinates */     GLfloat _VP_inf_norm[3];	/**< Norm direction to infinite light */ @@ -683,15 +703,6 @@ struct gl_lightmodel  /** - * Material state. - */ -struct gl_material -{ -   GLfloat Attrib[MAT_ATTRIB_MAX][4]; -}; - - -/**   * Accumulation buffer attribute group (GL_ACCUM_BUFFER_BIT)   */  struct gl_accum_attrib @@ -912,16 +923,6 @@ struct gl_hint_attrib     GLenum FragmentShaderDerivative; /**< GL_ARB_fragment_shader */  }; -/** - * Light state flags. - */ -/*@{*/ -#define LIGHT_SPOT         0x1 -#define LIGHT_LOCAL_VIEWER 0x2 -#define LIGHT_POSITIONAL   0x4 -#define LIGHT_NEED_VERTICES (LIGHT_POSITIONAL|LIGHT_LOCAL_VIEWER) -/*@}*/ -  /**   * Lighting attribute group (GL_LIGHT_BIT). @@ -932,20 +933,19 @@ struct gl_light_attrib     struct gl_lightmodel Model;		/**< Lighting model */     /** -    * Must flush FLUSH_VERTICES before referencing: +    * Front and back material values. +    * Note: must call FLUSH_VERTICES() before using.      */ -   /*@{*/ -   struct gl_material Material; 	/**< Includes front & back values */ -   /*@}*/ +   struct gl_material Material;     GLboolean Enabled;			/**< Lighting enabled flag */     GLenum ShadeModel;			/**< GL_FLAT or GL_SMOOTH */     GLenum ProvokingVertex;              /**< GL_EXT_provoking_vertex */     GLenum ColorMaterialFace;		/**< GL_FRONT, BACK or FRONT_AND_BACK */     GLenum ColorMaterialMode;		/**< GL_AMBIENT, GL_DIFFUSE, etc */ -   GLbitfield ColorMaterialBitmask;	/**< bitmask formed from Face and Mode */ +   GLbitfield _ColorMaterialBitmask;	/**< bitmask formed from Face and Mode */     GLboolean ColorMaterialEnabled; -   GLenum ClampVertexColor; +   GLenum ClampVertexColor;             /**< GL_TRUE, GL_FALSE, GL_FIXED_ONLY */     GLboolean _ClampVertexColor;     struct gl_light EnabledList;         /**< List sentinel */ @@ -1181,46 +1181,6 @@ typedef enum  /** - * TexGenEnabled flags. - */ -/*@{*/ -#define S_BIT 1 -#define T_BIT 2 -#define R_BIT 4 -#define Q_BIT 8 -#define STR_BITS (S_BIT | T_BIT | R_BIT) -/*@}*/ - - -/** - * Bit flag versions of the corresponding GL_ constants. - */ -/*@{*/ -#define TEXGEN_SPHERE_MAP        0x1 -#define TEXGEN_OBJ_LINEAR        0x2 -#define TEXGEN_EYE_LINEAR        0x4 -#define TEXGEN_REFLECTION_MAP_NV 0x8 -#define TEXGEN_NORMAL_MAP_NV     0x10 - -#define TEXGEN_NEED_NORMALS      (TEXGEN_SPHERE_MAP        | \ -				  TEXGEN_REFLECTION_MAP_NV | \ -				  TEXGEN_NORMAL_MAP_NV) -#define TEXGEN_NEED_EYE_COORD    (TEXGEN_SPHERE_MAP        | \ -				  TEXGEN_REFLECTION_MAP_NV | \ -				  TEXGEN_NORMAL_MAP_NV     | \ -				  TEXGEN_EYE_LINEAR) -/*@}*/ - - - -/** Tex-gen enabled for texture unit? */ -#define ENABLE_TEXGEN(unit) (1 << (unit)) - -/** Non-identity texture matrix for texture unit? */ -#define ENABLE_TEXMAT(unit) (1 << (unit)) - - -/**   * Texture image state.  Drivers will typically create a subclass of this   * with extra fields for memory buffers, etc.   */ @@ -1367,6 +1327,46 @@ struct gl_tex_env_combine_state  /** + * TexGenEnabled flags. + */ +/*@{*/ +#define S_BIT 1 +#define T_BIT 2 +#define R_BIT 4 +#define Q_BIT 8 +#define STR_BITS (S_BIT | T_BIT | R_BIT) +/*@}*/ + + +/** + * Bit flag versions of the corresponding GL_ constants. + */ +/*@{*/ +#define TEXGEN_SPHERE_MAP        0x1 +#define TEXGEN_OBJ_LINEAR        0x2 +#define TEXGEN_EYE_LINEAR        0x4 +#define TEXGEN_REFLECTION_MAP_NV 0x8 +#define TEXGEN_NORMAL_MAP_NV     0x10 + +#define TEXGEN_NEED_NORMALS      (TEXGEN_SPHERE_MAP        | \ +				  TEXGEN_REFLECTION_MAP_NV | \ +				  TEXGEN_NORMAL_MAP_NV) +#define TEXGEN_NEED_EYE_COORD    (TEXGEN_SPHERE_MAP        | \ +				  TEXGEN_REFLECTION_MAP_NV | \ +				  TEXGEN_NORMAL_MAP_NV     | \ +				  TEXGEN_EYE_LINEAR) +/*@}*/ + + + +/** Tex-gen enabled for texture unit? */ +#define ENABLE_TEXGEN(unit) (1 << (unit)) + +/** Non-identity texture matrix for texture unit? */ +#define ENABLE_TEXMAT(unit) (1 << (unit)) + + +/**   * Texture coord generation state.   */  struct gl_texgen @@ -2021,6 +2021,12 @@ struct gl_fragment_program      * GLSL, the value is INTERP_QUALIFIER_NONE.      */     enum glsl_interp_qualifier InterpQualifier[FRAG_ATTRIB_MAX]; + +   /** +    * Bitfield indicating, for each fragment shader input, 1 if that input +    * uses centroid interpolation, 0 otherwise.  Unused inputs are 0. +    */ +   GLbitfield64 IsCentroid;  }; diff --git a/mesalib/src/mesa/main/transformfeedback.c b/mesalib/src/mesa/main/transformfeedback.c index 84c409185..d02b6a056 100644 --- a/mesalib/src/mesa/main/transformfeedback.c +++ b/mesalib/src/mesa/main/transformfeedback.c @@ -428,6 +428,7 @@ bind_buffer_range(struct gl_context *ctx, GLuint index,  /**   * Specify a buffer object to receive vertex shader results.  Plus,   * specify the starting offset to place the results, and max size. + * Called from the glBindBufferRange() function.   */  void  _mesa_bind_buffer_range_transform_feedback(struct gl_context *ctx, @@ -471,6 +472,7 @@ _mesa_bind_buffer_range_transform_feedback(struct gl_context *ctx,  /**   * Specify a buffer object to receive vertex shader results.   * As above, but start at offset = 0. + * Called from the glBindBufferBase() function.   */  void  _mesa_bind_buffer_base_transform_feedback(struct gl_context *ctx, diff --git a/mesalib/src/mesa/state_tracker/st_cb_fbo.c b/mesalib/src/mesa/state_tracker/st_cb_fbo.c index aeb5ac7fb..10f4e09cf 100644 --- a/mesalib/src/mesa/state_tracker/st_cb_fbo.c +++ b/mesalib/src/mesa/state_tracker/st_cb_fbo.c @@ -57,6 +57,10 @@  #include "util/u_surface.h" +/** Set to 1 to enable extra debug code */ +#define ST_DEBUG_FBO 0 + +  static GLboolean  st_renderbuffer_alloc_sw_storage(struct gl_context * ctx,                                   struct gl_renderbuffer *rb, @@ -472,6 +476,16 @@ st_finish_render_texture(struct gl_context *ctx,  } +/** Debug helper */ +static void +st_fbo_invalid(const char *reason) +{ +#if ST_DEBUG_FBO +   debug_printf("Invalid FBO: %s\n", reason); +#endif +} + +  /**   * Validate a renderbuffer attachment for a particular set of bindings.   */ @@ -484,6 +498,7 @@ st_validate_attachment(struct gl_context *ctx,     const struct st_texture_object *stObj = st_texture_object(att->Texture);     enum pipe_format format;     gl_format texFormat; +   GLboolean valid;     /* Only validate texture attachments for now, since      * st_renderbuffer_alloc_storage makes sure that @@ -507,9 +522,14 @@ st_validate_attachment(struct gl_context *ctx,        format = st_mesa_format_to_pipe_format(linearFormat);     } -   return screen->is_format_supported(screen, format, +   valid = screen->is_format_supported(screen, format,                                        PIPE_TEXTURE_2D,                                        stObj->pt->nr_samples, bindings); +   if (!valid) { +      st_fbo_invalid("Invalid format"); +   } + +   return valid;  } @@ -558,12 +578,14 @@ st_validate_framebuffer(struct gl_context *ctx, struct gl_framebuffer *fb)           screen->get_param(screen, PIPE_CAP_MIXED_COLORBUFFER_FORMATS) != 0;     if (depth->Type && stencil->Type && depth->Type != stencil->Type) { +      st_fbo_invalid("Different Depth/Stencil buffer formats");        fb->_Status = GL_FRAMEBUFFER_UNSUPPORTED_EXT;        return;     }     if (depth->Type == GL_RENDERBUFFER_EXT &&         stencil->Type == GL_RENDERBUFFER_EXT &&         depth->Renderbuffer != stencil->Renderbuffer) { +      st_fbo_invalid("Separate Depth/Stencil buffers");        fb->_Status = GL_FRAMEBUFFER_UNSUPPORTED_EXT;        return;     } @@ -571,6 +593,7 @@ st_validate_framebuffer(struct gl_context *ctx, struct gl_framebuffer *fb)         stencil->Type == GL_TEXTURE &&         depth->Texture != stencil->Texture) {        fb->_Status = GL_FRAMEBUFFER_UNSUPPORTED_EXT; +      st_fbo_invalid("Different Depth/Stencil textures");        return;     } @@ -613,6 +636,7 @@ st_validate_framebuffer(struct gl_context *ctx, struct gl_framebuffer *fb)              first_format = format;           } else if (format != first_format) {              fb->_Status = GL_FRAMEBUFFER_UNSUPPORTED_EXT; +            st_fbo_invalid("Mixed color formats");              return;           }        } diff --git a/mesalib/src/mesa/tnl/t_vb_light.c b/mesalib/src/mesa/tnl/t_vb_light.c index 39467fac7..854887c8f 100644 --- a/mesalib/src/mesa/tnl/t_vb_light.c +++ b/mesalib/src/mesa/tnl/t_vb_light.c @@ -227,12 +227,12 @@ prepare_materials(struct gl_context *ctx,     store->mat_count = 0;     store->mat_bitmask = 0; -   /* Examine the ColorMaterialBitmask to determine which materials +   /* Examine the _ColorMaterialBitmask to determine which materials      * track vertex color.  Override the material attribute's pointer      * with the color pointer for each one.      */     if (ctx->Light.ColorMaterialEnabled) { -      const GLuint bitmask = ctx->Light.ColorMaterialBitmask; +      const GLuint bitmask = ctx->Light._ColorMaterialBitmask;        for (i = 0 ; i < MAT_ATTRIB_MAX ; i++)  	 if (bitmask & (1<<i))  	    VB->AttribPtr[_TNL_ATTRIB_MAT_FRONT_AMBIENT + i] = VB->AttribPtr[_TNL_ATTRIB_COLOR0]; diff --git a/mesalib/src/mesa/vbo/vbo_exec_api.c b/mesalib/src/mesa/vbo/vbo_exec_api.c index bfa1b1db8..fc7e40692 100644 --- a/mesalib/src/mesa/vbo/vbo_exec_api.c +++ b/mesalib/src/mesa/vbo/vbo_exec_api.c @@ -450,7 +450,7 @@ vbo_Materialfv(GLenum face, GLenum pname, const GLfloat *params)      * indicating which material attributes can actually be updated below.      */     if (ctx->Light.ColorMaterialEnabled) { -      updateMats = ~ctx->Light.ColorMaterialBitmask; +      updateMats = ~ctx->Light._ColorMaterialBitmask;     }     else {        /* GL_COLOR_MATERIAL is disabled so don't skip any material updates */ diff --git a/mesalib/src/mesa/vbo/vbo_exec_array.c b/mesalib/src/mesa/vbo/vbo_exec_array.c index ebf008536..6f6a2983a 100644 --- a/mesalib/src/mesa/vbo/vbo_exec_array.c +++ b/mesalib/src/mesa/vbo/vbo_exec_array.c @@ -1149,7 +1149,8 @@ vbo_exec_DrawElementsInstancedBaseVertexBaseInstance(GLenum mode, GLsizei count,  static void  vbo_validated_multidrawelements(struct gl_context *ctx, GLenum mode,  				const GLsizei *count, GLenum type, -				const GLvoid **indices, GLsizei primcount, +				const GLvoid * const *indices, +				GLsizei primcount,  				const GLint *basevertex)  {     struct vbo_context *vbo = vbo_context(ctx); @@ -1290,7 +1291,7 @@ vbo_exec_MultiDrawElements(GLenum mode,  static void GLAPIENTRY  vbo_exec_MultiDrawElementsBaseVertex(GLenum mode,  				     const GLsizei *count, GLenum type, -				     const GLvoid **indices, +				     const GLvoid * const *indices,  				     GLsizei primcount,  				     const GLsizei *basevertex)  { diff --git a/mesalib/src/mesa/vbo/vbo_noop.c b/mesalib/src/mesa/vbo/vbo_noop.c index 430011207..2f472c21c 100644 --- a/mesalib/src/mesa/vbo/vbo_noop.c +++ b/mesalib/src/mesa/vbo/vbo_noop.c @@ -404,7 +404,7 @@ _mesa_noop_DrawRangeElementsBaseVertex(GLenum mode,  static void GLAPIENTRY  _mesa_noop_MultiDrawElementsBaseVertex(GLenum mode, const GLsizei * count,                                         GLenum type, -                                       const GLvoid ** indices, +                                       const GLvoid * const *indices,                                         GLsizei primcount,                                         const GLint * basevertex)  { diff --git a/mesalib/src/mesa/vbo/vbo_save_api.c b/mesalib/src/mesa/vbo/vbo_save_api.c index b2c9dd5f0..d27525812 100644 --- a/mesalib/src/mesa/vbo/vbo_save_api.c +++ b/mesalib/src/mesa/vbo/vbo_save_api.c @@ -1042,7 +1042,7 @@ _save_MultiDrawElements(GLenum mode, const GLsizei *count, GLenum type,  static void GLAPIENTRY  _save_MultiDrawElementsBaseVertex(GLenum mode, const GLsizei *count, -                                  GLenum type, const GLvoid **indices, +                                  GLenum type, const GLvoid * const *indices,                                    GLsizei primcount, const GLint *basevertex)  {     GET_CURRENT_CONTEXT(ctx); @@ -1255,7 +1255,7 @@ _save_OBE_MultiDrawElements(GLenum mode, const GLsizei *count, GLenum type,  static void GLAPIENTRY  _save_OBE_MultiDrawElementsBaseVertex(GLenum mode, const GLsizei *count,                                        GLenum type, -                                      const GLvoid **indices, +                                      const GLvoid * const *indices,                                        GLsizei primcount,                                        const GLint *basevertex)  { diff --git a/mesalib/src/mesa/x86/Makefile.am b/mesalib/src/mesa/x86/Makefile.am index f241de505..5976bb47c 100644 --- a/mesalib/src/mesa/x86/Makefile.am +++ b/mesalib/src/mesa/x86/Makefile.am @@ -22,6 +22,7 @@  if HAVE_X86_ASM  AM_CPPFLAGS = \ +	-I$(top_srcdir)/include \  	-I$(top_srcdir)/src/mesa \  	-I$(top_srcdir)/src/mapi \  	$(API_DEFINES) \ diff --git a/mesalib/src/mesa/x86/gen_matypes.c b/mesalib/src/mesa/x86/gen_matypes.c index 4fe99e799..a1d8ee67d 100644 --- a/mesalib/src/mesa/x86/gen_matypes.c +++ b/mesalib/src/mesa/x86/gen_matypes.c @@ -99,7 +99,7 @@ int main( int argc, char **argv )     OFFSET( "CTX_LIGHT_SHADE_MODEL       ", struct gl_context, Light.ShadeModel );     OFFSET( "CTX_LIGHT_COLOR_MAT_FACE    ", struct gl_context, Light.ColorMaterialFace );     OFFSET( "CTX_LIGHT_COLOR_MAT_MODE    ", struct gl_context, Light.ColorMaterialMode ); -   OFFSET( "CTX_LIGHT_COLOR_MAT_MASK    ", struct gl_context, Light.ColorMaterialBitmask ); +   OFFSET( "CTX_LIGHT_COLOR_MAT_MASK    ", struct gl_context, Light._ColorMaterialBitmask );     OFFSET( "CTX_LIGHT_COLOR_MAT_ENABLED ", struct gl_context, Light.ColorMaterialEnabled );     OFFSET( "CTX_LIGHT_ENABLED_LIST      ", struct gl_context, Light.EnabledList );     OFFSET( "CTX_LIGHT_NEED_VERTS        ", struct gl_context, Light._NeedVertices ); | 
