diff options
Diffstat (limited to 'mesalib/src')
-rw-r--r-- | mesalib/src/gallium/auxiliary/util/u_blitter.c | 2072 | ||||
-rw-r--r-- | mesalib/src/glsl/opt_discard_simplification.cpp | 394 | ||||
-rw-r--r-- | mesalib/src/mapi/glapi/gen/Makefile | 9 | ||||
-rw-r--r-- | mesalib/src/mapi/glapi/gen/gl_gentable.py | 131 | ||||
-rw-r--r-- | mesalib/src/mapi/glapi/glapi.h | 358 | ||||
-rw-r--r-- | mesalib/src/mapi/glapi/glapi_gentable.c | 7804 | ||||
-rw-r--r-- | mesalib/src/mapi/glapi/sources.mak | 37 | ||||
-rw-r--r-- | mesalib/src/mapi/mapi/entry_x86-64_tls.h | 4 | ||||
-rw-r--r-- | mesalib/src/mapi/mapi/entry_x86_tls.h | 6 | ||||
-rw-r--r-- | mesalib/src/mapi/mapi/entry_x86_tsd.h | 5 | ||||
-rw-r--r-- | mesalib/src/mesa/state_tracker/st_draw.c | 3 |
11 files changed, 9393 insertions, 1430 deletions
diff --git a/mesalib/src/gallium/auxiliary/util/u_blitter.c b/mesalib/src/gallium/auxiliary/util/u_blitter.c index 0d9ce9ff7..528f344a0 100644 --- a/mesalib/src/gallium/auxiliary/util/u_blitter.c +++ b/mesalib/src/gallium/auxiliary/util/u_blitter.c @@ -1,1036 +1,1036 @@ -/**************************************************************************
- *
- * Copyright 2009 Marek Olšák <maraeo@gmail.com>
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the
- * "Software"), to deal in the Software without restriction, including
- * without limitation the rights to use, copy, modify, merge, publish,
- * distribute, sub license, and/or sell copies of the Software, and to
- * permit persons to whom the Software is furnished to do so, subject to
- * the following conditions:
- *
- * The above copyright notice and this permission notice (including the
- * next paragraph) shall be included in all copies or substantial portions
- * of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
- * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
- * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
- * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- *
- **************************************************************************/
-
-/**
- * @file
- * Blitter utility to facilitate acceleration of the clear, clear_render_target, clear_depth_stencil
- * resource_copy_region functions.
- *
- * @author Marek Olšák
- */
-
-#include "pipe/p_context.h"
-#include "pipe/p_defines.h"
-#include "util/u_inlines.h"
-#include "pipe/p_shader_tokens.h"
-#include "pipe/p_state.h"
-
-#include "util/u_format.h"
-#include "util/u_memory.h"
-#include "util/u_math.h"
-#include "util/u_blitter.h"
-#include "util/u_draw_quad.h"
-#include "util/u_sampler.h"
-#include "util/u_simple_shaders.h"
-#include "util/u_surface.h"
-#include "util/u_texture.h"
-
-#define INVALID_PTR ((void*)~0)
-
-struct blitter_context_priv
-{
- struct blitter_context base;
-
- struct pipe_resource *vbuf; /**< quad */
-
- float vertices[4][2][4]; /**< {pos, color} or {pos, texcoord} */
-
- /* Templates for various state objects. */
- struct pipe_sampler_state template_sampler_state;
-
- /* Constant state objects. */
- /* Vertex shaders. */
- void *vs; /**< Vertex shader which passes {pos, generic} to the output.*/
-
- /* Fragment shaders. */
- /* The shader at index i outputs color to color buffers 0,1,...,i-1. */
- void *fs_col[PIPE_MAX_COLOR_BUFS+1];
-
- /* FS which outputs a color from a texture,
- where the index is PIPE_TEXTURE_* to be sampled. */
- void *fs_texfetch_col[PIPE_MAX_TEXTURE_TYPES];
-
- /* FS which outputs a depth from a texture,
- where the index is PIPE_TEXTURE_* to be sampled. */
- void *fs_texfetch_depth[PIPE_MAX_TEXTURE_TYPES];
-
- /* Blend state. */
- void *blend_write_color; /**< blend state with writemask of RGBA */
- void *blend_keep_color; /**< blend state with writemask of 0 */
-
- /* Depth stencil alpha state. */
- void *dsa_write_depth_stencil;
- void *dsa_write_depth_keep_stencil;
- void *dsa_keep_depth_stencil;
- void *dsa_keep_depth_write_stencil;
-
- void *velem_state;
-
- /* Sampler state for clamping to a miplevel. */
- void *sampler_state[PIPE_MAX_TEXTURE_LEVELS * 2];
-
- /* Rasterizer state. */
- void *rs_state;
-
- /* Viewport state. */
- struct pipe_viewport_state viewport;
-
- /* Clip state. */
- struct pipe_clip_state clip;
-
- /* Destination surface dimensions. */
- unsigned dst_width;
- unsigned dst_height;
-};
-
-static void blitter_draw_rectangle(struct blitter_context *blitter,
- unsigned x, unsigned y,
- unsigned width, unsigned height,
- float depth,
- enum blitter_attrib_type type,
- const float attrib[4]);
-
-
-struct blitter_context *util_blitter_create(struct pipe_context *pipe)
-{
- struct blitter_context_priv *ctx;
- struct pipe_blend_state blend;
- struct pipe_depth_stencil_alpha_state dsa;
- struct pipe_rasterizer_state rs_state;
- struct pipe_sampler_state *sampler_state;
- struct pipe_vertex_element velem[2];
- unsigned i;
-
- ctx = CALLOC_STRUCT(blitter_context_priv);
- if (!ctx)
- return NULL;
-
- ctx->base.pipe = pipe;
- ctx->base.draw_rectangle = blitter_draw_rectangle;
-
- /* init state objects for them to be considered invalid */
- ctx->base.saved_blend_state = INVALID_PTR;
- ctx->base.saved_dsa_state = INVALID_PTR;
- ctx->base.saved_rs_state = INVALID_PTR;
- ctx->base.saved_fs = INVALID_PTR;
- ctx->base.saved_vs = INVALID_PTR;
- ctx->base.saved_velem_state = INVALID_PTR;
- ctx->base.saved_fb_state.nr_cbufs = ~0;
- ctx->base.saved_num_sampler_views = ~0;
- ctx->base.saved_num_sampler_states = ~0;
- ctx->base.saved_num_vertex_buffers = ~0;
-
- /* blend state objects */
- memset(&blend, 0, sizeof(blend));
- ctx->blend_keep_color = pipe->create_blend_state(pipe, &blend);
-
- blend.rt[0].colormask = PIPE_MASK_RGBA;
- ctx->blend_write_color = pipe->create_blend_state(pipe, &blend);
-
- /* depth stencil alpha state objects */
- memset(&dsa, 0, sizeof(dsa));
- ctx->dsa_keep_depth_stencil =
- pipe->create_depth_stencil_alpha_state(pipe, &dsa);
-
- dsa.depth.enabled = 1;
- dsa.depth.writemask = 1;
- dsa.depth.func = PIPE_FUNC_ALWAYS;
- ctx->dsa_write_depth_keep_stencil =
- pipe->create_depth_stencil_alpha_state(pipe, &dsa);
-
- dsa.stencil[0].enabled = 1;
- dsa.stencil[0].func = PIPE_FUNC_ALWAYS;
- dsa.stencil[0].fail_op = PIPE_STENCIL_OP_REPLACE;
- dsa.stencil[0].zpass_op = PIPE_STENCIL_OP_REPLACE;
- dsa.stencil[0].zfail_op = PIPE_STENCIL_OP_REPLACE;
- dsa.stencil[0].valuemask = 0xff;
- dsa.stencil[0].writemask = 0xff;
- ctx->dsa_write_depth_stencil =
- pipe->create_depth_stencil_alpha_state(pipe, &dsa);
-
-
- dsa.depth.enabled = 0;
- dsa.depth.writemask = 0;
- ctx->dsa_keep_depth_write_stencil =
- pipe->create_depth_stencil_alpha_state(pipe, &dsa);
-
- /* sampler state */
- sampler_state = &ctx->template_sampler_state;
- sampler_state->wrap_s = PIPE_TEX_WRAP_CLAMP_TO_EDGE;
- sampler_state->wrap_t = PIPE_TEX_WRAP_CLAMP_TO_EDGE;
- sampler_state->wrap_r = PIPE_TEX_WRAP_CLAMP_TO_EDGE;
- sampler_state->normalized_coords = TRUE;
- /* The sampler state objects which sample from a specified mipmap level
- * are created on-demand. */
-
- /* rasterizer state */
- memset(&rs_state, 0, sizeof(rs_state));
- rs_state.cull_face = PIPE_FACE_NONE;
- rs_state.gl_rasterization_rules = 1;
- rs_state.flatshade = 1;
- ctx->rs_state = pipe->create_rasterizer_state(pipe, &rs_state);
-
- /* vertex elements state */
- memset(&velem[0], 0, sizeof(velem[0]) * 2);
- for (i = 0; i < 2; i++) {
- velem[i].src_offset = i * 4 * sizeof(float);
- velem[i].instance_divisor = 0;
- velem[i].vertex_buffer_index = 0;
- velem[i].src_format = PIPE_FORMAT_R32G32B32A32_FLOAT;
- }
- ctx->velem_state = pipe->create_vertex_elements_state(pipe, 2, &velem[0]);
-
- /* fragment shaders are created on-demand */
-
- /* vertex shader */
- {
- const uint semantic_names[] = { TGSI_SEMANTIC_POSITION,
- TGSI_SEMANTIC_GENERIC };
- const uint semantic_indices[] = { 0, 0 };
- ctx->vs =
- util_make_vertex_passthrough_shader(pipe, 2, semantic_names,
- semantic_indices);
- }
-
- /* set invariant vertex coordinates */
- for (i = 0; i < 4; i++)
- ctx->vertices[i][0][3] = 1; /*v.w*/
-
- /* create the vertex buffer */
- ctx->vbuf = pipe_user_buffer_create(ctx->base.pipe->screen,
- ctx->vertices,
- sizeof(ctx->vertices),
- PIPE_BIND_VERTEX_BUFFER);
-
- return &ctx->base;
-}
-
-void util_blitter_destroy(struct blitter_context *blitter)
-{
- struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter;
- struct pipe_context *pipe = blitter->pipe;
- int i;
-
- pipe->delete_blend_state(pipe, ctx->blend_write_color);
- pipe->delete_blend_state(pipe, ctx->blend_keep_color);
- pipe->delete_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil);
- pipe->delete_depth_stencil_alpha_state(pipe,
- ctx->dsa_write_depth_keep_stencil);
- pipe->delete_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_stencil);
- pipe->delete_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_write_stencil);
-
- pipe->delete_rasterizer_state(pipe, ctx->rs_state);
- pipe->delete_vs_state(pipe, ctx->vs);
- pipe->delete_vertex_elements_state(pipe, ctx->velem_state);
-
- for (i = 0; i < PIPE_MAX_TEXTURE_TYPES; i++) {
- if (ctx->fs_texfetch_col[i])
- pipe->delete_fs_state(pipe, ctx->fs_texfetch_col[i]);
- if (ctx->fs_texfetch_depth[i])
- pipe->delete_fs_state(pipe, ctx->fs_texfetch_depth[i]);
- }
-
- for (i = 0; i <= PIPE_MAX_COLOR_BUFS; i++)
- if (ctx->fs_col[i])
- pipe->delete_fs_state(pipe, ctx->fs_col[i]);
-
- for (i = 0; i < PIPE_MAX_TEXTURE_LEVELS * 2; i++)
- if (ctx->sampler_state[i])
- pipe->delete_sampler_state(pipe, ctx->sampler_state[i]);
-
- pipe_resource_reference(&ctx->vbuf, NULL);
- FREE(ctx);
-}
-
-static void blitter_check_saved_CSOs(struct blitter_context_priv *ctx)
-{
- if (ctx->base.running) {
- _debug_printf("u_blitter: Caught recursion on save. "
- "This is a driver bug.\n");
- }
- ctx->base.running = TRUE;
-
- /* make sure these CSOs have been saved */
- assert(ctx->base.saved_blend_state != INVALID_PTR &&
- ctx->base.saved_dsa_state != INVALID_PTR &&
- ctx->base.saved_rs_state != INVALID_PTR &&
- ctx->base.saved_fs != INVALID_PTR &&
- ctx->base.saved_vs != INVALID_PTR &&
- ctx->base.saved_velem_state != INVALID_PTR);
-}
-
-static void blitter_restore_CSOs(struct blitter_context_priv *ctx)
-{
- struct pipe_context *pipe = ctx->base.pipe;
- unsigned i;
-
- /* restore the state objects which are always required to be saved */
- pipe->bind_blend_state(pipe, ctx->base.saved_blend_state);
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->base.saved_dsa_state);
- pipe->bind_rasterizer_state(pipe, ctx->base.saved_rs_state);
- pipe->bind_fs_state(pipe, ctx->base.saved_fs);
- pipe->bind_vs_state(pipe, ctx->base.saved_vs);
- pipe->bind_vertex_elements_state(pipe, ctx->base.saved_velem_state);
-
- ctx->base.saved_blend_state = INVALID_PTR;
- ctx->base.saved_dsa_state = INVALID_PTR;
- ctx->base.saved_rs_state = INVALID_PTR;
- ctx->base.saved_fs = INVALID_PTR;
- ctx->base.saved_vs = INVALID_PTR;
- ctx->base.saved_velem_state = INVALID_PTR;
-
- pipe->set_stencil_ref(pipe, &ctx->base.saved_stencil_ref);
- pipe->set_viewport_state(pipe, &ctx->base.saved_viewport);
- pipe->set_clip_state(pipe, &ctx->base.saved_clip);
-
- /* restore the state objects which are required to be saved before copy/fill
- */
- if (ctx->base.saved_fb_state.nr_cbufs != ~0) {
- pipe->set_framebuffer_state(pipe, &ctx->base.saved_fb_state);
- util_unreference_framebuffer_state(&ctx->base.saved_fb_state);
- ctx->base.saved_fb_state.nr_cbufs = ~0;
- }
-
- if (ctx->base.saved_num_sampler_states != ~0) {
- pipe->bind_fragment_sampler_states(pipe,
- ctx->base.saved_num_sampler_states,
- ctx->base.saved_sampler_states);
- ctx->base.saved_num_sampler_states = ~0;
- }
-
- if (ctx->base.saved_num_sampler_views != ~0) {
- pipe->set_fragment_sampler_views(pipe,
- ctx->base.saved_num_sampler_views,
- ctx->base.saved_sampler_views);
-
- for (i = 0; i < ctx->base.saved_num_sampler_views; i++)
- pipe_sampler_view_reference(&ctx->base.saved_sampler_views[i],
- NULL);
-
- ctx->base.saved_num_sampler_views = ~0;
- }
-
- if (ctx->base.saved_num_vertex_buffers != ~0) {
- pipe->set_vertex_buffers(pipe,
- ctx->base.saved_num_vertex_buffers,
- ctx->base.saved_vertex_buffers);
-
- for (i = 0; i < ctx->base.saved_num_vertex_buffers; i++) {
- if (ctx->base.saved_vertex_buffers[i].buffer) {
- pipe_resource_reference(&ctx->base.saved_vertex_buffers[i].buffer,
- NULL);
- }
- }
- ctx->base.saved_num_vertex_buffers = ~0;
- }
-
- if (!ctx->base.running) {
- _debug_printf("u_blitter: Caught recursion on restore. "
- "This is a driver bug.\n");
- }
- ctx->base.running = FALSE;
-}
-
-static void blitter_set_rectangle(struct blitter_context_priv *ctx,
- unsigned x1, unsigned y1,
- unsigned x2, unsigned y2,
- float depth)
-{
- int i;
-
- /* set vertex positions */
- ctx->vertices[0][0][0] = (float)x1 / ctx->dst_width * 2.0f - 1.0f; /*v0.x*/
- ctx->vertices[0][0][1] = (float)y1 / ctx->dst_height * 2.0f - 1.0f; /*v0.y*/
-
- ctx->vertices[1][0][0] = (float)x2 / ctx->dst_width * 2.0f - 1.0f; /*v1.x*/
- ctx->vertices[1][0][1] = (float)y1 / ctx->dst_height * 2.0f - 1.0f; /*v1.y*/
-
- ctx->vertices[2][0][0] = (float)x2 / ctx->dst_width * 2.0f - 1.0f; /*v2.x*/
- ctx->vertices[2][0][1] = (float)y2 / ctx->dst_height * 2.0f - 1.0f; /*v2.y*/
-
- ctx->vertices[3][0][0] = (float)x1 / ctx->dst_width * 2.0f - 1.0f; /*v3.x*/
- ctx->vertices[3][0][1] = (float)y2 / ctx->dst_height * 2.0f - 1.0f; /*v3.y*/
-
- for (i = 0; i < 4; i++)
- ctx->vertices[i][0][2] = depth; /*z*/
-
- /* viewport */
- ctx->viewport.scale[0] = 0.5f * ctx->dst_width;
- ctx->viewport.scale[1] = 0.5f * ctx->dst_height;
- ctx->viewport.scale[2] = 1.0f;
- ctx->viewport.scale[3] = 1.0f;
- ctx->viewport.translate[0] = 0.5f * ctx->dst_width;
- ctx->viewport.translate[1] = 0.5f * ctx->dst_height;
- ctx->viewport.translate[2] = 0.0f;
- ctx->viewport.translate[3] = 0.0f;
- ctx->base.pipe->set_viewport_state(ctx->base.pipe, &ctx->viewport);
-
- /* clip */
- ctx->base.pipe->set_clip_state(ctx->base.pipe, &ctx->clip);
-}
-
-static void blitter_set_clear_color(struct blitter_context_priv *ctx,
- const float *rgba)
-{
- int i;
-
- if (rgba) {
- for (i = 0; i < 4; i++) {
- ctx->vertices[i][1][0] = rgba[0];
- ctx->vertices[i][1][1] = rgba[1];
- ctx->vertices[i][1][2] = rgba[2];
- ctx->vertices[i][1][3] = rgba[3];
- }
- } else {
- for (i = 0; i < 4; i++) {
- ctx->vertices[i][1][0] = 0;
- ctx->vertices[i][1][1] = 0;
- ctx->vertices[i][1][2] = 0;
- ctx->vertices[i][1][3] = 0;
- }
- }
-}
-
-static void get_texcoords(struct pipe_resource *src,
- unsigned level,
- unsigned x1, unsigned y1,
- unsigned x2, unsigned y2,
- boolean normalized, float out[4])
-{
- if(normalized)
- {
- out[0] = x1 / (float)u_minify(src->width0, level);
- out[1] = y1 / (float)u_minify(src->height0, level);
- out[2] = x2 / (float)u_minify(src->width0, level);
- out[3] = y2 / (float)u_minify(src->height0, level);
- }
- else
- {
- out[0] = x1;
- out[1] = y1;
- out[2] = x2;
- out[3] = y2;
- }
-}
-
-static void set_texcoords_in_vertices(const float coord[4],
- float *out, unsigned stride)
-{
- out[0] = coord[0]; /*t0.s*/
- out[1] = coord[1]; /*t0.t*/
- out += stride;
- out[0] = coord[2]; /*t1.s*/
- out[1] = coord[1]; /*t1.t*/
- out += stride;
- out[0] = coord[2]; /*t2.s*/
- out[1] = coord[3]; /*t2.t*/
- out += stride;
- out[0] = coord[0]; /*t3.s*/
- out[1] = coord[3]; /*t3.t*/
-}
-
-static void blitter_set_texcoords_2d(struct blitter_context_priv *ctx,
- struct pipe_resource *src,
- unsigned level,
- unsigned x1, unsigned y1,
- unsigned x2, unsigned y2)
-{
- unsigned i;
- float coord[4];
-
- get_texcoords(src, level, x1, y1, x2, y2, TRUE, coord);
- set_texcoords_in_vertices(coord, &ctx->vertices[0][1][0], 8);
-
- for (i = 0; i < 4; i++) {
- ctx->vertices[i][1][2] = 0; /*r*/
- ctx->vertices[i][1][3] = 1; /*q*/
- }
-}
-
-static void blitter_set_texcoords_3d(struct blitter_context_priv *ctx,
- struct pipe_resource *src,
- unsigned level,
- unsigned zslice,
- unsigned x1, unsigned y1,
- unsigned x2, unsigned y2)
-{
- int i;
- float r = zslice / (float)u_minify(src->depth0, level);
-
- blitter_set_texcoords_2d(ctx, src, level, x1, y1, x2, y2);
-
- for (i = 0; i < 4; i++)
- ctx->vertices[i][1][2] = r; /*r*/
-}
-
-static void blitter_set_texcoords_cube(struct blitter_context_priv *ctx,
- struct pipe_resource *src,
- unsigned level, unsigned face,
- unsigned x1, unsigned y1,
- unsigned x2, unsigned y2)
-{
- int i;
- float coord[4];
- float st[4][2];
-
- get_texcoords(src, level, x1, y1, x2, y2, TRUE, coord);
- set_texcoords_in_vertices(coord, &st[0][0], 2);
-
- util_map_texcoords2d_onto_cubemap(face,
- /* pointer, stride in floats */
- &st[0][0], 2,
- &ctx->vertices[0][1][0], 8);
-
- for (i = 0; i < 4; i++)
- ctx->vertices[i][1][3] = 1; /*q*/
-}
-
-static void blitter_set_dst_dimensions(struct blitter_context_priv *ctx,
- unsigned width, unsigned height)
-{
- ctx->dst_width = width;
- ctx->dst_height = height;
-}
-
-static INLINE
-void **blitter_get_sampler_state(struct blitter_context_priv *ctx,
- int miplevel, boolean normalized)
-{
- struct pipe_context *pipe = ctx->base.pipe;
- struct pipe_sampler_state *sampler_state = &ctx->template_sampler_state;
-
- assert(miplevel < PIPE_MAX_TEXTURE_LEVELS);
-
- /* Create the sampler state on-demand. */
- if (!ctx->sampler_state[miplevel * 2 + normalized]) {
- sampler_state->lod_bias = miplevel;
- sampler_state->min_lod = miplevel;
- sampler_state->max_lod = miplevel;
- sampler_state->normalized_coords = normalized;
-
- ctx->sampler_state[miplevel * 2 + normalized] = pipe->create_sampler_state(pipe,
- sampler_state);
- }
-
- /* Return void** so that it can be passed to bind_fragment_sampler_states
- * directly. */
- return &ctx->sampler_state[miplevel * 2 + normalized];
-}
-
-static INLINE
-void *blitter_get_fs_col(struct blitter_context_priv *ctx, unsigned num_cbufs)
-{
- struct pipe_context *pipe = ctx->base.pipe;
-
- assert(num_cbufs <= PIPE_MAX_COLOR_BUFS);
-
- if (!ctx->fs_col[num_cbufs])
- ctx->fs_col[num_cbufs] =
- util_make_fragment_cloneinput_shader(pipe, num_cbufs,
- TGSI_SEMANTIC_GENERIC,
- TGSI_INTERPOLATE_LINEAR);
-
- return ctx->fs_col[num_cbufs];
-}
-
-/** Convert PIPE_TEXTURE_x to TGSI_TEXTURE_x */
-static unsigned
-pipe_tex_to_tgsi_tex(enum pipe_texture_target pipe_tex_target)
-{
- switch (pipe_tex_target) {
- case PIPE_TEXTURE_1D:
- return TGSI_TEXTURE_1D;
- case PIPE_TEXTURE_2D:
- return TGSI_TEXTURE_2D;
- case PIPE_TEXTURE_RECT:
- return TGSI_TEXTURE_RECT;
- case PIPE_TEXTURE_3D:
- return TGSI_TEXTURE_3D;
- case PIPE_TEXTURE_CUBE:
- return TGSI_TEXTURE_CUBE;
- default:
- assert(0 && "unexpected texture target");
- return TGSI_TEXTURE_UNKNOWN;
- }
-}
-
-
-static INLINE
-void *blitter_get_fs_texfetch_col(struct blitter_context_priv *ctx,
- unsigned tex_target)
-{
- struct pipe_context *pipe = ctx->base.pipe;
-
- assert(tex_target < PIPE_MAX_TEXTURE_TYPES);
-
- /* Create the fragment shader on-demand. */
- if (!ctx->fs_texfetch_col[tex_target]) {
- unsigned tgsi_tex = pipe_tex_to_tgsi_tex(tex_target);
-
- ctx->fs_texfetch_col[tex_target] =
- util_make_fragment_tex_shader(pipe, tgsi_tex, TGSI_INTERPOLATE_LINEAR);
- }
-
- return ctx->fs_texfetch_col[tex_target];
-}
-
-static INLINE
-void *blitter_get_fs_texfetch_depth(struct blitter_context_priv *ctx,
- unsigned tex_target)
-{
- struct pipe_context *pipe = ctx->base.pipe;
-
- assert(tex_target < PIPE_MAX_TEXTURE_TYPES);
-
- /* Create the fragment shader on-demand. */
- if (!ctx->fs_texfetch_depth[tex_target]) {
- unsigned tgsi_tex = pipe_tex_to_tgsi_tex(tex_target);
-
- ctx->fs_texfetch_depth[tex_target] =
- util_make_fragment_tex_shader_writedepth(pipe, tgsi_tex,
- TGSI_INTERPOLATE_LINEAR);
- }
-
- return ctx->fs_texfetch_depth[tex_target];
-}
-
-static void blitter_draw_rectangle(struct blitter_context *blitter,
- unsigned x1, unsigned y1,
- unsigned x2, unsigned y2,
- float depth,
- enum blitter_attrib_type type,
- const float attrib[4])
-{
- struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter;
-
- switch (type) {
- case UTIL_BLITTER_ATTRIB_COLOR:
- blitter_set_clear_color(ctx, attrib);
- break;
-
- case UTIL_BLITTER_ATTRIB_TEXCOORD:
- set_texcoords_in_vertices(attrib, &ctx->vertices[0][1][0], 8);
- break;
-
- default:;
- }
-
- blitter_set_rectangle(ctx, x1, y1, x2, y2, depth);
- ctx->base.pipe->redefine_user_buffer(ctx->base.pipe, ctx->vbuf,
- 0, ctx->vbuf->width0);
- util_draw_vertex_buffer(ctx->base.pipe, NULL, ctx->vbuf, 0,
- PIPE_PRIM_TRIANGLE_FAN, 4, 2);
-}
-
-static void util_blitter_clear_custom(struct blitter_context *blitter,
- unsigned width, unsigned height,
- unsigned num_cbufs,
- unsigned clear_buffers,
- const float *rgba,
- double depth, unsigned stencil,
- void *custom_blend, void *custom_dsa)
-{
- struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter;
- struct pipe_context *pipe = ctx->base.pipe;
- struct pipe_stencil_ref sr = { { 0 } };
-
- assert(num_cbufs <= PIPE_MAX_COLOR_BUFS);
-
- blitter_check_saved_CSOs(ctx);
-
- /* bind CSOs */
- if (custom_blend) {
- pipe->bind_blend_state(pipe, custom_blend);
- } else if (clear_buffers & PIPE_CLEAR_COLOR) {
- pipe->bind_blend_state(pipe, ctx->blend_write_color);
- } else {
- pipe->bind_blend_state(pipe, ctx->blend_keep_color);
- }
-
- if (custom_dsa) {
- pipe->bind_depth_stencil_alpha_state(pipe, custom_dsa);
- } else if ((clear_buffers & PIPE_CLEAR_DEPTHSTENCIL) == PIPE_CLEAR_DEPTHSTENCIL) {
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_stencil);
- } else if (clear_buffers & PIPE_CLEAR_DEPTH) {
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_keep_stencil);
- } else if (clear_buffers & PIPE_CLEAR_STENCIL) {
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_write_stencil);
- } else {
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil);
- }
-
- sr.ref_value[0] = stencil & 0xff;
- pipe->set_stencil_ref(pipe, &sr);
-
- pipe->bind_rasterizer_state(pipe, ctx->rs_state);
- pipe->bind_vertex_elements_state(pipe, ctx->velem_state);
- pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, num_cbufs));
- pipe->bind_vs_state(pipe, ctx->vs);
-
- blitter_set_dst_dimensions(ctx, width, height);
- blitter->draw_rectangle(blitter, 0, 0, width, height, depth,
- UTIL_BLITTER_ATTRIB_COLOR, rgba);
- blitter_restore_CSOs(ctx);
-}
-
-void util_blitter_clear(struct blitter_context *blitter,
- unsigned width, unsigned height,
- unsigned num_cbufs,
- unsigned clear_buffers,
- const float *rgba,
- double depth, unsigned stencil)
-{
- util_blitter_clear_custom(blitter, width, height, num_cbufs,
- clear_buffers, rgba, depth, stencil,
- NULL, NULL);
-}
-
-void util_blitter_clear_depth_custom(struct blitter_context *blitter,
- unsigned width, unsigned height,
- double depth, void *custom_dsa)
-{
- const float rgba[4] = {0, 0, 0, 0};
- util_blitter_clear_custom(blitter, width, height, 0,
- 0, rgba, depth, 0, NULL, custom_dsa);
-}
-
-static
-boolean is_overlap(unsigned sx1, unsigned sx2, unsigned sy1, unsigned sy2,
- unsigned dx1, unsigned dx2, unsigned dy1, unsigned dy2)
-{
- return sx1 < dx2 && sx2 > dx1 && sy1 < dy2 && sy2 > dy1;
-}
-
-void util_blitter_copy_region(struct blitter_context *blitter,
- struct pipe_resource *dst,
- unsigned dstlevel,
- unsigned dstx, unsigned dsty, unsigned dstz,
- struct pipe_resource *src,
- unsigned srclevel,
- const struct pipe_box *srcbox,
- boolean ignore_stencil)
-{
- struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter;
- struct pipe_context *pipe = ctx->base.pipe;
- struct pipe_screen *screen = pipe->screen;
- struct pipe_surface *dstsurf, surf_templ;
- struct pipe_framebuffer_state fb_state;
- struct pipe_sampler_view viewTempl, *view;
- unsigned bind;
- unsigned width = srcbox->width;
- unsigned height = srcbox->height;
- boolean is_stencil, is_depth;
- boolean normalized;
-
- /* Give up if textures are not set. */
- assert(dst && src);
- if (!dst || !src)
- return;
-
- /* Sanity checks. */
- if (dst == src) {
- assert(!is_overlap(srcbox->x, srcbox->x + width, srcbox->y, srcbox->y + height,
- dstx, dstx + width, dsty, dsty + height));
- }
- assert(src->target < PIPE_MAX_TEXTURE_TYPES);
- /* XXX should handle 3d regions */
- assert(srcbox->depth == 1);
-
- /* Is this a ZS format? */
- is_depth = util_format_get_component_bits(src->format, UTIL_FORMAT_COLORSPACE_ZS, 0) != 0;
- is_stencil = util_format_get_component_bits(src->format, UTIL_FORMAT_COLORSPACE_ZS, 1) != 0;
-
- if (is_depth || is_stencil)
- bind = PIPE_BIND_DEPTH_STENCIL;
- else
- bind = PIPE_BIND_RENDER_TARGET;
-
- /* Check if we can sample from and render to the surfaces. */
- /* (assuming copying a stencil buffer is not possible) */
- if ((!ignore_stencil && is_stencil) ||
- !screen->is_format_supported(screen, dst->format, dst->target,
- dst->nr_samples, bind) ||
- !screen->is_format_supported(screen, src->format, src->target,
- src->nr_samples, PIPE_BIND_SAMPLER_VIEW)) {
- ctx->base.running = TRUE;
- util_resource_copy_region(pipe, dst, dstlevel, dstx, dsty, dstz,
- src, srclevel, srcbox);
- ctx->base.running = FALSE;
- return;
- }
-
- /* Get surface. */
- memset(&surf_templ, 0, sizeof(surf_templ));
- u_surface_default_template(&surf_templ, dst, bind);
- surf_templ.format = util_format_linear(dst->format);
- surf_templ.u.tex.level = dstlevel;
- surf_templ.u.tex.first_layer = dstz;
- surf_templ.u.tex.last_layer = dstz;
- dstsurf = pipe->create_surface(pipe, dst, &surf_templ);
-
- /* Check whether the states are properly saved. */
- blitter_check_saved_CSOs(ctx);
- assert(blitter->saved_fb_state.nr_cbufs != ~0);
- assert(blitter->saved_num_sampler_views != ~0);
- assert(blitter->saved_num_sampler_states != ~0);
-
- /* Initialize framebuffer state. */
- fb_state.width = dstsurf->width;
- fb_state.height = dstsurf->height;
-
- if (is_depth) {
- pipe->bind_blend_state(pipe, ctx->blend_keep_color);
- pipe->bind_depth_stencil_alpha_state(pipe,
- ctx->dsa_write_depth_keep_stencil);
- pipe->bind_fs_state(pipe,
- blitter_get_fs_texfetch_depth(ctx, src->target));
-
- fb_state.nr_cbufs = 0;
- fb_state.zsbuf = dstsurf;
- } else {
- pipe->bind_blend_state(pipe, ctx->blend_write_color);
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil);
- pipe->bind_fs_state(pipe,
- blitter_get_fs_texfetch_col(ctx, src->target));
-
- fb_state.nr_cbufs = 1;
- fb_state.cbufs[0] = dstsurf;
- fb_state.zsbuf = 0;
- }
-
- normalized = src->target != PIPE_TEXTURE_RECT;
-
- /* Initialize sampler view. */
- u_sampler_view_default_template(&viewTempl, src, util_format_linear(src->format));
- view = pipe->create_sampler_view(pipe, src, &viewTempl);
-
- /* Set rasterizer state, shaders, and textures. */
- pipe->bind_rasterizer_state(pipe, ctx->rs_state);
- pipe->bind_vs_state(pipe, ctx->vs);
- pipe->bind_fragment_sampler_states(pipe, 1,
- blitter_get_sampler_state(ctx, srclevel, normalized));
- pipe->bind_vertex_elements_state(pipe, ctx->velem_state);
- pipe->set_fragment_sampler_views(pipe, 1, &view);
- pipe->set_framebuffer_state(pipe, &fb_state);
-
- blitter_set_dst_dimensions(ctx, dstsurf->width, dstsurf->height);
-
- switch (src->target) {
- /* Draw the quad with the draw_rectangle callback. */
- case PIPE_TEXTURE_1D:
- case PIPE_TEXTURE_2D:
- case PIPE_TEXTURE_RECT:
- {
- /* Set texture coordinates. */
- float coord[4];
- get_texcoords(src, srclevel, srcbox->x, srcbox->y,
- srcbox->x+width, srcbox->y+height, normalized, coord);
-
- /* Draw. */
- blitter->draw_rectangle(blitter, dstx, dsty, dstx+width, dsty+height, 0,
- UTIL_BLITTER_ATTRIB_TEXCOORD, coord);
- }
- break;
-
- /* Draw the quad with the generic codepath. */
- case PIPE_TEXTURE_3D:
- case PIPE_TEXTURE_CUBE:
- /* Set texture coordinates. */
- if (src->target == PIPE_TEXTURE_3D)
- blitter_set_texcoords_3d(ctx, src, srclevel, srcbox->z,
- srcbox->x, srcbox->y,
- srcbox->x + width, srcbox->y + height);
- else
- blitter_set_texcoords_cube(ctx, src, srclevel, srcbox->z,
- srcbox->x, srcbox->y,
- srcbox->x + width, srcbox->y + height);
-
- /* Draw. */
- blitter_set_rectangle(ctx, dstx, dsty, dstx+width, dsty+height, 0);
- ctx->base.pipe->redefine_user_buffer(ctx->base.pipe, ctx->vbuf,
- 0, ctx->vbuf->width0);
- util_draw_vertex_buffer(ctx->base.pipe, NULL, ctx->vbuf, 0,
- PIPE_PRIM_TRIANGLE_FAN, 4, 2);
- break;
-
- default:
- assert(0);
- return;
- }
-
- blitter_restore_CSOs(ctx);
-
- pipe_surface_reference(&dstsurf, NULL);
- pipe_sampler_view_reference(&view, NULL);
-}
-
-/* Clear a region of a color surface to a constant value. */
-void util_blitter_clear_render_target(struct blitter_context *blitter,
- struct pipe_surface *dstsurf,
- const float *rgba,
- unsigned dstx, unsigned dsty,
- unsigned width, unsigned height)
-{
- struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter;
- struct pipe_context *pipe = ctx->base.pipe;
- struct pipe_framebuffer_state fb_state;
-
- assert(dstsurf->texture);
- if (!dstsurf->texture)
- return;
-
- /* check the saved state */
- blitter_check_saved_CSOs(ctx);
- assert(blitter->saved_fb_state.nr_cbufs != ~0);
-
- /* bind CSOs */
- pipe->bind_blend_state(pipe, ctx->blend_write_color);
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil);
- pipe->bind_rasterizer_state(pipe, ctx->rs_state);
- pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, 1));
- pipe->bind_vs_state(pipe, ctx->vs);
- pipe->bind_vertex_elements_state(pipe, ctx->velem_state);
-
- /* set a framebuffer state */
- fb_state.width = dstsurf->width;
- fb_state.height = dstsurf->height;
- fb_state.nr_cbufs = 1;
- fb_state.cbufs[0] = dstsurf;
- fb_state.zsbuf = 0;
- pipe->set_framebuffer_state(pipe, &fb_state);
-
- blitter_set_dst_dimensions(ctx, dstsurf->width, dstsurf->height);
- blitter->draw_rectangle(blitter, dstx, dsty, dstx+width, dsty+height, 0,
- UTIL_BLITTER_ATTRIB_COLOR, rgba);
- blitter_restore_CSOs(ctx);
-}
-
-/* Clear a region of a depth stencil surface. */
-void util_blitter_clear_depth_stencil(struct blitter_context *blitter,
- struct pipe_surface *dstsurf,
- unsigned clear_flags,
- double depth,
- unsigned stencil,
- unsigned dstx, unsigned dsty,
- unsigned width, unsigned height)
-{
- struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter;
- struct pipe_context *pipe = ctx->base.pipe;
- struct pipe_framebuffer_state fb_state;
- struct pipe_stencil_ref sr = { { 0 } };
-
- assert(dstsurf->texture);
- if (!dstsurf->texture)
- return;
-
- /* check the saved state */
- blitter_check_saved_CSOs(ctx);
- assert(blitter->saved_fb_state.nr_cbufs != ~0);
-
- /* bind CSOs */
- pipe->bind_blend_state(pipe, ctx->blend_keep_color);
- if ((clear_flags & PIPE_CLEAR_DEPTHSTENCIL) == PIPE_CLEAR_DEPTHSTENCIL) {
- sr.ref_value[0] = stencil & 0xff;
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_stencil);
- pipe->set_stencil_ref(pipe, &sr);
- }
- else if (clear_flags & PIPE_CLEAR_DEPTH) {
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_keep_stencil);
- }
- else if (clear_flags & PIPE_CLEAR_STENCIL) {
- sr.ref_value[0] = stencil & 0xff;
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_write_stencil);
- pipe->set_stencil_ref(pipe, &sr);
- }
- else
- /* hmm that should be illegal probably, or make it a no-op somewhere */
- pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil);
-
- pipe->bind_rasterizer_state(pipe, ctx->rs_state);
- pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, 0));
- pipe->bind_vs_state(pipe, ctx->vs);
- pipe->bind_vertex_elements_state(pipe, ctx->velem_state);
-
- /* set a framebuffer state */
- fb_state.width = dstsurf->width;
- fb_state.height = dstsurf->height;
- fb_state.nr_cbufs = 0;
- fb_state.cbufs[0] = 0;
- fb_state.zsbuf = dstsurf;
- pipe->set_framebuffer_state(pipe, &fb_state);
-
- blitter_set_dst_dimensions(ctx, dstsurf->width, dstsurf->height);
- blitter->draw_rectangle(blitter, dstx, dsty, dstx+width, dsty+height, depth,
- UTIL_BLITTER_ATTRIB_NONE, NULL);
- blitter_restore_CSOs(ctx);
-}
-
-/* draw a rectangle across a region using a custom dsa stage - for r600g */
-void util_blitter_custom_depth_stencil(struct blitter_context *blitter,
- struct pipe_surface *zsurf,
- struct pipe_surface *cbsurf,
- void *dsa_stage, float depth)
-{
- struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter;
- struct pipe_context *pipe = ctx->base.pipe;
- struct pipe_framebuffer_state fb_state;
-
- assert(zsurf->texture);
- if (!zsurf->texture)
- return;
-
- /* check the saved state */
- blitter_check_saved_CSOs(ctx);
- assert(blitter->saved_fb_state.nr_cbufs != ~0);
-
- /* bind CSOs */
- pipe->bind_blend_state(pipe, ctx->blend_write_color);
- pipe->bind_depth_stencil_alpha_state(pipe, dsa_stage);
-
- pipe->bind_rasterizer_state(pipe, ctx->rs_state);
- pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, 0));
- pipe->bind_vs_state(pipe, ctx->vs);
- pipe->bind_vertex_elements_state(pipe, ctx->velem_state);
-
- /* set a framebuffer state */
- fb_state.width = zsurf->width;
- fb_state.height = zsurf->height;
- fb_state.nr_cbufs = 1;
- if (cbsurf) {
- fb_state.cbufs[0] = cbsurf;
- fb_state.nr_cbufs = 1;
- } else {
- fb_state.cbufs[0] = NULL;
- fb_state.nr_cbufs = 0;
- }
- fb_state.zsbuf = zsurf;
- pipe->set_framebuffer_state(pipe, &fb_state);
-
- blitter_set_dst_dimensions(ctx, zsurf->width, zsurf->height);
- blitter->draw_rectangle(blitter, 0, 0, zsurf->width, zsurf->height, depth,
- UTIL_BLITTER_ATTRIB_NONE, NULL);
- blitter_restore_CSOs(ctx);
-}
+/************************************************************************** + * + * Copyright 2009 Marek Olšák <maraeo@gmail.com> + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the + * "Software"), to deal in the Software without restriction, including + * without limitation the rights to use, copy, modify, merge, publish, + * distribute, sub license, and/or sell copies of the Software, and to + * permit persons to whom the Software is furnished to do so, subject to + * the following conditions: + * + * The above copyright notice and this permission notice (including the + * next paragraph) shall be included in all copies or substantial portions + * of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. + * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR + * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, + * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE + * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + * + **************************************************************************/ + +/** + * @file + * Blitter utility to facilitate acceleration of the clear, clear_render_target, clear_depth_stencil + * resource_copy_region functions. + * + * @author Marek Olšák + */ + +#include "pipe/p_context.h" +#include "pipe/p_defines.h" +#include "util/u_inlines.h" +#include "pipe/p_shader_tokens.h" +#include "pipe/p_state.h" + +#include "util/u_format.h" +#include "util/u_memory.h" +#include "util/u_math.h" +#include "util/u_blitter.h" +#include "util/u_draw_quad.h" +#include "util/u_sampler.h" +#include "util/u_simple_shaders.h" +#include "util/u_surface.h" +#include "util/u_texture.h" + +#define INVALID_PTR ((void*)~0) + +struct blitter_context_priv +{ + struct blitter_context base; + + struct pipe_resource *vbuf; /**< quad */ + + float vertices[4][2][4]; /**< {pos, color} or {pos, texcoord} */ + + /* Templates for various state objects. */ + struct pipe_sampler_state template_sampler_state; + + /* Constant state objects. */ + /* Vertex shaders. */ + void *vs; /**< Vertex shader which passes {pos, generic} to the output.*/ + + /* Fragment shaders. */ + /* The shader at index i outputs color to color buffers 0,1,...,i-1. */ + void *fs_col[PIPE_MAX_COLOR_BUFS+1]; + + /* FS which outputs a color from a texture, + where the index is PIPE_TEXTURE_* to be sampled. */ + void *fs_texfetch_col[PIPE_MAX_TEXTURE_TYPES]; + + /* FS which outputs a depth from a texture, + where the index is PIPE_TEXTURE_* to be sampled. */ + void *fs_texfetch_depth[PIPE_MAX_TEXTURE_TYPES]; + + /* Blend state. */ + void *blend_write_color; /**< blend state with writemask of RGBA */ + void *blend_keep_color; /**< blend state with writemask of 0 */ + + /* Depth stencil alpha state. */ + void *dsa_write_depth_stencil; + void *dsa_write_depth_keep_stencil; + void *dsa_keep_depth_stencil; + void *dsa_keep_depth_write_stencil; + + void *velem_state; + + /* Sampler state for clamping to a miplevel. */ + void *sampler_state[PIPE_MAX_TEXTURE_LEVELS * 2]; + + /* Rasterizer state. */ + void *rs_state; + + /* Viewport state. */ + struct pipe_viewport_state viewport; + + /* Clip state. */ + struct pipe_clip_state clip; + + /* Destination surface dimensions. */ + unsigned dst_width; + unsigned dst_height; +}; + +static void blitter_draw_rectangle(struct blitter_context *blitter, + unsigned x, unsigned y, + unsigned width, unsigned height, + float depth, + enum blitter_attrib_type type, + const float attrib[4]); + + +struct blitter_context *util_blitter_create(struct pipe_context *pipe) +{ + struct blitter_context_priv *ctx; + struct pipe_blend_state blend; + struct pipe_depth_stencil_alpha_state dsa; + struct pipe_rasterizer_state rs_state; + struct pipe_sampler_state *sampler_state; + struct pipe_vertex_element velem[2]; + unsigned i; + + ctx = CALLOC_STRUCT(blitter_context_priv); + if (!ctx) + return NULL; + + ctx->base.pipe = pipe; + ctx->base.draw_rectangle = blitter_draw_rectangle; + + /* init state objects for them to be considered invalid */ + ctx->base.saved_blend_state = INVALID_PTR; + ctx->base.saved_dsa_state = INVALID_PTR; + ctx->base.saved_rs_state = INVALID_PTR; + ctx->base.saved_fs = INVALID_PTR; + ctx->base.saved_vs = INVALID_PTR; + ctx->base.saved_velem_state = INVALID_PTR; + ctx->base.saved_fb_state.nr_cbufs = ~0; + ctx->base.saved_num_sampler_views = ~0; + ctx->base.saved_num_sampler_states = ~0; + ctx->base.saved_num_vertex_buffers = ~0; + + /* blend state objects */ + memset(&blend, 0, sizeof(blend)); + ctx->blend_keep_color = pipe->create_blend_state(pipe, &blend); + + blend.rt[0].colormask = PIPE_MASK_RGBA; + ctx->blend_write_color = pipe->create_blend_state(pipe, &blend); + + /* depth stencil alpha state objects */ + memset(&dsa, 0, sizeof(dsa)); + ctx->dsa_keep_depth_stencil = + pipe->create_depth_stencil_alpha_state(pipe, &dsa); + + dsa.depth.enabled = 1; + dsa.depth.writemask = 1; + dsa.depth.func = PIPE_FUNC_ALWAYS; + ctx->dsa_write_depth_keep_stencil = + pipe->create_depth_stencil_alpha_state(pipe, &dsa); + + dsa.stencil[0].enabled = 1; + dsa.stencil[0].func = PIPE_FUNC_ALWAYS; + dsa.stencil[0].fail_op = PIPE_STENCIL_OP_REPLACE; + dsa.stencil[0].zpass_op = PIPE_STENCIL_OP_REPLACE; + dsa.stencil[0].zfail_op = PIPE_STENCIL_OP_REPLACE; + dsa.stencil[0].valuemask = 0xff; + dsa.stencil[0].writemask = 0xff; + ctx->dsa_write_depth_stencil = + pipe->create_depth_stencil_alpha_state(pipe, &dsa); + + + dsa.depth.enabled = 0; + dsa.depth.writemask = 0; + ctx->dsa_keep_depth_write_stencil = + pipe->create_depth_stencil_alpha_state(pipe, &dsa); + + /* sampler state */ + sampler_state = &ctx->template_sampler_state; + sampler_state->wrap_s = PIPE_TEX_WRAP_CLAMP_TO_EDGE; + sampler_state->wrap_t = PIPE_TEX_WRAP_CLAMP_TO_EDGE; + sampler_state->wrap_r = PIPE_TEX_WRAP_CLAMP_TO_EDGE; + sampler_state->normalized_coords = TRUE; + /* The sampler state objects which sample from a specified mipmap level + * are created on-demand. */ + + /* rasterizer state */ + memset(&rs_state, 0, sizeof(rs_state)); + rs_state.cull_face = PIPE_FACE_NONE; + rs_state.gl_rasterization_rules = 1; + rs_state.flatshade = 1; + ctx->rs_state = pipe->create_rasterizer_state(pipe, &rs_state); + + /* vertex elements state */ + memset(&velem[0], 0, sizeof(velem[0]) * 2); + for (i = 0; i < 2; i++) { + velem[i].src_offset = i * 4 * sizeof(float); + velem[i].instance_divisor = 0; + velem[i].vertex_buffer_index = 0; + velem[i].src_format = PIPE_FORMAT_R32G32B32A32_FLOAT; + } + ctx->velem_state = pipe->create_vertex_elements_state(pipe, 2, &velem[0]); + + /* fragment shaders are created on-demand */ + + /* vertex shader */ + { + const uint semantic_names[] = { TGSI_SEMANTIC_POSITION, + TGSI_SEMANTIC_GENERIC }; + const uint semantic_indices[] = { 0, 0 }; + ctx->vs = + util_make_vertex_passthrough_shader(pipe, 2, semantic_names, + semantic_indices); + } + + /* set invariant vertex coordinates */ + for (i = 0; i < 4; i++) + ctx->vertices[i][0][3] = 1; /*v.w*/ + + /* create the vertex buffer */ + ctx->vbuf = pipe_user_buffer_create(ctx->base.pipe->screen, + ctx->vertices, + sizeof(ctx->vertices), + PIPE_BIND_VERTEX_BUFFER); + + return &ctx->base; +} + +void util_blitter_destroy(struct blitter_context *blitter) +{ + struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter; + struct pipe_context *pipe = blitter->pipe; + int i; + + pipe->delete_blend_state(pipe, ctx->blend_write_color); + pipe->delete_blend_state(pipe, ctx->blend_keep_color); + pipe->delete_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil); + pipe->delete_depth_stencil_alpha_state(pipe, + ctx->dsa_write_depth_keep_stencil); + pipe->delete_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_stencil); + pipe->delete_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_write_stencil); + + pipe->delete_rasterizer_state(pipe, ctx->rs_state); + pipe->delete_vs_state(pipe, ctx->vs); + pipe->delete_vertex_elements_state(pipe, ctx->velem_state); + + for (i = 0; i < PIPE_MAX_TEXTURE_TYPES; i++) { + if (ctx->fs_texfetch_col[i]) + pipe->delete_fs_state(pipe, ctx->fs_texfetch_col[i]); + if (ctx->fs_texfetch_depth[i]) + pipe->delete_fs_state(pipe, ctx->fs_texfetch_depth[i]); + } + + for (i = 0; i <= PIPE_MAX_COLOR_BUFS; i++) + if (ctx->fs_col[i]) + pipe->delete_fs_state(pipe, ctx->fs_col[i]); + + for (i = 0; i < PIPE_MAX_TEXTURE_LEVELS * 2; i++) + if (ctx->sampler_state[i]) + pipe->delete_sampler_state(pipe, ctx->sampler_state[i]); + + pipe_resource_reference(&ctx->vbuf, NULL); + FREE(ctx); +} + +static void blitter_check_saved_CSOs(struct blitter_context_priv *ctx) +{ + if (ctx->base.running) { + _debug_printf("u_blitter: Caught recursion on save. " + "This is a driver bug.\n"); + } + ctx->base.running = TRUE; + + /* make sure these CSOs have been saved */ + assert(ctx->base.saved_blend_state != INVALID_PTR && + ctx->base.saved_dsa_state != INVALID_PTR && + ctx->base.saved_rs_state != INVALID_PTR && + ctx->base.saved_fs != INVALID_PTR && + ctx->base.saved_vs != INVALID_PTR && + ctx->base.saved_velem_state != INVALID_PTR); +} + +static void blitter_restore_CSOs(struct blitter_context_priv *ctx) +{ + struct pipe_context *pipe = ctx->base.pipe; + unsigned i; + + /* restore the state objects which are always required to be saved */ + pipe->bind_blend_state(pipe, ctx->base.saved_blend_state); + pipe->bind_depth_stencil_alpha_state(pipe, ctx->base.saved_dsa_state); + pipe->bind_rasterizer_state(pipe, ctx->base.saved_rs_state); + pipe->bind_fs_state(pipe, ctx->base.saved_fs); + pipe->bind_vs_state(pipe, ctx->base.saved_vs); + pipe->bind_vertex_elements_state(pipe, ctx->base.saved_velem_state); + + ctx->base.saved_blend_state = INVALID_PTR; + ctx->base.saved_dsa_state = INVALID_PTR; + ctx->base.saved_rs_state = INVALID_PTR; + ctx->base.saved_fs = INVALID_PTR; + ctx->base.saved_vs = INVALID_PTR; + ctx->base.saved_velem_state = INVALID_PTR; + + pipe->set_stencil_ref(pipe, &ctx->base.saved_stencil_ref); + pipe->set_viewport_state(pipe, &ctx->base.saved_viewport); + pipe->set_clip_state(pipe, &ctx->base.saved_clip); + + /* restore the state objects which are required to be saved before copy/fill + */ + if (ctx->base.saved_fb_state.nr_cbufs != ~0) { + pipe->set_framebuffer_state(pipe, &ctx->base.saved_fb_state); + util_unreference_framebuffer_state(&ctx->base.saved_fb_state); + ctx->base.saved_fb_state.nr_cbufs = ~0; + } + + if (ctx->base.saved_num_sampler_states != ~0) { + pipe->bind_fragment_sampler_states(pipe, + ctx->base.saved_num_sampler_states, + ctx->base.saved_sampler_states); + ctx->base.saved_num_sampler_states = ~0; + } + + if (ctx->base.saved_num_sampler_views != ~0) { + pipe->set_fragment_sampler_views(pipe, + ctx->base.saved_num_sampler_views, + ctx->base.saved_sampler_views); + + for (i = 0; i < ctx->base.saved_num_sampler_views; i++) + pipe_sampler_view_reference(&ctx->base.saved_sampler_views[i], + NULL); + + ctx->base.saved_num_sampler_views = ~0; + } + + if (ctx->base.saved_num_vertex_buffers != ~0) { + pipe->set_vertex_buffers(pipe, + ctx->base.saved_num_vertex_buffers, + ctx->base.saved_vertex_buffers); + + for (i = 0; i < ctx->base.saved_num_vertex_buffers; i++) { + if (ctx->base.saved_vertex_buffers[i].buffer) { + pipe_resource_reference(&ctx->base.saved_vertex_buffers[i].buffer, + NULL); + } + } + ctx->base.saved_num_vertex_buffers = ~0; + } + + if (!ctx->base.running) { + _debug_printf("u_blitter: Caught recursion on restore. " + "This is a driver bug.\n"); + } + ctx->base.running = FALSE; +} + +static void blitter_set_rectangle(struct blitter_context_priv *ctx, + unsigned x1, unsigned y1, + unsigned x2, unsigned y2, + float depth) +{ + int i; + + /* set vertex positions */ + ctx->vertices[0][0][0] = (float)x1 / ctx->dst_width * 2.0f - 1.0f; /*v0.x*/ + ctx->vertices[0][0][1] = (float)y1 / ctx->dst_height * 2.0f - 1.0f; /*v0.y*/ + + ctx->vertices[1][0][0] = (float)x2 / ctx->dst_width * 2.0f - 1.0f; /*v1.x*/ + ctx->vertices[1][0][1] = (float)y1 / ctx->dst_height * 2.0f - 1.0f; /*v1.y*/ + + ctx->vertices[2][0][0] = (float)x2 / ctx->dst_width * 2.0f - 1.0f; /*v2.x*/ + ctx->vertices[2][0][1] = (float)y2 / ctx->dst_height * 2.0f - 1.0f; /*v2.y*/ + + ctx->vertices[3][0][0] = (float)x1 / ctx->dst_width * 2.0f - 1.0f; /*v3.x*/ + ctx->vertices[3][0][1] = (float)y2 / ctx->dst_height * 2.0f - 1.0f; /*v3.y*/ + + for (i = 0; i < 4; i++) + ctx->vertices[i][0][2] = depth; /*z*/ + + /* viewport */ + ctx->viewport.scale[0] = 0.5f * ctx->dst_width; + ctx->viewport.scale[1] = 0.5f * ctx->dst_height; + ctx->viewport.scale[2] = 1.0f; + ctx->viewport.scale[3] = 1.0f; + ctx->viewport.translate[0] = 0.5f * ctx->dst_width; + ctx->viewport.translate[1] = 0.5f * ctx->dst_height; + ctx->viewport.translate[2] = 0.0f; + ctx->viewport.translate[3] = 0.0f; + ctx->base.pipe->set_viewport_state(ctx->base.pipe, &ctx->viewport); + + /* clip */ + ctx->base.pipe->set_clip_state(ctx->base.pipe, &ctx->clip); +} + +static void blitter_set_clear_color(struct blitter_context_priv *ctx, + const float *rgba) +{ + int i; + + if (rgba) { + for (i = 0; i < 4; i++) { + ctx->vertices[i][1][0] = rgba[0]; + ctx->vertices[i][1][1] = rgba[1]; + ctx->vertices[i][1][2] = rgba[2]; + ctx->vertices[i][1][3] = rgba[3]; + } + } else { + for (i = 0; i < 4; i++) { + ctx->vertices[i][1][0] = 0; + ctx->vertices[i][1][1] = 0; + ctx->vertices[i][1][2] = 0; + ctx->vertices[i][1][3] = 0; + } + } +} + +static void get_texcoords(struct pipe_resource *src, + unsigned level, + unsigned x1, unsigned y1, + unsigned x2, unsigned y2, + boolean normalized, float out[4]) +{ + if(normalized) + { + out[0] = x1 / (float)u_minify(src->width0, level); + out[1] = y1 / (float)u_minify(src->height0, level); + out[2] = x2 / (float)u_minify(src->width0, level); + out[3] = y2 / (float)u_minify(src->height0, level); + } + else + { + out[0] = x1; + out[1] = y1; + out[2] = x2; + out[3] = y2; + } +} + +static void set_texcoords_in_vertices(const float coord[4], + float *out, unsigned stride) +{ + out[0] = coord[0]; /*t0.s*/ + out[1] = coord[1]; /*t0.t*/ + out += stride; + out[0] = coord[2]; /*t1.s*/ + out[1] = coord[1]; /*t1.t*/ + out += stride; + out[0] = coord[2]; /*t2.s*/ + out[1] = coord[3]; /*t2.t*/ + out += stride; + out[0] = coord[0]; /*t3.s*/ + out[1] = coord[3]; /*t3.t*/ +} + +static void blitter_set_texcoords_2d(struct blitter_context_priv *ctx, + struct pipe_resource *src, + unsigned level, + unsigned x1, unsigned y1, + unsigned x2, unsigned y2) +{ + unsigned i; + float coord[4]; + + get_texcoords(src, level, x1, y1, x2, y2, TRUE, coord); + set_texcoords_in_vertices(coord, &ctx->vertices[0][1][0], 8); + + for (i = 0; i < 4; i++) { + ctx->vertices[i][1][2] = 0; /*r*/ + ctx->vertices[i][1][3] = 1; /*q*/ + } +} + +static void blitter_set_texcoords_3d(struct blitter_context_priv *ctx, + struct pipe_resource *src, + unsigned level, + unsigned zslice, + unsigned x1, unsigned y1, + unsigned x2, unsigned y2) +{ + int i; + float r = zslice / (float)u_minify(src->depth0, level); + + blitter_set_texcoords_2d(ctx, src, level, x1, y1, x2, y2); + + for (i = 0; i < 4; i++) + ctx->vertices[i][1][2] = r; /*r*/ +} + +static void blitter_set_texcoords_cube(struct blitter_context_priv *ctx, + struct pipe_resource *src, + unsigned level, unsigned face, + unsigned x1, unsigned y1, + unsigned x2, unsigned y2) +{ + int i; + float coord[4]; + float st[4][2]; + + get_texcoords(src, level, x1, y1, x2, y2, TRUE, coord); + set_texcoords_in_vertices(coord, &st[0][0], 2); + + util_map_texcoords2d_onto_cubemap(face, + /* pointer, stride in floats */ + &st[0][0], 2, + &ctx->vertices[0][1][0], 8); + + for (i = 0; i < 4; i++) + ctx->vertices[i][1][3] = 1; /*q*/ +} + +static void blitter_set_dst_dimensions(struct blitter_context_priv *ctx, + unsigned width, unsigned height) +{ + ctx->dst_width = width; + ctx->dst_height = height; +} + +static INLINE +void **blitter_get_sampler_state(struct blitter_context_priv *ctx, + int miplevel, boolean normalized) +{ + struct pipe_context *pipe = ctx->base.pipe; + struct pipe_sampler_state *sampler_state = &ctx->template_sampler_state; + + assert(miplevel < PIPE_MAX_TEXTURE_LEVELS); + + /* Create the sampler state on-demand. */ + if (!ctx->sampler_state[miplevel * 2 + normalized]) { + sampler_state->lod_bias = miplevel; + sampler_state->min_lod = miplevel; + sampler_state->max_lod = miplevel; + sampler_state->normalized_coords = normalized; + + ctx->sampler_state[miplevel * 2 + normalized] = pipe->create_sampler_state(pipe, + sampler_state); + } + + /* Return void** so that it can be passed to bind_fragment_sampler_states + * directly. */ + return &ctx->sampler_state[miplevel * 2 + normalized]; +} + +static INLINE +void *blitter_get_fs_col(struct blitter_context_priv *ctx, unsigned num_cbufs) +{ + struct pipe_context *pipe = ctx->base.pipe; + + assert(num_cbufs <= PIPE_MAX_COLOR_BUFS); + + if (!ctx->fs_col[num_cbufs]) + ctx->fs_col[num_cbufs] = + util_make_fragment_cloneinput_shader(pipe, num_cbufs, + TGSI_SEMANTIC_GENERIC, + TGSI_INTERPOLATE_LINEAR); + + return ctx->fs_col[num_cbufs]; +} + +/** Convert PIPE_TEXTURE_x to TGSI_TEXTURE_x */ +static unsigned +pipe_tex_to_tgsi_tex(enum pipe_texture_target pipe_tex_target) +{ + switch (pipe_tex_target) { + case PIPE_TEXTURE_1D: + return TGSI_TEXTURE_1D; + case PIPE_TEXTURE_2D: + return TGSI_TEXTURE_2D; + case PIPE_TEXTURE_RECT: + return TGSI_TEXTURE_RECT; + case PIPE_TEXTURE_3D: + return TGSI_TEXTURE_3D; + case PIPE_TEXTURE_CUBE: + return TGSI_TEXTURE_CUBE; + default: + assert(0 && "unexpected texture target"); + return TGSI_TEXTURE_UNKNOWN; + } +} + + +static INLINE +void *blitter_get_fs_texfetch_col(struct blitter_context_priv *ctx, + unsigned tex_target) +{ + struct pipe_context *pipe = ctx->base.pipe; + + assert(tex_target < PIPE_MAX_TEXTURE_TYPES); + + /* Create the fragment shader on-demand. */ + if (!ctx->fs_texfetch_col[tex_target]) { + unsigned tgsi_tex = pipe_tex_to_tgsi_tex(tex_target); + + ctx->fs_texfetch_col[tex_target] = + util_make_fragment_tex_shader(pipe, tgsi_tex, TGSI_INTERPOLATE_LINEAR); + } + + return ctx->fs_texfetch_col[tex_target]; +} + +static INLINE +void *blitter_get_fs_texfetch_depth(struct blitter_context_priv *ctx, + unsigned tex_target) +{ + struct pipe_context *pipe = ctx->base.pipe; + + assert(tex_target < PIPE_MAX_TEXTURE_TYPES); + + /* Create the fragment shader on-demand. */ + if (!ctx->fs_texfetch_depth[tex_target]) { + unsigned tgsi_tex = pipe_tex_to_tgsi_tex(tex_target); + + ctx->fs_texfetch_depth[tex_target] = + util_make_fragment_tex_shader_writedepth(pipe, tgsi_tex, + TGSI_INTERPOLATE_LINEAR); + } + + return ctx->fs_texfetch_depth[tex_target]; +} + +static void blitter_draw_rectangle(struct blitter_context *blitter, + unsigned x1, unsigned y1, + unsigned x2, unsigned y2, + float depth, + enum blitter_attrib_type type, + const float attrib[4]) +{ + struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter; + + switch (type) { + case UTIL_BLITTER_ATTRIB_COLOR: + blitter_set_clear_color(ctx, attrib); + break; + + case UTIL_BLITTER_ATTRIB_TEXCOORD: + set_texcoords_in_vertices(attrib, &ctx->vertices[0][1][0], 8); + break; + + default:; + } + + blitter_set_rectangle(ctx, x1, y1, x2, y2, depth); + ctx->base.pipe->redefine_user_buffer(ctx->base.pipe, ctx->vbuf, + 0, ctx->vbuf->width0); + util_draw_vertex_buffer(ctx->base.pipe, NULL, ctx->vbuf, 0, + PIPE_PRIM_TRIANGLE_FAN, 4, 2); +} + +static void util_blitter_clear_custom(struct blitter_context *blitter, + unsigned width, unsigned height, + unsigned num_cbufs, + unsigned clear_buffers, + const float *rgba, + double depth, unsigned stencil, + void *custom_blend, void *custom_dsa) +{ + struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter; + struct pipe_context *pipe = ctx->base.pipe; + struct pipe_stencil_ref sr = { { 0 } }; + + assert(num_cbufs <= PIPE_MAX_COLOR_BUFS); + + blitter_check_saved_CSOs(ctx); + + /* bind CSOs */ + if (custom_blend) { + pipe->bind_blend_state(pipe, custom_blend); + } else if (clear_buffers & PIPE_CLEAR_COLOR) { + pipe->bind_blend_state(pipe, ctx->blend_write_color); + } else { + pipe->bind_blend_state(pipe, ctx->blend_keep_color); + } + + if (custom_dsa) { + pipe->bind_depth_stencil_alpha_state(pipe, custom_dsa); + } else if ((clear_buffers & PIPE_CLEAR_DEPTHSTENCIL) == PIPE_CLEAR_DEPTHSTENCIL) { + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_stencil); + } else if (clear_buffers & PIPE_CLEAR_DEPTH) { + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_keep_stencil); + } else if (clear_buffers & PIPE_CLEAR_STENCIL) { + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_write_stencil); + } else { + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil); + } + + sr.ref_value[0] = stencil & 0xff; + pipe->set_stencil_ref(pipe, &sr); + + pipe->bind_rasterizer_state(pipe, ctx->rs_state); + pipe->bind_vertex_elements_state(pipe, ctx->velem_state); + pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, num_cbufs)); + pipe->bind_vs_state(pipe, ctx->vs); + + blitter_set_dst_dimensions(ctx, width, height); + blitter->draw_rectangle(blitter, 0, 0, width, height, depth, + UTIL_BLITTER_ATTRIB_COLOR, rgba); + blitter_restore_CSOs(ctx); +} + +void util_blitter_clear(struct blitter_context *blitter, + unsigned width, unsigned height, + unsigned num_cbufs, + unsigned clear_buffers, + const float *rgba, + double depth, unsigned stencil) +{ + util_blitter_clear_custom(blitter, width, height, num_cbufs, + clear_buffers, rgba, depth, stencil, + NULL, NULL); +} + +void util_blitter_clear_depth_custom(struct blitter_context *blitter, + unsigned width, unsigned height, + double depth, void *custom_dsa) +{ + const float rgba[4] = {0, 0, 0, 0}; + util_blitter_clear_custom(blitter, width, height, 0, + 0, rgba, depth, 0, NULL, custom_dsa); +} + +static +boolean is_overlap(unsigned sx1, unsigned sx2, unsigned sy1, unsigned sy2, + unsigned dx1, unsigned dx2, unsigned dy1, unsigned dy2) +{ + return sx1 < dx2 && sx2 > dx1 && sy1 < dy2 && sy2 > dy1; +} + +void util_blitter_copy_region(struct blitter_context *blitter, + struct pipe_resource *dst, + unsigned dstlevel, + unsigned dstx, unsigned dsty, unsigned dstz, + struct pipe_resource *src, + unsigned srclevel, + const struct pipe_box *srcbox, + boolean ignore_stencil) +{ + struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter; + struct pipe_context *pipe = ctx->base.pipe; + struct pipe_screen *screen = pipe->screen; + struct pipe_surface *dstsurf, surf_templ; + struct pipe_framebuffer_state fb_state; + struct pipe_sampler_view viewTempl, *view; + unsigned bind; + unsigned width = srcbox->width; + unsigned height = srcbox->height; + boolean is_stencil, is_depth; + boolean normalized; + + /* Give up if textures are not set. */ + assert(dst && src); + if (!dst || !src) + return; + + /* Sanity checks. */ + if (dst == src) { + assert(!is_overlap(srcbox->x, srcbox->x + width, srcbox->y, srcbox->y + height, + dstx, dstx + width, dsty, dsty + height)); + } + assert(src->target < PIPE_MAX_TEXTURE_TYPES); + /* XXX should handle 3d regions */ + assert(srcbox->depth == 1); + + /* Is this a ZS format? */ + is_depth = util_format_get_component_bits(src->format, UTIL_FORMAT_COLORSPACE_ZS, 0) != 0; + is_stencil = util_format_get_component_bits(src->format, UTIL_FORMAT_COLORSPACE_ZS, 1) != 0; + + if (is_depth || is_stencil) + bind = PIPE_BIND_DEPTH_STENCIL; + else + bind = PIPE_BIND_RENDER_TARGET; + + /* Check if we can sample from and render to the surfaces. */ + /* (assuming copying a stencil buffer is not possible) */ + if ((!ignore_stencil && is_stencil) || + !screen->is_format_supported(screen, dst->format, dst->target, + dst->nr_samples, bind) || + !screen->is_format_supported(screen, src->format, src->target, + src->nr_samples, PIPE_BIND_SAMPLER_VIEW)) { + ctx->base.running = TRUE; + util_resource_copy_region(pipe, dst, dstlevel, dstx, dsty, dstz, + src, srclevel, srcbox); + ctx->base.running = FALSE; + return; + } + + /* Get surface. */ + memset(&surf_templ, 0, sizeof(surf_templ)); + u_surface_default_template(&surf_templ, dst, bind); + surf_templ.format = util_format_linear(dst->format); + surf_templ.u.tex.level = dstlevel; + surf_templ.u.tex.first_layer = dstz; + surf_templ.u.tex.last_layer = dstz; + dstsurf = pipe->create_surface(pipe, dst, &surf_templ); + + /* Check whether the states are properly saved. */ + blitter_check_saved_CSOs(ctx); + assert(blitter->saved_fb_state.nr_cbufs != ~0); + assert(blitter->saved_num_sampler_views != ~0); + assert(blitter->saved_num_sampler_states != ~0); + + /* Initialize framebuffer state. */ + fb_state.width = dstsurf->width; + fb_state.height = dstsurf->height; + + if (is_depth) { + pipe->bind_blend_state(pipe, ctx->blend_keep_color); + pipe->bind_depth_stencil_alpha_state(pipe, + ctx->dsa_write_depth_keep_stencil); + pipe->bind_fs_state(pipe, + blitter_get_fs_texfetch_depth(ctx, src->target)); + + fb_state.nr_cbufs = 0; + fb_state.zsbuf = dstsurf; + } else { + pipe->bind_blend_state(pipe, ctx->blend_write_color); + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil); + pipe->bind_fs_state(pipe, + blitter_get_fs_texfetch_col(ctx, src->target)); + + fb_state.nr_cbufs = 1; + fb_state.cbufs[0] = dstsurf; + fb_state.zsbuf = 0; + } + + normalized = src->target != PIPE_TEXTURE_RECT; + + /* Initialize sampler view. */ + u_sampler_view_default_template(&viewTempl, src, util_format_linear(src->format)); + view = pipe->create_sampler_view(pipe, src, &viewTempl); + + /* Set rasterizer state, shaders, and textures. */ + pipe->bind_rasterizer_state(pipe, ctx->rs_state); + pipe->bind_vs_state(pipe, ctx->vs); + pipe->bind_fragment_sampler_states(pipe, 1, + blitter_get_sampler_state(ctx, srclevel, normalized)); + pipe->bind_vertex_elements_state(pipe, ctx->velem_state); + pipe->set_fragment_sampler_views(pipe, 1, &view); + pipe->set_framebuffer_state(pipe, &fb_state); + + blitter_set_dst_dimensions(ctx, dstsurf->width, dstsurf->height); + + switch (src->target) { + /* Draw the quad with the draw_rectangle callback. */ + case PIPE_TEXTURE_1D: + case PIPE_TEXTURE_2D: + case PIPE_TEXTURE_RECT: + { + /* Set texture coordinates. */ + float coord[4]; + get_texcoords(src, srclevel, srcbox->x, srcbox->y, + srcbox->x+width, srcbox->y+height, normalized, coord); + + /* Draw. */ + blitter->draw_rectangle(blitter, dstx, dsty, dstx+width, dsty+height, 0, + UTIL_BLITTER_ATTRIB_TEXCOORD, coord); + } + break; + + /* Draw the quad with the generic codepath. */ + case PIPE_TEXTURE_3D: + case PIPE_TEXTURE_CUBE: + /* Set texture coordinates. */ + if (src->target == PIPE_TEXTURE_3D) + blitter_set_texcoords_3d(ctx, src, srclevel, srcbox->z, + srcbox->x, srcbox->y, + srcbox->x + width, srcbox->y + height); + else + blitter_set_texcoords_cube(ctx, src, srclevel, srcbox->z, + srcbox->x, srcbox->y, + srcbox->x + width, srcbox->y + height); + + /* Draw. */ + blitter_set_rectangle(ctx, dstx, dsty, dstx+width, dsty+height, 0); + ctx->base.pipe->redefine_user_buffer(ctx->base.pipe, ctx->vbuf, + 0, ctx->vbuf->width0); + util_draw_vertex_buffer(ctx->base.pipe, NULL, ctx->vbuf, 0, + PIPE_PRIM_TRIANGLE_FAN, 4, 2); + break; + + default: + assert(0); + return; + } + + blitter_restore_CSOs(ctx); + + pipe_surface_reference(&dstsurf, NULL); + pipe_sampler_view_reference(&view, NULL); +} + +/* Clear a region of a color surface to a constant value. */ +void util_blitter_clear_render_target(struct blitter_context *blitter, + struct pipe_surface *dstsurf, + const float *rgba, + unsigned dstx, unsigned dsty, + unsigned width, unsigned height) +{ + struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter; + struct pipe_context *pipe = ctx->base.pipe; + struct pipe_framebuffer_state fb_state; + + assert(dstsurf->texture); + if (!dstsurf->texture) + return; + + /* check the saved state */ + blitter_check_saved_CSOs(ctx); + assert(blitter->saved_fb_state.nr_cbufs != ~0); + + /* bind CSOs */ + pipe->bind_blend_state(pipe, ctx->blend_write_color); + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil); + pipe->bind_rasterizer_state(pipe, ctx->rs_state); + pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, 1)); + pipe->bind_vs_state(pipe, ctx->vs); + pipe->bind_vertex_elements_state(pipe, ctx->velem_state); + + /* set a framebuffer state */ + fb_state.width = dstsurf->width; + fb_state.height = dstsurf->height; + fb_state.nr_cbufs = 1; + fb_state.cbufs[0] = dstsurf; + fb_state.zsbuf = 0; + pipe->set_framebuffer_state(pipe, &fb_state); + + blitter_set_dst_dimensions(ctx, dstsurf->width, dstsurf->height); + blitter->draw_rectangle(blitter, dstx, dsty, dstx+width, dsty+height, 0, + UTIL_BLITTER_ATTRIB_COLOR, rgba); + blitter_restore_CSOs(ctx); +} + +/* Clear a region of a depth stencil surface. */ +void util_blitter_clear_depth_stencil(struct blitter_context *blitter, + struct pipe_surface *dstsurf, + unsigned clear_flags, + double depth, + unsigned stencil, + unsigned dstx, unsigned dsty, + unsigned width, unsigned height) +{ + struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter; + struct pipe_context *pipe = ctx->base.pipe; + struct pipe_framebuffer_state fb_state; + struct pipe_stencil_ref sr = { { 0 } }; + + assert(dstsurf->texture); + if (!dstsurf->texture) + return; + + /* check the saved state */ + blitter_check_saved_CSOs(ctx); + assert(blitter->saved_fb_state.nr_cbufs != ~0); + + /* bind CSOs */ + pipe->bind_blend_state(pipe, ctx->blend_keep_color); + if ((clear_flags & PIPE_CLEAR_DEPTHSTENCIL) == PIPE_CLEAR_DEPTHSTENCIL) { + sr.ref_value[0] = stencil & 0xff; + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_stencil); + pipe->set_stencil_ref(pipe, &sr); + } + else if (clear_flags & PIPE_CLEAR_DEPTH) { + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_write_depth_keep_stencil); + } + else if (clear_flags & PIPE_CLEAR_STENCIL) { + sr.ref_value[0] = stencil & 0xff; + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_write_stencil); + pipe->set_stencil_ref(pipe, &sr); + } + else + /* hmm that should be illegal probably, or make it a no-op somewhere */ + pipe->bind_depth_stencil_alpha_state(pipe, ctx->dsa_keep_depth_stencil); + + pipe->bind_rasterizer_state(pipe, ctx->rs_state); + pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, 0)); + pipe->bind_vs_state(pipe, ctx->vs); + pipe->bind_vertex_elements_state(pipe, ctx->velem_state); + + /* set a framebuffer state */ + fb_state.width = dstsurf->width; + fb_state.height = dstsurf->height; + fb_state.nr_cbufs = 0; + fb_state.cbufs[0] = 0; + fb_state.zsbuf = dstsurf; + pipe->set_framebuffer_state(pipe, &fb_state); + + blitter_set_dst_dimensions(ctx, dstsurf->width, dstsurf->height); + blitter->draw_rectangle(blitter, dstx, dsty, dstx+width, dsty+height, depth, + UTIL_BLITTER_ATTRIB_NONE, NULL); + blitter_restore_CSOs(ctx); +} + +/* draw a rectangle across a region using a custom dsa stage - for r600g */ +void util_blitter_custom_depth_stencil(struct blitter_context *blitter, + struct pipe_surface *zsurf, + struct pipe_surface *cbsurf, + void *dsa_stage, float depth) +{ + struct blitter_context_priv *ctx = (struct blitter_context_priv*)blitter; + struct pipe_context *pipe = ctx->base.pipe; + struct pipe_framebuffer_state fb_state; + + assert(zsurf->texture); + if (!zsurf->texture) + return; + + /* check the saved state */ + blitter_check_saved_CSOs(ctx); + assert(blitter->saved_fb_state.nr_cbufs != ~0); + + /* bind CSOs */ + pipe->bind_blend_state(pipe, ctx->blend_write_color); + pipe->bind_depth_stencil_alpha_state(pipe, dsa_stage); + + pipe->bind_rasterizer_state(pipe, ctx->rs_state); + pipe->bind_fs_state(pipe, blitter_get_fs_col(ctx, 0)); + pipe->bind_vs_state(pipe, ctx->vs); + pipe->bind_vertex_elements_state(pipe, ctx->velem_state); + + /* set a framebuffer state */ + fb_state.width = zsurf->width; + fb_state.height = zsurf->height; + fb_state.nr_cbufs = 1; + if (cbsurf) { + fb_state.cbufs[0] = cbsurf; + fb_state.nr_cbufs = 1; + } else { + fb_state.cbufs[0] = NULL; + fb_state.nr_cbufs = 0; + } + fb_state.zsbuf = zsurf; + pipe->set_framebuffer_state(pipe, &fb_state); + + blitter_set_dst_dimensions(ctx, zsurf->width, zsurf->height); + blitter->draw_rectangle(blitter, 0, 0, zsurf->width, zsurf->height, depth, + UTIL_BLITTER_ATTRIB_NONE, NULL); + blitter_restore_CSOs(ctx); +} diff --git a/mesalib/src/glsl/opt_discard_simplification.cpp b/mesalib/src/glsl/opt_discard_simplification.cpp index 37622eb02..a19947ddd 100644 --- a/mesalib/src/glsl/opt_discard_simplification.cpp +++ b/mesalib/src/glsl/opt_discard_simplification.cpp @@ -1,190 +1,204 @@ -/*
- * Copyright © 2010 Intel Corporation
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice (including the next
- * paragraph) shall be included in all copies or substantial portions of the
- * Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
- * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- * DEALINGS IN THE SOFTWARE.
- */
-
-/**
- * \file opt_discard_simplification.cpp
- *
- * This pass simplifies if-statements and loops containing unconditional
- * discards.
- *
- * Case 1: Both branches contain unconditional discards:
- * -----------------------------------------------------
- *
- * if (cond) {
- * s1;
- * discard;
- * s2;
- * } else {
- * s3;
- * discard;
- * s4;
- * }
- *
- * becomes:
- *
- * discard
- *
- * Case 2: The "then" clause contains an unconditional discard:
- * ------------------------------------------------------------
- *
- * if (cond) {
- * s1;
- * discard;
- * s2;
- * } else {
- * s3;
- * }
- *
- * becomes:
- *
- * if (cond) {
- * discard;
- * } else {
- * s3;
- * }
- *
- * Case 3: The "else" clause contains an unconditional discard:
- * ------------------------------------------------------------
- *
- * if (cond) {
- * s1;
- * } else {
- * s2;
- * discard;
- * s3;
- * }
- *
- * becomes:
- *
- * if (cond) {
- * s1;
- * } else {
- * discard;
- * }
- */
-
-#include "glsl_types.h"
-#include "ir.h"
-
-class discard_simplifier : public ir_hierarchical_visitor {
-public:
- discard_simplifier()
- {
- this->progress = false;
- }
-
- ir_visitor_status visit_enter(ir_if *);
- ir_visitor_status visit_enter(ir_loop *);
- ir_visitor_status visit_enter(ir_assignment *);
-
- bool progress;
-};
-
-static ir_discard *
-find_unconditional_discard(exec_list &instructions)
-{
- foreach_list(n, &instructions) {
- ir_discard *ir = ((ir_instruction *) n)->as_discard();
- if (ir != NULL && ir->condition == NULL)
- return ir;
- }
- return NULL;
-}
-
-static bool
-is_only_instruction(ir_discard *discard)
-{
- return (discard->prev->is_head_sentinel() &&
- discard->next->is_tail_sentinel());
-}
-
-/* We only care about the top level instructions, so don't descend
- * into expressions.
- */
-ir_visitor_status
-discard_simplifier::visit_enter(ir_assignment *ir)
-{
- return visit_continue_with_parent;
-}
-
-ir_visitor_status
-discard_simplifier::visit_enter(ir_if *ir)
-{
- ir_discard *then_discard = find_unconditional_discard(ir->then_instructions);
- ir_discard *else_discard = find_unconditional_discard(ir->else_instructions);
-
- if (then_discard == NULL && else_discard == NULL)
- return visit_continue;
-
- /* If both branches result in discard, replace whole if with discard. */
- if (then_discard != NULL && else_discard != NULL) {
- this->progress = true;
- ir->replace_with(then_discard);
- return visit_continue_with_parent;
- }
-
- /* Otherwise, one branch has a discard. */
- if (then_discard != NULL && !is_only_instruction(then_discard)) {
- this->progress = true;
- ir->then_instructions.make_empty();
- ir->then_instructions.push_tail(then_discard);
- } else if (else_discard != NULL && !is_only_instruction(else_discard)) {
- this->progress = true;
- ir->else_instructions.make_empty();
- ir->else_instructions.push_tail(else_discard);
- }
-
- visit_list_elements(this, &ir->then_instructions);
- return visit_continue_with_parent;
-}
-
-ir_visitor_status
-discard_simplifier::visit_enter(ir_loop *ir)
-{
- ir_discard *discard = find_unconditional_discard(ir->body_instructions);
-
- if (discard) {
- ir->replace_with(discard);
- return visit_continue_with_parent;
- }
-
- return visit_continue;
-}
-
-bool
-do_discard_simplification(exec_list *instructions)
-{
- /* Look for a top-level unconditional discard */
- ir_discard *discard = find_unconditional_discard(*instructions);
- if (discard != NULL) {
- instructions->make_empty();
- instructions->push_tail(discard);
- return true;
- }
-
- discard_simplifier v;
-
- visit_list_elements(&v, instructions);
-
- return v.progress;
-}
+/* + * Copyright © 2010 Intel Corporation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ + +/** + * \file opt_discard_simplification.cpp + * + * This pass simplifies if-statements and loops containing unconditional + * discards. + * + * Case 1: Both branches contain unconditional discards: + * ----------------------------------------------------- + * + * if (cond) { + * s1; + * discard; + * s2; + * } else { + * s3; + * discard; + * s4; + * } + * + * becomes: + * + * discard + * + * Case 2: The "then" clause contains an unconditional discard: + * ------------------------------------------------------------ + * + * if (cond) { + * s1; + * discard; + * s2; + * } else { + * s3; + * } + * + * becomes: + * + * if (cond) { + * discard; + * } else { + * s3; + * } + * + * Case 3: The "else" clause contains an unconditional discard: + * ------------------------------------------------------------ + * + * if (cond) { + * s1; + * } else { + * s2; + * discard; + * s3; + * } + * + * becomes: + * + * if (cond) { + * s1; + * } else { + * discard; + * } + */ + +#include "glsl_types.h" +#include "ir.h" + +class discard_simplifier : public ir_hierarchical_visitor { +public: + discard_simplifier() + { + this->progress = false; + } + + ir_visitor_status visit_enter(ir_if *); + ir_visitor_status visit_enter(ir_loop *); + ir_visitor_status visit_enter(ir_assignment *); + + bool progress; +}; + +static ir_discard * +find_unconditional_discard(exec_list &instructions) +{ + foreach_list(n, &instructions) { + ir_instruction *ir = (ir_instruction *)n; + + if (ir->ir_type == ir_type_return || + ir->ir_type == ir_type_loop_jump) + return NULL; + + /* So far, this code doesn't know how to look inside of flow + * control to see if a discard later on at this level is + * unconditional. + */ + if (ir->ir_type == ir_type_if || + ir->ir_type == ir_type_loop) + return NULL; + + ir_discard *discard = ir->as_discard(); + if (discard != NULL && discard->condition == NULL) + return discard; + } + return NULL; +} + +static bool +is_only_instruction(ir_discard *discard) +{ + return (discard->prev->is_head_sentinel() && + discard->next->is_tail_sentinel()); +} + +/* We only care about the top level instructions, so don't descend + * into expressions. + */ +ir_visitor_status +discard_simplifier::visit_enter(ir_assignment *ir) +{ + return visit_continue_with_parent; +} + +ir_visitor_status +discard_simplifier::visit_enter(ir_if *ir) +{ + ir_discard *then_discard = find_unconditional_discard(ir->then_instructions); + ir_discard *else_discard = find_unconditional_discard(ir->else_instructions); + + if (then_discard == NULL && else_discard == NULL) + return visit_continue; + + /* If both branches result in discard, replace whole if with discard. */ + if (then_discard != NULL && else_discard != NULL) { + this->progress = true; + ir->replace_with(then_discard); + return visit_continue_with_parent; + } + + /* Otherwise, one branch has a discard. */ + if (then_discard != NULL && !is_only_instruction(then_discard)) { + this->progress = true; + ir->then_instructions.make_empty(); + ir->then_instructions.push_tail(then_discard); + } else if (else_discard != NULL && !is_only_instruction(else_discard)) { + this->progress = true; + ir->else_instructions.make_empty(); + ir->else_instructions.push_tail(else_discard); + } + + visit_list_elements(this, &ir->then_instructions); + return visit_continue_with_parent; +} + +ir_visitor_status +discard_simplifier::visit_enter(ir_loop *ir) +{ + ir_discard *discard = find_unconditional_discard(ir->body_instructions); + + if (discard) { + ir->replace_with(discard); + return visit_continue_with_parent; + } + + return visit_continue; +} + +bool +do_discard_simplification(exec_list *instructions) +{ + /* Look for a top-level unconditional discard */ + ir_discard *discard = find_unconditional_discard(*instructions); + if (discard != NULL) { + instructions->make_empty(); + instructions->push_tail(discard); + return true; + } + + discard_simplifier v; + + visit_list_elements(&v, instructions); + + return v.progress; +} diff --git a/mesalib/src/mapi/glapi/gen/Makefile b/mesalib/src/mapi/glapi/gen/Makefile index 7415bdc52..3e101f3a1 100644 --- a/mesalib/src/mapi/glapi/gen/Makefile +++ b/mesalib/src/mapi/glapi/gen/Makefile @@ -16,7 +16,8 @@ MESA_GLAPI_OUTPUTS = \ $(MESA_GLAPI_DIR)/glapi_mapi_tmp.h \ $(MESA_GLAPI_DIR)/glprocs.h \ $(MESA_GLAPI_DIR)/glapitemp.h \ - $(MESA_GLAPI_DIR)/glapitable.h + $(MESA_GLAPI_DIR)/glapitable.h \ + $(MESA_GLAPI_DIR)/glapi_gentable.c MESA_GLAPI_ASM_OUTPUTS = \ $(MESA_GLAPI_DIR)/glapi_x86.S \ @@ -50,7 +51,8 @@ XORG_GLAPI_OUTPUTS = \ $(XORG_GLAPI_DIR)/glprocs.h \ $(XORG_GLAPI_DIR)/glapioffsets.h \ $(XORG_GLAPI_DIR)/glapitable.h \ - $(XORG_GLAPI_DIR)/glapidispatch.h + $(XORG_GLAPI_DIR)/glapidispatch.h \ + $(XORG_GLAPI_DIR)/glapi_gentable.c XORG_OUTPUTS = \ $(XORG_GLAPI_FILES) \ @@ -162,6 +164,9 @@ $(MESA_GLAPI_DIR)/glapitemp.h: gl_apitemp.py $(COMMON) $(MESA_GLAPI_DIR)/glapitable.h: gl_table.py $(COMMON) $(PYTHON2) $(PYTHON_FLAGS) $< > $@ +$(MESA_GLAPI_DIR)/glapi_gentable.c: gl_gentable.py $(COMMON) + $(PYTHON2) $(PYTHON_FLAGS) $< > $@ + ###################################################################### $(MESA_GLAPI_DIR)/glapi_x86.S: gl_x86_asm.py $(COMMON) diff --git a/mesalib/src/mapi/glapi/gen/gl_gentable.py b/mesalib/src/mapi/glapi/gen/gl_gentable.py new file mode 100644 index 000000000..0dfebf87f --- /dev/null +++ b/mesalib/src/mapi/glapi/gen/gl_gentable.py @@ -0,0 +1,131 @@ +#!/usr/bin/env python + +# (C) Copyright IBM Corporation 2004, 2005 +# (C) Copyright Apple Inc. 2011 +# All Rights Reserved. +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# on the rights to use, copy, modify, merge, publish, distribute, sub +# license, and/or sell copies of the Software, and to permit persons to whom +# the Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice (including the next +# paragraph) shall be included in all copies or substantial portions of the +# Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL +# IBM AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +# IN THE SOFTWARE. +# +# Authors: +# Jeremy Huddleston <jeremyhu@apple.com> +# +# Based on code ogiginally by: +# Ian Romanick <idr@us.ibm.com> + +import license +import gl_XML, glX_XML +import sys, getopt + +header = """ +#include <dlfcn.h> +#include <stdlib.h> +#include <stdio.h> + +#include <GL/gl.h> + +#include "glapi.h" +#include "glapitable.h" +#include "main/dispatch.h" + +struct _glapi_table * +_glapi_create_table_from_handle(void *handle, const char *symbol_prefix) { + struct _glapi_table *disp = calloc(1, sizeof(struct _glapi_table)); + char symboln[512]; + + if(!disp) + return NULL; +""" + +footer = """ + return disp; +} +""" + +body_template = """ + if(!disp->%(name)s) { + snprintf(symboln, sizeof(symboln), "%%s%(entry_point)s", symbol_prefix); + SET_%(name)s(disp, dlsym(handle, symboln)); + } +""" + +class PrintCode(gl_XML.gl_print_base): + + def __init__(self): + gl_XML.gl_print_base.__init__(self) + + self.name = "gl_gen_table.py (from Mesa)" + self.license = license.bsd_license_template % ( \ +"""Copyright (C) 1999-2001 Brian Paul All Rights Reserved. +(C) Copyright IBM Corporation 2004, 2005 +(C) Copyright Apple Inc 2011""", "BRIAN PAUL, IBM") + + return + + + def get_stack_size(self, f): + size = 0 + for p in f.parameterIterator(): + if p.is_padding: + continue + + size += p.get_stack_size() + + return size + + + def printRealHeader(self): + print header + return + + + def printRealFooter(self): + print footer + return + + + def printBody(self, api): + for f in api.functionIterateByOffset(): + for entry_point in f.entry_points: + vars = { 'entry_point' : entry_point, + 'name' : f.name } + + print body_template % vars + return + +def show_usage(): + print "Usage: %s [-f input_file_name]" % sys.argv[0] + sys.exit(1) + +if __name__ == '__main__': + file_name = "gl_API.xml" + + try: + (args, trail) = getopt.getopt(sys.argv[1:], "m:f:") + except Exception,e: + show_usage() + + for (arg,val) in args: + if arg == "-f": + file_name = val + + printer = PrintCode() + + api = gl_XML.parse_GL_API(file_name, glX_XML.glx_item_factory()) + printer.Print(api) diff --git a/mesalib/src/mapi/glapi/glapi.h b/mesalib/src/mapi/glapi/glapi.h index 1d4ac4674..35dffd757 100644 --- a/mesalib/src/mapi/glapi/glapi.h +++ b/mesalib/src/mapi/glapi/glapi.h @@ -1,177 +1,181 @@ -/*
- * Mesa 3-D graphics library
- * Version: 7.1
- *
- * Copyright (C) 1999-2008 Brian Paul All Rights Reserved.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included
- * in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
- * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
- * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
- * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
- * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- */
-
-
-/**
- * \mainpage Mesa GL API Module
- *
- * \section GLAPIIntroduction Introduction
- *
- * The Mesa GL API module is responsible for dispatching all the
- * gl*() functions. All GL functions are dispatched by jumping through
- * the current dispatch table (basically a struct full of function
- * pointers.)
- *
- * A per-thread current dispatch table and per-thread current context
- * pointer are managed by this module too.
- *
- * This module is intended to be non-Mesa-specific so it can be used
- * with the X/DRI libGL also.
- */
-
-
-#ifndef _GLAPI_H
-#define _GLAPI_H
-
-
-#ifdef _GLAPI_NO_EXPORTS
-# define _GLAPI_EXPORT
-#else /* _GLAPI_NO_EXPORTS */
-# ifdef _WIN32
-# ifdef _GLAPI_DLL_EXPORTS
-# define _GLAPI_EXPORT __declspec(dllexport)
-# else
-# define _GLAPI_EXPORT __declspec(dllimport)
-# endif
-# elif defined(__GNUC__) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590))
-# define _GLAPI_EXPORT __attribute__((visibility("default")))
-# else
-# define _GLAPI_EXPORT
-# endif
-#endif /* _GLAPI_NO_EXPORTS */
-
-
-/* Is this needed? It is incomplete anyway. */
-#ifdef USE_MGL_NAMESPACE
-#define _glapi_set_dispatch _mglapi_set_dispatch
-#define _glapi_get_dispatch _mglapi_get_dispatch
-#define _glapi_set_context _mglapi_set_context
-#define _glapi_get_context _mglapi_get_context
-#define _glapi_Dispatch _mglapi_Dispatch
-#define _glapi_Context _mglapi_Context
-#endif
-
-#include "glapi/glthread.h"
-
-typedef void (*_glapi_proc)(void);
-struct _glapi_table;
-
-
-#if defined (GLX_USE_TLS)
-
-_GLAPI_EXPORT extern __thread struct _glapi_table * _glapi_tls_Dispatch
- __attribute__((tls_model("initial-exec")));
-
-_GLAPI_EXPORT extern __thread void * _glapi_tls_Context
- __attribute__((tls_model("initial-exec")));
-
-_GLAPI_EXPORT extern const struct _glapi_table *_glapi_Dispatch;
-_GLAPI_EXPORT extern const void *_glapi_Context;
-
-# define GET_DISPATCH() _glapi_tls_Dispatch
-# define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) _glapi_tls_Context
-
-#else
-
-_GLAPI_EXPORT extern struct _glapi_table *_glapi_Dispatch;
-_GLAPI_EXPORT extern void *_glapi_Context;
-
-# ifdef THREADS
-
-# define GET_DISPATCH() \
- (likely(_glapi_Dispatch) ? _glapi_Dispatch : _glapi_get_dispatch())
-
-# define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) \
- (likely(_glapi_Context) ? _glapi_Context : _glapi_get_context())
-
-# else
-
-# define GET_DISPATCH() _glapi_Dispatch
-# define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) _glapi_Context
-
-# endif
-
-#endif /* defined (GLX_USE_TLS) */
-
-
-void
-_glapi_destroy_multithread(void);
-
-
-_GLAPI_EXPORT void
-_glapi_check_multithread(void);
-
-
-_GLAPI_EXPORT void
-_glapi_set_context(void *context);
-
-
-_GLAPI_EXPORT void *
-_glapi_get_context(void);
-
-
-_GLAPI_EXPORT void
-_glapi_set_dispatch(struct _glapi_table *dispatch);
-
-
-_GLAPI_EXPORT struct _glapi_table *
-_glapi_get_dispatch(void);
-
-
-_GLAPI_EXPORT unsigned int
-_glapi_get_dispatch_table_size(void);
-
-
-_GLAPI_EXPORT int
-_glapi_add_dispatch( const char * const * function_names,
- const char * parameter_signature );
-
-_GLAPI_EXPORT int
-_glapi_get_proc_offset(const char *funcName);
-
-
-_GLAPI_EXPORT _glapi_proc
-_glapi_get_proc_address(const char *funcName);
-
-
-_GLAPI_EXPORT const char *
-_glapi_get_proc_name(unsigned int offset);
-
-
-_GLAPI_EXPORT unsigned long
-_glthread_GetID(void);
-
-
-/*
- * These stubs are kept so that the old DRI drivers still load.
- */
-_GLAPI_EXPORT void
-_glapi_noop_enable_warnings(unsigned char enable);
-
-
-_GLAPI_EXPORT void
-_glapi_set_warning_func(_glapi_proc func);
-
-
-#endif /* _GLAPI_H */
+/* + * Mesa 3-D graphics library + * Version: 7.1 + * + * Copyright (C) 1999-2008 Brian Paul All Rights Reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included + * in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN + * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + + +/** + * \mainpage Mesa GL API Module + * + * \section GLAPIIntroduction Introduction + * + * The Mesa GL API module is responsible for dispatching all the + * gl*() functions. All GL functions are dispatched by jumping through + * the current dispatch table (basically a struct full of function + * pointers.) + * + * A per-thread current dispatch table and per-thread current context + * pointer are managed by this module too. + * + * This module is intended to be non-Mesa-specific so it can be used + * with the X/DRI libGL also. + */ + + +#ifndef _GLAPI_H +#define _GLAPI_H + + +#ifdef _GLAPI_NO_EXPORTS +# define _GLAPI_EXPORT +#else /* _GLAPI_NO_EXPORTS */ +# ifdef _WIN32 +# ifdef _GLAPI_DLL_EXPORTS +# define _GLAPI_EXPORT __declspec(dllexport) +# else +# define _GLAPI_EXPORT __declspec(dllimport) +# endif +# elif defined(__GNUC__) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)) +# define _GLAPI_EXPORT __attribute__((visibility("default"))) +# else +# define _GLAPI_EXPORT +# endif +#endif /* _GLAPI_NO_EXPORTS */ + + +/* Is this needed? It is incomplete anyway. */ +#ifdef USE_MGL_NAMESPACE +#define _glapi_set_dispatch _mglapi_set_dispatch +#define _glapi_get_dispatch _mglapi_get_dispatch +#define _glapi_set_context _mglapi_set_context +#define _glapi_get_context _mglapi_get_context +#define _glapi_Dispatch _mglapi_Dispatch +#define _glapi_Context _mglapi_Context +#endif + +#include "glapi/glthread.h" + +typedef void (*_glapi_proc)(void); +struct _glapi_table; + + +#if defined (GLX_USE_TLS) + +_GLAPI_EXPORT extern __thread struct _glapi_table * _glapi_tls_Dispatch + __attribute__((tls_model("initial-exec"))); + +_GLAPI_EXPORT extern __thread void * _glapi_tls_Context + __attribute__((tls_model("initial-exec"))); + +_GLAPI_EXPORT extern const struct _glapi_table *_glapi_Dispatch; +_GLAPI_EXPORT extern const void *_glapi_Context; + +# define GET_DISPATCH() _glapi_tls_Dispatch +# define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) _glapi_tls_Context + +#else + +_GLAPI_EXPORT extern struct _glapi_table *_glapi_Dispatch; +_GLAPI_EXPORT extern void *_glapi_Context; + +# ifdef THREADS + +# define GET_DISPATCH() \ + (likely(_glapi_Dispatch) ? _glapi_Dispatch : _glapi_get_dispatch()) + +# define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) \ + (likely(_glapi_Context) ? _glapi_Context : _glapi_get_context()) + +# else + +# define GET_DISPATCH() _glapi_Dispatch +# define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) _glapi_Context + +# endif + +#endif /* defined (GLX_USE_TLS) */ + + +void +_glapi_destroy_multithread(void); + + +_GLAPI_EXPORT void +_glapi_check_multithread(void); + + +_GLAPI_EXPORT void +_glapi_set_context(void *context); + + +_GLAPI_EXPORT void * +_glapi_get_context(void); + + +_GLAPI_EXPORT void +_glapi_set_dispatch(struct _glapi_table *dispatch); + + +_GLAPI_EXPORT struct _glapi_table * +_glapi_get_dispatch(void); + + +_GLAPI_EXPORT unsigned int +_glapi_get_dispatch_table_size(void); + + +_GLAPI_EXPORT int +_glapi_add_dispatch( const char * const * function_names, + const char * parameter_signature ); + +_GLAPI_EXPORT int +_glapi_get_proc_offset(const char *funcName); + + +_GLAPI_EXPORT _glapi_proc +_glapi_get_proc_address(const char *funcName); + + +_GLAPI_EXPORT const char * +_glapi_get_proc_name(unsigned int offset); + + +_GLAPI_EXPORT struct _glapi_table * +_glapi_create_table_from_handle(void *handle, const char *symbol_prefix); + + +_GLAPI_EXPORT unsigned long +_glthread_GetID(void); + + +/* + * These stubs are kept so that the old DRI drivers still load. + */ +_GLAPI_EXPORT void +_glapi_noop_enable_warnings(unsigned char enable); + + +_GLAPI_EXPORT void +_glapi_set_warning_func(_glapi_proc func); + + +#endif /* _GLAPI_H */ diff --git a/mesalib/src/mapi/glapi/glapi_gentable.c b/mesalib/src/mapi/glapi/glapi_gentable.c new file mode 100644 index 000000000..7f09b412b --- /dev/null +++ b/mesalib/src/mapi/glapi/glapi_gentable.c @@ -0,0 +1,7804 @@ +/* DO NOT EDIT - This file generated automatically by gl_gen_table.py (from Mesa) script */ + +/* + * Copyright (C) 1999-2001 Brian Paul All Rights Reserved. + * (C) Copyright IBM Corporation 2004, 2005 + * (C) Copyright Apple Inc 2011 + * All Rights Reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sub license, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL + * BRIAN PAUL, IBM, + * AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, + * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF + * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ + + +#include <dlfcn.h> +#include <stdlib.h> +#include <stdio.h> + +#include <GL/gl.h> + +#include "glapi.h" +#include "glapitable.h" +#include "main/dispatch.h" + +struct _glapi_table * +_glapi_create_table_from_handle(void *handle, const char *symbol_prefix) { + struct _glapi_table *disp = calloc(1, sizeof(struct _glapi_table)); + char symboln[512]; + + if(!disp) + return NULL; + + + if(!disp->NewList) { + snprintf(symboln, sizeof(symboln), "%sNewList", symbol_prefix); + SET_NewList(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndList) { + snprintf(symboln, sizeof(symboln), "%sEndList", symbol_prefix); + SET_EndList(disp, dlsym(handle, symboln)); + } + + + if(!disp->CallList) { + snprintf(symboln, sizeof(symboln), "%sCallList", symbol_prefix); + SET_CallList(disp, dlsym(handle, symboln)); + } + + + if(!disp->CallLists) { + snprintf(symboln, sizeof(symboln), "%sCallLists", symbol_prefix); + SET_CallLists(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteLists) { + snprintf(symboln, sizeof(symboln), "%sDeleteLists", symbol_prefix); + SET_DeleteLists(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenLists) { + snprintf(symboln, sizeof(symboln), "%sGenLists", symbol_prefix); + SET_GenLists(disp, dlsym(handle, symboln)); + } + + + if(!disp->ListBase) { + snprintf(symboln, sizeof(symboln), "%sListBase", symbol_prefix); + SET_ListBase(disp, dlsym(handle, symboln)); + } + + + if(!disp->Begin) { + snprintf(symboln, sizeof(symboln), "%sBegin", symbol_prefix); + SET_Begin(disp, dlsym(handle, symboln)); + } + + + if(!disp->Bitmap) { + snprintf(symboln, sizeof(symboln), "%sBitmap", symbol_prefix); + SET_Bitmap(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3b) { + snprintf(symboln, sizeof(symboln), "%sColor3b", symbol_prefix); + SET_Color3b(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3bv) { + snprintf(symboln, sizeof(symboln), "%sColor3bv", symbol_prefix); + SET_Color3bv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3d) { + snprintf(symboln, sizeof(symboln), "%sColor3d", symbol_prefix); + SET_Color3d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3dv) { + snprintf(symboln, sizeof(symboln), "%sColor3dv", symbol_prefix); + SET_Color3dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3f) { + snprintf(symboln, sizeof(symboln), "%sColor3f", symbol_prefix); + SET_Color3f(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3fv) { + snprintf(symboln, sizeof(symboln), "%sColor3fv", symbol_prefix); + SET_Color3fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3i) { + snprintf(symboln, sizeof(symboln), "%sColor3i", symbol_prefix); + SET_Color3i(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3iv) { + snprintf(symboln, sizeof(symboln), "%sColor3iv", symbol_prefix); + SET_Color3iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3s) { + snprintf(symboln, sizeof(symboln), "%sColor3s", symbol_prefix); + SET_Color3s(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3sv) { + snprintf(symboln, sizeof(symboln), "%sColor3sv", symbol_prefix); + SET_Color3sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3ub) { + snprintf(symboln, sizeof(symboln), "%sColor3ub", symbol_prefix); + SET_Color3ub(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3ubv) { + snprintf(symboln, sizeof(symboln), "%sColor3ubv", symbol_prefix); + SET_Color3ubv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3ui) { + snprintf(symboln, sizeof(symboln), "%sColor3ui", symbol_prefix); + SET_Color3ui(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3uiv) { + snprintf(symboln, sizeof(symboln), "%sColor3uiv", symbol_prefix); + SET_Color3uiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3us) { + snprintf(symboln, sizeof(symboln), "%sColor3us", symbol_prefix); + SET_Color3us(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color3usv) { + snprintf(symboln, sizeof(symboln), "%sColor3usv", symbol_prefix); + SET_Color3usv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4b) { + snprintf(symboln, sizeof(symboln), "%sColor4b", symbol_prefix); + SET_Color4b(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4bv) { + snprintf(symboln, sizeof(symboln), "%sColor4bv", symbol_prefix); + SET_Color4bv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4d) { + snprintf(symboln, sizeof(symboln), "%sColor4d", symbol_prefix); + SET_Color4d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4dv) { + snprintf(symboln, sizeof(symboln), "%sColor4dv", symbol_prefix); + SET_Color4dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4f) { + snprintf(symboln, sizeof(symboln), "%sColor4f", symbol_prefix); + SET_Color4f(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4fv) { + snprintf(symboln, sizeof(symboln), "%sColor4fv", symbol_prefix); + SET_Color4fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4i) { + snprintf(symboln, sizeof(symboln), "%sColor4i", symbol_prefix); + SET_Color4i(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4iv) { + snprintf(symboln, sizeof(symboln), "%sColor4iv", symbol_prefix); + SET_Color4iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4s) { + snprintf(symboln, sizeof(symboln), "%sColor4s", symbol_prefix); + SET_Color4s(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4sv) { + snprintf(symboln, sizeof(symboln), "%sColor4sv", symbol_prefix); + SET_Color4sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4ub) { + snprintf(symboln, sizeof(symboln), "%sColor4ub", symbol_prefix); + SET_Color4ub(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4ubv) { + snprintf(symboln, sizeof(symboln), "%sColor4ubv", symbol_prefix); + SET_Color4ubv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4ui) { + snprintf(symboln, sizeof(symboln), "%sColor4ui", symbol_prefix); + SET_Color4ui(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4uiv) { + snprintf(symboln, sizeof(symboln), "%sColor4uiv", symbol_prefix); + SET_Color4uiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4us) { + snprintf(symboln, sizeof(symboln), "%sColor4us", symbol_prefix); + SET_Color4us(disp, dlsym(handle, symboln)); + } + + + if(!disp->Color4usv) { + snprintf(symboln, sizeof(symboln), "%sColor4usv", symbol_prefix); + SET_Color4usv(disp, dlsym(handle, symboln)); + } + + + if(!disp->EdgeFlag) { + snprintf(symboln, sizeof(symboln), "%sEdgeFlag", symbol_prefix); + SET_EdgeFlag(disp, dlsym(handle, symboln)); + } + + + if(!disp->EdgeFlagv) { + snprintf(symboln, sizeof(symboln), "%sEdgeFlagv", symbol_prefix); + SET_EdgeFlagv(disp, dlsym(handle, symboln)); + } + + + if(!disp->End) { + snprintf(symboln, sizeof(symboln), "%sEnd", symbol_prefix); + SET_End(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexd) { + snprintf(symboln, sizeof(symboln), "%sIndexd", symbol_prefix); + SET_Indexd(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexdv) { + snprintf(symboln, sizeof(symboln), "%sIndexdv", symbol_prefix); + SET_Indexdv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexf) { + snprintf(symboln, sizeof(symboln), "%sIndexf", symbol_prefix); + SET_Indexf(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexfv) { + snprintf(symboln, sizeof(symboln), "%sIndexfv", symbol_prefix); + SET_Indexfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexi) { + snprintf(symboln, sizeof(symboln), "%sIndexi", symbol_prefix); + SET_Indexi(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexiv) { + snprintf(symboln, sizeof(symboln), "%sIndexiv", symbol_prefix); + SET_Indexiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexs) { + snprintf(symboln, sizeof(symboln), "%sIndexs", symbol_prefix); + SET_Indexs(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexsv) { + snprintf(symboln, sizeof(symboln), "%sIndexsv", symbol_prefix); + SET_Indexsv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3b) { + snprintf(symboln, sizeof(symboln), "%sNormal3b", symbol_prefix); + SET_Normal3b(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3bv) { + snprintf(symboln, sizeof(symboln), "%sNormal3bv", symbol_prefix); + SET_Normal3bv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3d) { + snprintf(symboln, sizeof(symboln), "%sNormal3d", symbol_prefix); + SET_Normal3d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3dv) { + snprintf(symboln, sizeof(symboln), "%sNormal3dv", symbol_prefix); + SET_Normal3dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3f) { + snprintf(symboln, sizeof(symboln), "%sNormal3f", symbol_prefix); + SET_Normal3f(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3fv) { + snprintf(symboln, sizeof(symboln), "%sNormal3fv", symbol_prefix); + SET_Normal3fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3i) { + snprintf(symboln, sizeof(symboln), "%sNormal3i", symbol_prefix); + SET_Normal3i(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3iv) { + snprintf(symboln, sizeof(symboln), "%sNormal3iv", symbol_prefix); + SET_Normal3iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3s) { + snprintf(symboln, sizeof(symboln), "%sNormal3s", symbol_prefix); + SET_Normal3s(disp, dlsym(handle, symboln)); + } + + + if(!disp->Normal3sv) { + snprintf(symboln, sizeof(symboln), "%sNormal3sv", symbol_prefix); + SET_Normal3sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2d) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2d", symbol_prefix); + SET_RasterPos2d(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2dv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2dv", symbol_prefix); + SET_RasterPos2dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2f) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2f", symbol_prefix); + SET_RasterPos2f(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2fv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2fv", symbol_prefix); + SET_RasterPos2fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2i) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2i", symbol_prefix); + SET_RasterPos2i(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2iv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2iv", symbol_prefix); + SET_RasterPos2iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2s) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2s", symbol_prefix); + SET_RasterPos2s(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos2sv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos2sv", symbol_prefix); + SET_RasterPos2sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3d) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3d", symbol_prefix); + SET_RasterPos3d(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3dv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3dv", symbol_prefix); + SET_RasterPos3dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3f) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3f", symbol_prefix); + SET_RasterPos3f(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3fv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3fv", symbol_prefix); + SET_RasterPos3fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3i) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3i", symbol_prefix); + SET_RasterPos3i(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3iv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3iv", symbol_prefix); + SET_RasterPos3iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3s) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3s", symbol_prefix); + SET_RasterPos3s(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos3sv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos3sv", symbol_prefix); + SET_RasterPos3sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4d) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4d", symbol_prefix); + SET_RasterPos4d(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4dv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4dv", symbol_prefix); + SET_RasterPos4dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4f) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4f", symbol_prefix); + SET_RasterPos4f(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4fv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4fv", symbol_prefix); + SET_RasterPos4fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4i) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4i", symbol_prefix); + SET_RasterPos4i(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4iv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4iv", symbol_prefix); + SET_RasterPos4iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4s) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4s", symbol_prefix); + SET_RasterPos4s(disp, dlsym(handle, symboln)); + } + + + if(!disp->RasterPos4sv) { + snprintf(symboln, sizeof(symboln), "%sRasterPos4sv", symbol_prefix); + SET_RasterPos4sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rectd) { + snprintf(symboln, sizeof(symboln), "%sRectd", symbol_prefix); + SET_Rectd(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rectdv) { + snprintf(symboln, sizeof(symboln), "%sRectdv", symbol_prefix); + SET_Rectdv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rectf) { + snprintf(symboln, sizeof(symboln), "%sRectf", symbol_prefix); + SET_Rectf(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rectfv) { + snprintf(symboln, sizeof(symboln), "%sRectfv", symbol_prefix); + SET_Rectfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Recti) { + snprintf(symboln, sizeof(symboln), "%sRecti", symbol_prefix); + SET_Recti(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rectiv) { + snprintf(symboln, sizeof(symboln), "%sRectiv", symbol_prefix); + SET_Rectiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rects) { + snprintf(symboln, sizeof(symboln), "%sRects", symbol_prefix); + SET_Rects(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rectsv) { + snprintf(symboln, sizeof(symboln), "%sRectsv", symbol_prefix); + SET_Rectsv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1d) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1d", symbol_prefix); + SET_TexCoord1d(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1dv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1dv", symbol_prefix); + SET_TexCoord1dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1f) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1f", symbol_prefix); + SET_TexCoord1f(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1fv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1fv", symbol_prefix); + SET_TexCoord1fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1i) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1i", symbol_prefix); + SET_TexCoord1i(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1iv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1iv", symbol_prefix); + SET_TexCoord1iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1s) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1s", symbol_prefix); + SET_TexCoord1s(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord1sv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord1sv", symbol_prefix); + SET_TexCoord1sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2d) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2d", symbol_prefix); + SET_TexCoord2d(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2dv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2dv", symbol_prefix); + SET_TexCoord2dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2f) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2f", symbol_prefix); + SET_TexCoord2f(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2fv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2fv", symbol_prefix); + SET_TexCoord2fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2i) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2i", symbol_prefix); + SET_TexCoord2i(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2iv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2iv", symbol_prefix); + SET_TexCoord2iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2s) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2s", symbol_prefix); + SET_TexCoord2s(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord2sv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord2sv", symbol_prefix); + SET_TexCoord2sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3d) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3d", symbol_prefix); + SET_TexCoord3d(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3dv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3dv", symbol_prefix); + SET_TexCoord3dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3f) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3f", symbol_prefix); + SET_TexCoord3f(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3fv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3fv", symbol_prefix); + SET_TexCoord3fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3i) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3i", symbol_prefix); + SET_TexCoord3i(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3iv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3iv", symbol_prefix); + SET_TexCoord3iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3s) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3s", symbol_prefix); + SET_TexCoord3s(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord3sv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord3sv", symbol_prefix); + SET_TexCoord3sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4d) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4d", symbol_prefix); + SET_TexCoord4d(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4dv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4dv", symbol_prefix); + SET_TexCoord4dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4f) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4f", symbol_prefix); + SET_TexCoord4f(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4fv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4fv", symbol_prefix); + SET_TexCoord4fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4i) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4i", symbol_prefix); + SET_TexCoord4i(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4iv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4iv", symbol_prefix); + SET_TexCoord4iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4s) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4s", symbol_prefix); + SET_TexCoord4s(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoord4sv) { + snprintf(symboln, sizeof(symboln), "%sTexCoord4sv", symbol_prefix); + SET_TexCoord4sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2d) { + snprintf(symboln, sizeof(symboln), "%sVertex2d", symbol_prefix); + SET_Vertex2d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2dv) { + snprintf(symboln, sizeof(symboln), "%sVertex2dv", symbol_prefix); + SET_Vertex2dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2f) { + snprintf(symboln, sizeof(symboln), "%sVertex2f", symbol_prefix); + SET_Vertex2f(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2fv) { + snprintf(symboln, sizeof(symboln), "%sVertex2fv", symbol_prefix); + SET_Vertex2fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2i) { + snprintf(symboln, sizeof(symboln), "%sVertex2i", symbol_prefix); + SET_Vertex2i(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2iv) { + snprintf(symboln, sizeof(symboln), "%sVertex2iv", symbol_prefix); + SET_Vertex2iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2s) { + snprintf(symboln, sizeof(symboln), "%sVertex2s", symbol_prefix); + SET_Vertex2s(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex2sv) { + snprintf(symboln, sizeof(symboln), "%sVertex2sv", symbol_prefix); + SET_Vertex2sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3d) { + snprintf(symboln, sizeof(symboln), "%sVertex3d", symbol_prefix); + SET_Vertex3d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3dv) { + snprintf(symboln, sizeof(symboln), "%sVertex3dv", symbol_prefix); + SET_Vertex3dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3f) { + snprintf(symboln, sizeof(symboln), "%sVertex3f", symbol_prefix); + SET_Vertex3f(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3fv) { + snprintf(symboln, sizeof(symboln), "%sVertex3fv", symbol_prefix); + SET_Vertex3fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3i) { + snprintf(symboln, sizeof(symboln), "%sVertex3i", symbol_prefix); + SET_Vertex3i(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3iv) { + snprintf(symboln, sizeof(symboln), "%sVertex3iv", symbol_prefix); + SET_Vertex3iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3s) { + snprintf(symboln, sizeof(symboln), "%sVertex3s", symbol_prefix); + SET_Vertex3s(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex3sv) { + snprintf(symboln, sizeof(symboln), "%sVertex3sv", symbol_prefix); + SET_Vertex3sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4d) { + snprintf(symboln, sizeof(symboln), "%sVertex4d", symbol_prefix); + SET_Vertex4d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4dv) { + snprintf(symboln, sizeof(symboln), "%sVertex4dv", symbol_prefix); + SET_Vertex4dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4f) { + snprintf(symboln, sizeof(symboln), "%sVertex4f", symbol_prefix); + SET_Vertex4f(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4fv) { + snprintf(symboln, sizeof(symboln), "%sVertex4fv", symbol_prefix); + SET_Vertex4fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4i) { + snprintf(symboln, sizeof(symboln), "%sVertex4i", symbol_prefix); + SET_Vertex4i(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4iv) { + snprintf(symboln, sizeof(symboln), "%sVertex4iv", symbol_prefix); + SET_Vertex4iv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4s) { + snprintf(symboln, sizeof(symboln), "%sVertex4s", symbol_prefix); + SET_Vertex4s(disp, dlsym(handle, symboln)); + } + + + if(!disp->Vertex4sv) { + snprintf(symboln, sizeof(symboln), "%sVertex4sv", symbol_prefix); + SET_Vertex4sv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClipPlane) { + snprintf(symboln, sizeof(symboln), "%sClipPlane", symbol_prefix); + SET_ClipPlane(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorMaterial) { + snprintf(symboln, sizeof(symboln), "%sColorMaterial", symbol_prefix); + SET_ColorMaterial(disp, dlsym(handle, symboln)); + } + + + if(!disp->CullFace) { + snprintf(symboln, sizeof(symboln), "%sCullFace", symbol_prefix); + SET_CullFace(disp, dlsym(handle, symboln)); + } + + + if(!disp->Fogf) { + snprintf(symboln, sizeof(symboln), "%sFogf", symbol_prefix); + SET_Fogf(disp, dlsym(handle, symboln)); + } + + + if(!disp->Fogfv) { + snprintf(symboln, sizeof(symboln), "%sFogfv", symbol_prefix); + SET_Fogfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Fogi) { + snprintf(symboln, sizeof(symboln), "%sFogi", symbol_prefix); + SET_Fogi(disp, dlsym(handle, symboln)); + } + + + if(!disp->Fogiv) { + snprintf(symboln, sizeof(symboln), "%sFogiv", symbol_prefix); + SET_Fogiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->FrontFace) { + snprintf(symboln, sizeof(symboln), "%sFrontFace", symbol_prefix); + SET_FrontFace(disp, dlsym(handle, symboln)); + } + + + if(!disp->Hint) { + snprintf(symboln, sizeof(symboln), "%sHint", symbol_prefix); + SET_Hint(disp, dlsym(handle, symboln)); + } + + + if(!disp->Lightf) { + snprintf(symboln, sizeof(symboln), "%sLightf", symbol_prefix); + SET_Lightf(disp, dlsym(handle, symboln)); + } + + + if(!disp->Lightfv) { + snprintf(symboln, sizeof(symboln), "%sLightfv", symbol_prefix); + SET_Lightfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Lighti) { + snprintf(symboln, sizeof(symboln), "%sLighti", symbol_prefix); + SET_Lighti(disp, dlsym(handle, symboln)); + } + + + if(!disp->Lightiv) { + snprintf(symboln, sizeof(symboln), "%sLightiv", symbol_prefix); + SET_Lightiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->LightModelf) { + snprintf(symboln, sizeof(symboln), "%sLightModelf", symbol_prefix); + SET_LightModelf(disp, dlsym(handle, symboln)); + } + + + if(!disp->LightModelfv) { + snprintf(symboln, sizeof(symboln), "%sLightModelfv", symbol_prefix); + SET_LightModelfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->LightModeli) { + snprintf(symboln, sizeof(symboln), "%sLightModeli", symbol_prefix); + SET_LightModeli(disp, dlsym(handle, symboln)); + } + + + if(!disp->LightModeliv) { + snprintf(symboln, sizeof(symboln), "%sLightModeliv", symbol_prefix); + SET_LightModeliv(disp, dlsym(handle, symboln)); + } + + + if(!disp->LineStipple) { + snprintf(symboln, sizeof(symboln), "%sLineStipple", symbol_prefix); + SET_LineStipple(disp, dlsym(handle, symboln)); + } + + + if(!disp->LineWidth) { + snprintf(symboln, sizeof(symboln), "%sLineWidth", symbol_prefix); + SET_LineWidth(disp, dlsym(handle, symboln)); + } + + + if(!disp->Materialf) { + snprintf(symboln, sizeof(symboln), "%sMaterialf", symbol_prefix); + SET_Materialf(disp, dlsym(handle, symboln)); + } + + + if(!disp->Materialfv) { + snprintf(symboln, sizeof(symboln), "%sMaterialfv", symbol_prefix); + SET_Materialfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Materiali) { + snprintf(symboln, sizeof(symboln), "%sMateriali", symbol_prefix); + SET_Materiali(disp, dlsym(handle, symboln)); + } + + + if(!disp->Materialiv) { + snprintf(symboln, sizeof(symboln), "%sMaterialiv", symbol_prefix); + SET_Materialiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointSize) { + snprintf(symboln, sizeof(symboln), "%sPointSize", symbol_prefix); + SET_PointSize(disp, dlsym(handle, symboln)); + } + + + if(!disp->PolygonMode) { + snprintf(symboln, sizeof(symboln), "%sPolygonMode", symbol_prefix); + SET_PolygonMode(disp, dlsym(handle, symboln)); + } + + + if(!disp->PolygonStipple) { + snprintf(symboln, sizeof(symboln), "%sPolygonStipple", symbol_prefix); + SET_PolygonStipple(disp, dlsym(handle, symboln)); + } + + + if(!disp->Scissor) { + snprintf(symboln, sizeof(symboln), "%sScissor", symbol_prefix); + SET_Scissor(disp, dlsym(handle, symboln)); + } + + + if(!disp->ShadeModel) { + snprintf(symboln, sizeof(symboln), "%sShadeModel", symbol_prefix); + SET_ShadeModel(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameterf) { + snprintf(symboln, sizeof(symboln), "%sTexParameterf", symbol_prefix); + SET_TexParameterf(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameterfv) { + snprintf(symboln, sizeof(symboln), "%sTexParameterfv", symbol_prefix); + SET_TexParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameteri) { + snprintf(symboln, sizeof(symboln), "%sTexParameteri", symbol_prefix); + SET_TexParameteri(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameteriv) { + snprintf(symboln, sizeof(symboln), "%sTexParameteriv", symbol_prefix); + SET_TexParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexImage1D) { + snprintf(symboln, sizeof(symboln), "%sTexImage1D", symbol_prefix); + SET_TexImage1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexImage2D) { + snprintf(symboln, sizeof(symboln), "%sTexImage2D", symbol_prefix); + SET_TexImage2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexEnvf) { + snprintf(symboln, sizeof(symboln), "%sTexEnvf", symbol_prefix); + SET_TexEnvf(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexEnvfv) { + snprintf(symboln, sizeof(symboln), "%sTexEnvfv", symbol_prefix); + SET_TexEnvfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexEnvi) { + snprintf(symboln, sizeof(symboln), "%sTexEnvi", symbol_prefix); + SET_TexEnvi(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexEnviv) { + snprintf(symboln, sizeof(symboln), "%sTexEnviv", symbol_prefix); + SET_TexEnviv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexGend) { + snprintf(symboln, sizeof(symboln), "%sTexGend", symbol_prefix); + SET_TexGend(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexGendv) { + snprintf(symboln, sizeof(symboln), "%sTexGendv", symbol_prefix); + SET_TexGendv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexGenf) { + snprintf(symboln, sizeof(symboln), "%sTexGenf", symbol_prefix); + SET_TexGenf(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexGenfv) { + snprintf(symboln, sizeof(symboln), "%sTexGenfv", symbol_prefix); + SET_TexGenfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexGeni) { + snprintf(symboln, sizeof(symboln), "%sTexGeni", symbol_prefix); + SET_TexGeni(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexGeniv) { + snprintf(symboln, sizeof(symboln), "%sTexGeniv", symbol_prefix); + SET_TexGeniv(disp, dlsym(handle, symboln)); + } + + + if(!disp->FeedbackBuffer) { + snprintf(symboln, sizeof(symboln), "%sFeedbackBuffer", symbol_prefix); + SET_FeedbackBuffer(disp, dlsym(handle, symboln)); + } + + + if(!disp->SelectBuffer) { + snprintf(symboln, sizeof(symboln), "%sSelectBuffer", symbol_prefix); + SET_SelectBuffer(disp, dlsym(handle, symboln)); + } + + + if(!disp->RenderMode) { + snprintf(symboln, sizeof(symboln), "%sRenderMode", symbol_prefix); + SET_RenderMode(disp, dlsym(handle, symboln)); + } + + + if(!disp->InitNames) { + snprintf(symboln, sizeof(symboln), "%sInitNames", symbol_prefix); + SET_InitNames(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadName) { + snprintf(symboln, sizeof(symboln), "%sLoadName", symbol_prefix); + SET_LoadName(disp, dlsym(handle, symboln)); + } + + + if(!disp->PassThrough) { + snprintf(symboln, sizeof(symboln), "%sPassThrough", symbol_prefix); + SET_PassThrough(disp, dlsym(handle, symboln)); + } + + + if(!disp->PopName) { + snprintf(symboln, sizeof(symboln), "%sPopName", symbol_prefix); + SET_PopName(disp, dlsym(handle, symboln)); + } + + + if(!disp->PushName) { + snprintf(symboln, sizeof(symboln), "%sPushName", symbol_prefix); + SET_PushName(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawBuffer) { + snprintf(symboln, sizeof(symboln), "%sDrawBuffer", symbol_prefix); + SET_DrawBuffer(disp, dlsym(handle, symboln)); + } + + + if(!disp->Clear) { + snprintf(symboln, sizeof(symboln), "%sClear", symbol_prefix); + SET_Clear(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearAccum) { + snprintf(symboln, sizeof(symboln), "%sClearAccum", symbol_prefix); + SET_ClearAccum(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearIndex) { + snprintf(symboln, sizeof(symboln), "%sClearIndex", symbol_prefix); + SET_ClearIndex(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearColor) { + snprintf(symboln, sizeof(symboln), "%sClearColor", symbol_prefix); + SET_ClearColor(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearStencil) { + snprintf(symboln, sizeof(symboln), "%sClearStencil", symbol_prefix); + SET_ClearStencil(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearDepth) { + snprintf(symboln, sizeof(symboln), "%sClearDepth", symbol_prefix); + SET_ClearDepth(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilMask) { + snprintf(symboln, sizeof(symboln), "%sStencilMask", symbol_prefix); + SET_StencilMask(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorMask) { + snprintf(symboln, sizeof(symboln), "%sColorMask", symbol_prefix); + SET_ColorMask(disp, dlsym(handle, symboln)); + } + + + if(!disp->DepthMask) { + snprintf(symboln, sizeof(symboln), "%sDepthMask", symbol_prefix); + SET_DepthMask(disp, dlsym(handle, symboln)); + } + + + if(!disp->IndexMask) { + snprintf(symboln, sizeof(symboln), "%sIndexMask", symbol_prefix); + SET_IndexMask(disp, dlsym(handle, symboln)); + } + + + if(!disp->Accum) { + snprintf(symboln, sizeof(symboln), "%sAccum", symbol_prefix); + SET_Accum(disp, dlsym(handle, symboln)); + } + + + if(!disp->Disable) { + snprintf(symboln, sizeof(symboln), "%sDisable", symbol_prefix); + SET_Disable(disp, dlsym(handle, symboln)); + } + + + if(!disp->Enable) { + snprintf(symboln, sizeof(symboln), "%sEnable", symbol_prefix); + SET_Enable(disp, dlsym(handle, symboln)); + } + + + if(!disp->Finish) { + snprintf(symboln, sizeof(symboln), "%sFinish", symbol_prefix); + SET_Finish(disp, dlsym(handle, symboln)); + } + + + if(!disp->Flush) { + snprintf(symboln, sizeof(symboln), "%sFlush", symbol_prefix); + SET_Flush(disp, dlsym(handle, symboln)); + } + + + if(!disp->PopAttrib) { + snprintf(symboln, sizeof(symboln), "%sPopAttrib", symbol_prefix); + SET_PopAttrib(disp, dlsym(handle, symboln)); + } + + + if(!disp->PushAttrib) { + snprintf(symboln, sizeof(symboln), "%sPushAttrib", symbol_prefix); + SET_PushAttrib(disp, dlsym(handle, symboln)); + } + + + if(!disp->Map1d) { + snprintf(symboln, sizeof(symboln), "%sMap1d", symbol_prefix); + SET_Map1d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Map1f) { + snprintf(symboln, sizeof(symboln), "%sMap1f", symbol_prefix); + SET_Map1f(disp, dlsym(handle, symboln)); + } + + + if(!disp->Map2d) { + snprintf(symboln, sizeof(symboln), "%sMap2d", symbol_prefix); + SET_Map2d(disp, dlsym(handle, symboln)); + } + + + if(!disp->Map2f) { + snprintf(symboln, sizeof(symboln), "%sMap2f", symbol_prefix); + SET_Map2f(disp, dlsym(handle, symboln)); + } + + + if(!disp->MapGrid1d) { + snprintf(symboln, sizeof(symboln), "%sMapGrid1d", symbol_prefix); + SET_MapGrid1d(disp, dlsym(handle, symboln)); + } + + + if(!disp->MapGrid1f) { + snprintf(symboln, sizeof(symboln), "%sMapGrid1f", symbol_prefix); + SET_MapGrid1f(disp, dlsym(handle, symboln)); + } + + + if(!disp->MapGrid2d) { + snprintf(symboln, sizeof(symboln), "%sMapGrid2d", symbol_prefix); + SET_MapGrid2d(disp, dlsym(handle, symboln)); + } + + + if(!disp->MapGrid2f) { + snprintf(symboln, sizeof(symboln), "%sMapGrid2f", symbol_prefix); + SET_MapGrid2f(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord1d) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord1d", symbol_prefix); + SET_EvalCoord1d(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord1dv) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord1dv", symbol_prefix); + SET_EvalCoord1dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord1f) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord1f", symbol_prefix); + SET_EvalCoord1f(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord1fv) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord1fv", symbol_prefix); + SET_EvalCoord1fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord2d) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord2d", symbol_prefix); + SET_EvalCoord2d(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord2dv) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord2dv", symbol_prefix); + SET_EvalCoord2dv(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord2f) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord2f", symbol_prefix); + SET_EvalCoord2f(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalCoord2fv) { + snprintf(symboln, sizeof(symboln), "%sEvalCoord2fv", symbol_prefix); + SET_EvalCoord2fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalMesh1) { + snprintf(symboln, sizeof(symboln), "%sEvalMesh1", symbol_prefix); + SET_EvalMesh1(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalPoint1) { + snprintf(symboln, sizeof(symboln), "%sEvalPoint1", symbol_prefix); + SET_EvalPoint1(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalMesh2) { + snprintf(symboln, sizeof(symboln), "%sEvalMesh2", symbol_prefix); + SET_EvalMesh2(disp, dlsym(handle, symboln)); + } + + + if(!disp->EvalPoint2) { + snprintf(symboln, sizeof(symboln), "%sEvalPoint2", symbol_prefix); + SET_EvalPoint2(disp, dlsym(handle, symboln)); + } + + + if(!disp->AlphaFunc) { + snprintf(symboln, sizeof(symboln), "%sAlphaFunc", symbol_prefix); + SET_AlphaFunc(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFunc) { + snprintf(symboln, sizeof(symboln), "%sBlendFunc", symbol_prefix); + SET_BlendFunc(disp, dlsym(handle, symboln)); + } + + + if(!disp->LogicOp) { + snprintf(symboln, sizeof(symboln), "%sLogicOp", symbol_prefix); + SET_LogicOp(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilFunc) { + snprintf(symboln, sizeof(symboln), "%sStencilFunc", symbol_prefix); + SET_StencilFunc(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilOp) { + snprintf(symboln, sizeof(symboln), "%sStencilOp", symbol_prefix); + SET_StencilOp(disp, dlsym(handle, symboln)); + } + + + if(!disp->DepthFunc) { + snprintf(symboln, sizeof(symboln), "%sDepthFunc", symbol_prefix); + SET_DepthFunc(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelZoom) { + snprintf(symboln, sizeof(symboln), "%sPixelZoom", symbol_prefix); + SET_PixelZoom(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelTransferf) { + snprintf(symboln, sizeof(symboln), "%sPixelTransferf", symbol_prefix); + SET_PixelTransferf(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelTransferi) { + snprintf(symboln, sizeof(symboln), "%sPixelTransferi", symbol_prefix); + SET_PixelTransferi(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelStoref) { + snprintf(symboln, sizeof(symboln), "%sPixelStoref", symbol_prefix); + SET_PixelStoref(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelStorei) { + snprintf(symboln, sizeof(symboln), "%sPixelStorei", symbol_prefix); + SET_PixelStorei(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelMapfv) { + snprintf(symboln, sizeof(symboln), "%sPixelMapfv", symbol_prefix); + SET_PixelMapfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelMapuiv) { + snprintf(symboln, sizeof(symboln), "%sPixelMapuiv", symbol_prefix); + SET_PixelMapuiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelMapusv) { + snprintf(symboln, sizeof(symboln), "%sPixelMapusv", symbol_prefix); + SET_PixelMapusv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ReadBuffer) { + snprintf(symboln, sizeof(symboln), "%sReadBuffer", symbol_prefix); + SET_ReadBuffer(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyPixels) { + snprintf(symboln, sizeof(symboln), "%sCopyPixels", symbol_prefix); + SET_CopyPixels(disp, dlsym(handle, symboln)); + } + + + if(!disp->ReadPixels) { + snprintf(symboln, sizeof(symboln), "%sReadPixels", symbol_prefix); + SET_ReadPixels(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawPixels) { + snprintf(symboln, sizeof(symboln), "%sDrawPixels", symbol_prefix); + SET_DrawPixels(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBooleanv) { + snprintf(symboln, sizeof(symboln), "%sGetBooleanv", symbol_prefix); + SET_GetBooleanv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetClipPlane) { + snprintf(symboln, sizeof(symboln), "%sGetClipPlane", symbol_prefix); + SET_GetClipPlane(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetDoublev) { + snprintf(symboln, sizeof(symboln), "%sGetDoublev", symbol_prefix); + SET_GetDoublev(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetError) { + snprintf(symboln, sizeof(symboln), "%sGetError", symbol_prefix); + SET_GetError(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFloatv) { + snprintf(symboln, sizeof(symboln), "%sGetFloatv", symbol_prefix); + SET_GetFloatv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetIntegerv) { + snprintf(symboln, sizeof(symboln), "%sGetIntegerv", symbol_prefix); + SET_GetIntegerv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetLightfv) { + snprintf(symboln, sizeof(symboln), "%sGetLightfv", symbol_prefix); + SET_GetLightfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetLightiv) { + snprintf(symboln, sizeof(symboln), "%sGetLightiv", symbol_prefix); + SET_GetLightiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMapdv) { + snprintf(symboln, sizeof(symboln), "%sGetMapdv", symbol_prefix); + SET_GetMapdv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMapfv) { + snprintf(symboln, sizeof(symboln), "%sGetMapfv", symbol_prefix); + SET_GetMapfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMapiv) { + snprintf(symboln, sizeof(symboln), "%sGetMapiv", symbol_prefix); + SET_GetMapiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMaterialfv) { + snprintf(symboln, sizeof(symboln), "%sGetMaterialfv", symbol_prefix); + SET_GetMaterialfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMaterialiv) { + snprintf(symboln, sizeof(symboln), "%sGetMaterialiv", symbol_prefix); + SET_GetMaterialiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPixelMapfv) { + snprintf(symboln, sizeof(symboln), "%sGetPixelMapfv", symbol_prefix); + SET_GetPixelMapfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPixelMapuiv) { + snprintf(symboln, sizeof(symboln), "%sGetPixelMapuiv", symbol_prefix); + SET_GetPixelMapuiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPixelMapusv) { + snprintf(symboln, sizeof(symboln), "%sGetPixelMapusv", symbol_prefix); + SET_GetPixelMapusv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPolygonStipple) { + snprintf(symboln, sizeof(symboln), "%sGetPolygonStipple", symbol_prefix); + SET_GetPolygonStipple(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetString) { + snprintf(symboln, sizeof(symboln), "%sGetString", symbol_prefix); + SET_GetString(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexEnvfv) { + snprintf(symboln, sizeof(symboln), "%sGetTexEnvfv", symbol_prefix); + SET_GetTexEnvfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexEnviv) { + snprintf(symboln, sizeof(symboln), "%sGetTexEnviv", symbol_prefix); + SET_GetTexEnviv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexGendv) { + snprintf(symboln, sizeof(symboln), "%sGetTexGendv", symbol_prefix); + SET_GetTexGendv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexGenfv) { + snprintf(symboln, sizeof(symboln), "%sGetTexGenfv", symbol_prefix); + SET_GetTexGenfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexGeniv) { + snprintf(symboln, sizeof(symboln), "%sGetTexGeniv", symbol_prefix); + SET_GetTexGeniv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexImage) { + snprintf(symboln, sizeof(symboln), "%sGetTexImage", symbol_prefix); + SET_GetTexImage(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetTexParameterfv", symbol_prefix); + SET_GetTexParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetTexParameteriv", symbol_prefix); + SET_GetTexParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexLevelParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetTexLevelParameterfv", symbol_prefix); + SET_GetTexLevelParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexLevelParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetTexLevelParameteriv", symbol_prefix); + SET_GetTexLevelParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsEnabled) { + snprintf(symboln, sizeof(symboln), "%sIsEnabled", symbol_prefix); + SET_IsEnabled(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsList) { + snprintf(symboln, sizeof(symboln), "%sIsList", symbol_prefix); + SET_IsList(disp, dlsym(handle, symboln)); + } + + + if(!disp->DepthRange) { + snprintf(symboln, sizeof(symboln), "%sDepthRange", symbol_prefix); + SET_DepthRange(disp, dlsym(handle, symboln)); + } + + + if(!disp->Frustum) { + snprintf(symboln, sizeof(symboln), "%sFrustum", symbol_prefix); + SET_Frustum(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadIdentity) { + snprintf(symboln, sizeof(symboln), "%sLoadIdentity", symbol_prefix); + SET_LoadIdentity(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadMatrixf) { + snprintf(symboln, sizeof(symboln), "%sLoadMatrixf", symbol_prefix); + SET_LoadMatrixf(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadMatrixd) { + snprintf(symboln, sizeof(symboln), "%sLoadMatrixd", symbol_prefix); + SET_LoadMatrixd(disp, dlsym(handle, symboln)); + } + + + if(!disp->MatrixMode) { + snprintf(symboln, sizeof(symboln), "%sMatrixMode", symbol_prefix); + SET_MatrixMode(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultMatrixf) { + snprintf(symboln, sizeof(symboln), "%sMultMatrixf", symbol_prefix); + SET_MultMatrixf(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultMatrixd) { + snprintf(symboln, sizeof(symboln), "%sMultMatrixd", symbol_prefix); + SET_MultMatrixd(disp, dlsym(handle, symboln)); + } + + + if(!disp->Ortho) { + snprintf(symboln, sizeof(symboln), "%sOrtho", symbol_prefix); + SET_Ortho(disp, dlsym(handle, symboln)); + } + + + if(!disp->PopMatrix) { + snprintf(symboln, sizeof(symboln), "%sPopMatrix", symbol_prefix); + SET_PopMatrix(disp, dlsym(handle, symboln)); + } + + + if(!disp->PushMatrix) { + snprintf(symboln, sizeof(symboln), "%sPushMatrix", symbol_prefix); + SET_PushMatrix(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rotated) { + snprintf(symboln, sizeof(symboln), "%sRotated", symbol_prefix); + SET_Rotated(disp, dlsym(handle, symboln)); + } + + + if(!disp->Rotatef) { + snprintf(symboln, sizeof(symboln), "%sRotatef", symbol_prefix); + SET_Rotatef(disp, dlsym(handle, symboln)); + } + + + if(!disp->Scaled) { + snprintf(symboln, sizeof(symboln), "%sScaled", symbol_prefix); + SET_Scaled(disp, dlsym(handle, symboln)); + } + + + if(!disp->Scalef) { + snprintf(symboln, sizeof(symboln), "%sScalef", symbol_prefix); + SET_Scalef(disp, dlsym(handle, symboln)); + } + + + if(!disp->Translated) { + snprintf(symboln, sizeof(symboln), "%sTranslated", symbol_prefix); + SET_Translated(disp, dlsym(handle, symboln)); + } + + + if(!disp->Translatef) { + snprintf(symboln, sizeof(symboln), "%sTranslatef", symbol_prefix); + SET_Translatef(disp, dlsym(handle, symboln)); + } + + + if(!disp->Viewport) { + snprintf(symboln, sizeof(symboln), "%sViewport", symbol_prefix); + SET_Viewport(disp, dlsym(handle, symboln)); + } + + + if(!disp->ArrayElement) { + snprintf(symboln, sizeof(symboln), "%sArrayElement", symbol_prefix); + SET_ArrayElement(disp, dlsym(handle, symboln)); + } + + + if(!disp->ArrayElement) { + snprintf(symboln, sizeof(symboln), "%sArrayElementEXT", symbol_prefix); + SET_ArrayElement(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindTexture) { + snprintf(symboln, sizeof(symboln), "%sBindTexture", symbol_prefix); + SET_BindTexture(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindTexture) { + snprintf(symboln, sizeof(symboln), "%sBindTextureEXT", symbol_prefix); + SET_BindTexture(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorPointer) { + snprintf(symboln, sizeof(symboln), "%sColorPointer", symbol_prefix); + SET_ColorPointer(disp, dlsym(handle, symboln)); + } + + + if(!disp->DisableClientState) { + snprintf(symboln, sizeof(symboln), "%sDisableClientState", symbol_prefix); + SET_DisableClientState(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawArrays) { + snprintf(symboln, sizeof(symboln), "%sDrawArrays", symbol_prefix); + SET_DrawArrays(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawArrays) { + snprintf(symboln, sizeof(symboln), "%sDrawArraysEXT", symbol_prefix); + SET_DrawArrays(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawElements) { + snprintf(symboln, sizeof(symboln), "%sDrawElements", symbol_prefix); + SET_DrawElements(disp, dlsym(handle, symboln)); + } + + + if(!disp->EdgeFlagPointer) { + snprintf(symboln, sizeof(symboln), "%sEdgeFlagPointer", symbol_prefix); + SET_EdgeFlagPointer(disp, dlsym(handle, symboln)); + } + + + if(!disp->EnableClientState) { + snprintf(symboln, sizeof(symboln), "%sEnableClientState", symbol_prefix); + SET_EnableClientState(disp, dlsym(handle, symboln)); + } + + + if(!disp->IndexPointer) { + snprintf(symboln, sizeof(symboln), "%sIndexPointer", symbol_prefix); + SET_IndexPointer(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexub) { + snprintf(symboln, sizeof(symboln), "%sIndexub", symbol_prefix); + SET_Indexub(disp, dlsym(handle, symboln)); + } + + + if(!disp->Indexubv) { + snprintf(symboln, sizeof(symboln), "%sIndexubv", symbol_prefix); + SET_Indexubv(disp, dlsym(handle, symboln)); + } + + + if(!disp->InterleavedArrays) { + snprintf(symboln, sizeof(symboln), "%sInterleavedArrays", symbol_prefix); + SET_InterleavedArrays(disp, dlsym(handle, symboln)); + } + + + if(!disp->NormalPointer) { + snprintf(symboln, sizeof(symboln), "%sNormalPointer", symbol_prefix); + SET_NormalPointer(disp, dlsym(handle, symboln)); + } + + + if(!disp->PolygonOffset) { + snprintf(symboln, sizeof(symboln), "%sPolygonOffset", symbol_prefix); + SET_PolygonOffset(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoordPointer) { + snprintf(symboln, sizeof(symboln), "%sTexCoordPointer", symbol_prefix); + SET_TexCoordPointer(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexPointer) { + snprintf(symboln, sizeof(symboln), "%sVertexPointer", symbol_prefix); + SET_VertexPointer(disp, dlsym(handle, symboln)); + } + + + if(!disp->AreTexturesResident) { + snprintf(symboln, sizeof(symboln), "%sAreTexturesResident", symbol_prefix); + SET_AreTexturesResident(disp, dlsym(handle, symboln)); + } + + + if(!disp->AreTexturesResident) { + snprintf(symboln, sizeof(symboln), "%sAreTexturesResidentEXT", symbol_prefix); + SET_AreTexturesResident(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexImage1D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexImage1D", symbol_prefix); + SET_CopyTexImage1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexImage1D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexImage1DEXT", symbol_prefix); + SET_CopyTexImage1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexImage2D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexImage2D", symbol_prefix); + SET_CopyTexImage2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexImage2D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexImage2DEXT", symbol_prefix); + SET_CopyTexImage2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexSubImage1D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexSubImage1D", symbol_prefix); + SET_CopyTexSubImage1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexSubImage1D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexSubImage1DEXT", symbol_prefix); + SET_CopyTexSubImage1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexSubImage2D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexSubImage2D", symbol_prefix); + SET_CopyTexSubImage2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexSubImage2D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexSubImage2DEXT", symbol_prefix); + SET_CopyTexSubImage2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteTextures) { + snprintf(symboln, sizeof(symboln), "%sDeleteTextures", symbol_prefix); + SET_DeleteTextures(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteTextures) { + snprintf(symboln, sizeof(symboln), "%sDeleteTexturesEXT", symbol_prefix); + SET_DeleteTextures(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenTextures) { + snprintf(symboln, sizeof(symboln), "%sGenTextures", symbol_prefix); + SET_GenTextures(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenTextures) { + snprintf(symboln, sizeof(symboln), "%sGenTexturesEXT", symbol_prefix); + SET_GenTextures(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPointerv) { + snprintf(symboln, sizeof(symboln), "%sGetPointerv", symbol_prefix); + SET_GetPointerv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPointerv) { + snprintf(symboln, sizeof(symboln), "%sGetPointervEXT", symbol_prefix); + SET_GetPointerv(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsTexture) { + snprintf(symboln, sizeof(symboln), "%sIsTexture", symbol_prefix); + SET_IsTexture(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsTexture) { + snprintf(symboln, sizeof(symboln), "%sIsTextureEXT", symbol_prefix); + SET_IsTexture(disp, dlsym(handle, symboln)); + } + + + if(!disp->PrioritizeTextures) { + snprintf(symboln, sizeof(symboln), "%sPrioritizeTextures", symbol_prefix); + SET_PrioritizeTextures(disp, dlsym(handle, symboln)); + } + + + if(!disp->PrioritizeTextures) { + snprintf(symboln, sizeof(symboln), "%sPrioritizeTexturesEXT", symbol_prefix); + SET_PrioritizeTextures(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexSubImage1D) { + snprintf(symboln, sizeof(symboln), "%sTexSubImage1D", symbol_prefix); + SET_TexSubImage1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexSubImage1D) { + snprintf(symboln, sizeof(symboln), "%sTexSubImage1DEXT", symbol_prefix); + SET_TexSubImage1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexSubImage2D) { + snprintf(symboln, sizeof(symboln), "%sTexSubImage2D", symbol_prefix); + SET_TexSubImage2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexSubImage2D) { + snprintf(symboln, sizeof(symboln), "%sTexSubImage2DEXT", symbol_prefix); + SET_TexSubImage2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->PopClientAttrib) { + snprintf(symboln, sizeof(symboln), "%sPopClientAttrib", symbol_prefix); + SET_PopClientAttrib(disp, dlsym(handle, symboln)); + } + + + if(!disp->PushClientAttrib) { + snprintf(symboln, sizeof(symboln), "%sPushClientAttrib", symbol_prefix); + SET_PushClientAttrib(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendColor) { + snprintf(symboln, sizeof(symboln), "%sBlendColor", symbol_prefix); + SET_BlendColor(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendColor) { + snprintf(symboln, sizeof(symboln), "%sBlendColorEXT", symbol_prefix); + SET_BlendColor(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquation) { + snprintf(symboln, sizeof(symboln), "%sBlendEquation", symbol_prefix); + SET_BlendEquation(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquation) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationEXT", symbol_prefix); + SET_BlendEquation(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawRangeElements) { + snprintf(symboln, sizeof(symboln), "%sDrawRangeElements", symbol_prefix); + SET_DrawRangeElements(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawRangeElements) { + snprintf(symboln, sizeof(symboln), "%sDrawRangeElementsEXT", symbol_prefix); + SET_DrawRangeElements(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorTable) { + snprintf(symboln, sizeof(symboln), "%sColorTable", symbol_prefix); + SET_ColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorTable) { + snprintf(symboln, sizeof(symboln), "%sColorTableSGI", symbol_prefix); + SET_ColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorTable) { + snprintf(symboln, sizeof(symboln), "%sColorTableEXT", symbol_prefix); + SET_ColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorTableParameterfv) { + snprintf(symboln, sizeof(symboln), "%sColorTableParameterfv", symbol_prefix); + SET_ColorTableParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorTableParameterfv) { + snprintf(symboln, sizeof(symboln), "%sColorTableParameterfvSGI", symbol_prefix); + SET_ColorTableParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorTableParameteriv) { + snprintf(symboln, sizeof(symboln), "%sColorTableParameteriv", symbol_prefix); + SET_ColorTableParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorTableParameteriv) { + snprintf(symboln, sizeof(symboln), "%sColorTableParameterivSGI", symbol_prefix); + SET_ColorTableParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyColorTable) { + snprintf(symboln, sizeof(symboln), "%sCopyColorTable", symbol_prefix); + SET_CopyColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyColorTable) { + snprintf(symboln, sizeof(symboln), "%sCopyColorTableSGI", symbol_prefix); + SET_CopyColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTable) { + snprintf(symboln, sizeof(symboln), "%sGetColorTable", symbol_prefix); + SET_GetColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTable) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableSGI", symbol_prefix); + SET_GetColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTable) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableEXT", symbol_prefix); + SET_GetColorTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTableParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableParameterfv", symbol_prefix); + SET_GetColorTableParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTableParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableParameterfvSGI", symbol_prefix); + SET_GetColorTableParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTableParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableParameterfvEXT", symbol_prefix); + SET_GetColorTableParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTableParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableParameteriv", symbol_prefix); + SET_GetColorTableParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTableParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableParameterivSGI", symbol_prefix); + SET_GetColorTableParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetColorTableParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetColorTableParameterivEXT", symbol_prefix); + SET_GetColorTableParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorSubTable) { + snprintf(symboln, sizeof(symboln), "%sColorSubTable", symbol_prefix); + SET_ColorSubTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorSubTable) { + snprintf(symboln, sizeof(symboln), "%sColorSubTableEXT", symbol_prefix); + SET_ColorSubTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyColorSubTable) { + snprintf(symboln, sizeof(symboln), "%sCopyColorSubTable", symbol_prefix); + SET_CopyColorSubTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyColorSubTable) { + snprintf(symboln, sizeof(symboln), "%sCopyColorSubTableEXT", symbol_prefix); + SET_CopyColorSubTable(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionFilter1D) { + snprintf(symboln, sizeof(symboln), "%sConvolutionFilter1D", symbol_prefix); + SET_ConvolutionFilter1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionFilter1D) { + snprintf(symboln, sizeof(symboln), "%sConvolutionFilter1DEXT", symbol_prefix); + SET_ConvolutionFilter1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionFilter2D) { + snprintf(symboln, sizeof(symboln), "%sConvolutionFilter2D", symbol_prefix); + SET_ConvolutionFilter2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionFilter2D) { + snprintf(symboln, sizeof(symboln), "%sConvolutionFilter2DEXT", symbol_prefix); + SET_ConvolutionFilter2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameterf) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameterf", symbol_prefix); + SET_ConvolutionParameterf(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameterf) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameterfEXT", symbol_prefix); + SET_ConvolutionParameterf(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameterfv) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameterfv", symbol_prefix); + SET_ConvolutionParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameterfv) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameterfvEXT", symbol_prefix); + SET_ConvolutionParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameteri) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameteri", symbol_prefix); + SET_ConvolutionParameteri(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameteri) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameteriEXT", symbol_prefix); + SET_ConvolutionParameteri(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameteriv) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameteriv", symbol_prefix); + SET_ConvolutionParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ConvolutionParameteriv) { + snprintf(symboln, sizeof(symboln), "%sConvolutionParameterivEXT", symbol_prefix); + SET_ConvolutionParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyConvolutionFilter1D) { + snprintf(symboln, sizeof(symboln), "%sCopyConvolutionFilter1D", symbol_prefix); + SET_CopyConvolutionFilter1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyConvolutionFilter1D) { + snprintf(symboln, sizeof(symboln), "%sCopyConvolutionFilter1DEXT", symbol_prefix); + SET_CopyConvolutionFilter1D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyConvolutionFilter2D) { + snprintf(symboln, sizeof(symboln), "%sCopyConvolutionFilter2D", symbol_prefix); + SET_CopyConvolutionFilter2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyConvolutionFilter2D) { + snprintf(symboln, sizeof(symboln), "%sCopyConvolutionFilter2DEXT", symbol_prefix); + SET_CopyConvolutionFilter2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetConvolutionFilter) { + snprintf(symboln, sizeof(symboln), "%sGetConvolutionFilter", symbol_prefix); + SET_GetConvolutionFilter(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetConvolutionFilter) { + snprintf(symboln, sizeof(symboln), "%sGetConvolutionFilterEXT", symbol_prefix); + SET_GetConvolutionFilter(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetConvolutionParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetConvolutionParameterfv", symbol_prefix); + SET_GetConvolutionParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetConvolutionParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetConvolutionParameterfvEXT", symbol_prefix); + SET_GetConvolutionParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetConvolutionParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetConvolutionParameteriv", symbol_prefix); + SET_GetConvolutionParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetConvolutionParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetConvolutionParameterivEXT", symbol_prefix); + SET_GetConvolutionParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetSeparableFilter) { + snprintf(symboln, sizeof(symboln), "%sGetSeparableFilter", symbol_prefix); + SET_GetSeparableFilter(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetSeparableFilter) { + snprintf(symboln, sizeof(symboln), "%sGetSeparableFilterEXT", symbol_prefix); + SET_GetSeparableFilter(disp, dlsym(handle, symboln)); + } + + + if(!disp->SeparableFilter2D) { + snprintf(symboln, sizeof(symboln), "%sSeparableFilter2D", symbol_prefix); + SET_SeparableFilter2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->SeparableFilter2D) { + snprintf(symboln, sizeof(symboln), "%sSeparableFilter2DEXT", symbol_prefix); + SET_SeparableFilter2D(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetHistogram) { + snprintf(symboln, sizeof(symboln), "%sGetHistogram", symbol_prefix); + SET_GetHistogram(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetHistogram) { + snprintf(symboln, sizeof(symboln), "%sGetHistogramEXT", symbol_prefix); + SET_GetHistogram(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetHistogramParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetHistogramParameterfv", symbol_prefix); + SET_GetHistogramParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetHistogramParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetHistogramParameterfvEXT", symbol_prefix); + SET_GetHistogramParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetHistogramParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetHistogramParameteriv", symbol_prefix); + SET_GetHistogramParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetHistogramParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetHistogramParameterivEXT", symbol_prefix); + SET_GetHistogramParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMinmax) { + snprintf(symboln, sizeof(symboln), "%sGetMinmax", symbol_prefix); + SET_GetMinmax(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMinmax) { + snprintf(symboln, sizeof(symboln), "%sGetMinmaxEXT", symbol_prefix); + SET_GetMinmax(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMinmaxParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetMinmaxParameterfv", symbol_prefix); + SET_GetMinmaxParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMinmaxParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetMinmaxParameterfvEXT", symbol_prefix); + SET_GetMinmaxParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMinmaxParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetMinmaxParameteriv", symbol_prefix); + SET_GetMinmaxParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetMinmaxParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetMinmaxParameterivEXT", symbol_prefix); + SET_GetMinmaxParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->Histogram) { + snprintf(symboln, sizeof(symboln), "%sHistogram", symbol_prefix); + SET_Histogram(disp, dlsym(handle, symboln)); + } + + + if(!disp->Histogram) { + snprintf(symboln, sizeof(symboln), "%sHistogramEXT", symbol_prefix); + SET_Histogram(disp, dlsym(handle, symboln)); + } + + + if(!disp->Minmax) { + snprintf(symboln, sizeof(symboln), "%sMinmax", symbol_prefix); + SET_Minmax(disp, dlsym(handle, symboln)); + } + + + if(!disp->Minmax) { + snprintf(symboln, sizeof(symboln), "%sMinmaxEXT", symbol_prefix); + SET_Minmax(disp, dlsym(handle, symboln)); + } + + + if(!disp->ResetHistogram) { + snprintf(symboln, sizeof(symboln), "%sResetHistogram", symbol_prefix); + SET_ResetHistogram(disp, dlsym(handle, symboln)); + } + + + if(!disp->ResetHistogram) { + snprintf(symboln, sizeof(symboln), "%sResetHistogramEXT", symbol_prefix); + SET_ResetHistogram(disp, dlsym(handle, symboln)); + } + + + if(!disp->ResetMinmax) { + snprintf(symboln, sizeof(symboln), "%sResetMinmax", symbol_prefix); + SET_ResetMinmax(disp, dlsym(handle, symboln)); + } + + + if(!disp->ResetMinmax) { + snprintf(symboln, sizeof(symboln), "%sResetMinmaxEXT", symbol_prefix); + SET_ResetMinmax(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexImage3D) { + snprintf(symboln, sizeof(symboln), "%sTexImage3D", symbol_prefix); + SET_TexImage3D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexImage3D) { + snprintf(symboln, sizeof(symboln), "%sTexImage3DEXT", symbol_prefix); + SET_TexImage3D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexSubImage3D) { + snprintf(symboln, sizeof(symboln), "%sTexSubImage3D", symbol_prefix); + SET_TexSubImage3D(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexSubImage3D) { + snprintf(symboln, sizeof(symboln), "%sTexSubImage3DEXT", symbol_prefix); + SET_TexSubImage3D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexSubImage3D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexSubImage3D", symbol_prefix); + SET_CopyTexSubImage3D(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyTexSubImage3D) { + snprintf(symboln, sizeof(symboln), "%sCopyTexSubImage3DEXT", symbol_prefix); + SET_CopyTexSubImage3D(disp, dlsym(handle, symboln)); + } + + + if(!disp->ActiveTextureARB) { + snprintf(symboln, sizeof(symboln), "%sActiveTexture", symbol_prefix); + SET_ActiveTextureARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ActiveTextureARB) { + snprintf(symboln, sizeof(symboln), "%sActiveTextureARB", symbol_prefix); + SET_ActiveTextureARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClientActiveTextureARB) { + snprintf(symboln, sizeof(symboln), "%sClientActiveTexture", symbol_prefix); + SET_ClientActiveTextureARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClientActiveTextureARB) { + snprintf(symboln, sizeof(symboln), "%sClientActiveTextureARB", symbol_prefix); + SET_ClientActiveTextureARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1d", symbol_prefix); + SET_MultiTexCoord1dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1dARB", symbol_prefix); + SET_MultiTexCoord1dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1dv", symbol_prefix); + SET_MultiTexCoord1dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1dvARB", symbol_prefix); + SET_MultiTexCoord1dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1f", symbol_prefix); + SET_MultiTexCoord1fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1fARB", symbol_prefix); + SET_MultiTexCoord1fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1fv", symbol_prefix); + SET_MultiTexCoord1fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1fvARB", symbol_prefix); + SET_MultiTexCoord1fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1i", symbol_prefix); + SET_MultiTexCoord1iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1iARB", symbol_prefix); + SET_MultiTexCoord1iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1iv", symbol_prefix); + SET_MultiTexCoord1ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1ivARB", symbol_prefix); + SET_MultiTexCoord1ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1s", symbol_prefix); + SET_MultiTexCoord1sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1sARB", symbol_prefix); + SET_MultiTexCoord1sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1sv", symbol_prefix); + SET_MultiTexCoord1svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord1svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord1svARB", symbol_prefix); + SET_MultiTexCoord1svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2d", symbol_prefix); + SET_MultiTexCoord2dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2dARB", symbol_prefix); + SET_MultiTexCoord2dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2dv", symbol_prefix); + SET_MultiTexCoord2dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2dvARB", symbol_prefix); + SET_MultiTexCoord2dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2f", symbol_prefix); + SET_MultiTexCoord2fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2fARB", symbol_prefix); + SET_MultiTexCoord2fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2fv", symbol_prefix); + SET_MultiTexCoord2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2fvARB", symbol_prefix); + SET_MultiTexCoord2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2i", symbol_prefix); + SET_MultiTexCoord2iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2iARB", symbol_prefix); + SET_MultiTexCoord2iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2iv", symbol_prefix); + SET_MultiTexCoord2ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2ivARB", symbol_prefix); + SET_MultiTexCoord2ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2s", symbol_prefix); + SET_MultiTexCoord2sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2sARB", symbol_prefix); + SET_MultiTexCoord2sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2sv", symbol_prefix); + SET_MultiTexCoord2svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord2svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord2svARB", symbol_prefix); + SET_MultiTexCoord2svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3d", symbol_prefix); + SET_MultiTexCoord3dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3dARB", symbol_prefix); + SET_MultiTexCoord3dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3dv", symbol_prefix); + SET_MultiTexCoord3dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3dvARB", symbol_prefix); + SET_MultiTexCoord3dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3f", symbol_prefix); + SET_MultiTexCoord3fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3fARB", symbol_prefix); + SET_MultiTexCoord3fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3fv", symbol_prefix); + SET_MultiTexCoord3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3fvARB", symbol_prefix); + SET_MultiTexCoord3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3i", symbol_prefix); + SET_MultiTexCoord3iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3iARB", symbol_prefix); + SET_MultiTexCoord3iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3iv", symbol_prefix); + SET_MultiTexCoord3ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3ivARB", symbol_prefix); + SET_MultiTexCoord3ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3s", symbol_prefix); + SET_MultiTexCoord3sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3sARB", symbol_prefix); + SET_MultiTexCoord3sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3sv", symbol_prefix); + SET_MultiTexCoord3svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord3svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord3svARB", symbol_prefix); + SET_MultiTexCoord3svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4d", symbol_prefix); + SET_MultiTexCoord4dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4dARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4dARB", symbol_prefix); + SET_MultiTexCoord4dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4dv", symbol_prefix); + SET_MultiTexCoord4dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4dvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4dvARB", symbol_prefix); + SET_MultiTexCoord4dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4f", symbol_prefix); + SET_MultiTexCoord4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4fARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4fARB", symbol_prefix); + SET_MultiTexCoord4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4fv", symbol_prefix); + SET_MultiTexCoord4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4fvARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4fvARB", symbol_prefix); + SET_MultiTexCoord4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4i", symbol_prefix); + SET_MultiTexCoord4iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4iARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4iARB", symbol_prefix); + SET_MultiTexCoord4iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4iv", symbol_prefix); + SET_MultiTexCoord4ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4ivARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4ivARB", symbol_prefix); + SET_MultiTexCoord4ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4s", symbol_prefix); + SET_MultiTexCoord4sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4sARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4sARB", symbol_prefix); + SET_MultiTexCoord4sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4sv", symbol_prefix); + SET_MultiTexCoord4svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiTexCoord4svARB) { + snprintf(symboln, sizeof(symboln), "%sMultiTexCoord4svARB", symbol_prefix); + SET_MultiTexCoord4svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->AttachShader) { + snprintf(symboln, sizeof(symboln), "%sAttachShader", symbol_prefix); + SET_AttachShader(disp, dlsym(handle, symboln)); + } + + + if(!disp->CreateProgram) { + snprintf(symboln, sizeof(symboln), "%sCreateProgram", symbol_prefix); + SET_CreateProgram(disp, dlsym(handle, symboln)); + } + + + if(!disp->CreateShader) { + snprintf(symboln, sizeof(symboln), "%sCreateShader", symbol_prefix); + SET_CreateShader(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteProgram) { + snprintf(symboln, sizeof(symboln), "%sDeleteProgram", symbol_prefix); + SET_DeleteProgram(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteShader) { + snprintf(symboln, sizeof(symboln), "%sDeleteShader", symbol_prefix); + SET_DeleteShader(disp, dlsym(handle, symboln)); + } + + + if(!disp->DetachShader) { + snprintf(symboln, sizeof(symboln), "%sDetachShader", symbol_prefix); + SET_DetachShader(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetAttachedShaders) { + snprintf(symboln, sizeof(symboln), "%sGetAttachedShaders", symbol_prefix); + SET_GetAttachedShaders(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramInfoLog) { + snprintf(symboln, sizeof(symboln), "%sGetProgramInfoLog", symbol_prefix); + SET_GetProgramInfoLog(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramiv) { + snprintf(symboln, sizeof(symboln), "%sGetProgramiv", symbol_prefix); + SET_GetProgramiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetShaderInfoLog) { + snprintf(symboln, sizeof(symboln), "%sGetShaderInfoLog", symbol_prefix); + SET_GetShaderInfoLog(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetShaderiv) { + snprintf(symboln, sizeof(symboln), "%sGetShaderiv", symbol_prefix); + SET_GetShaderiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsProgram) { + snprintf(symboln, sizeof(symboln), "%sIsProgram", symbol_prefix); + SET_IsProgram(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsShader) { + snprintf(symboln, sizeof(symboln), "%sIsShader", symbol_prefix); + SET_IsShader(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilFuncSeparate) { + snprintf(symboln, sizeof(symboln), "%sStencilFuncSeparate", symbol_prefix); + SET_StencilFuncSeparate(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilMaskSeparate) { + snprintf(symboln, sizeof(symboln), "%sStencilMaskSeparate", symbol_prefix); + SET_StencilMaskSeparate(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilOpSeparate) { + snprintf(symboln, sizeof(symboln), "%sStencilOpSeparate", symbol_prefix); + SET_StencilOpSeparate(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilOpSeparate) { + snprintf(symboln, sizeof(symboln), "%sStencilOpSeparateATI", symbol_prefix); + SET_StencilOpSeparate(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix2x3fv) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix2x3fv", symbol_prefix); + SET_UniformMatrix2x3fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix2x4fv) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix2x4fv", symbol_prefix); + SET_UniformMatrix2x4fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix3x2fv) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix3x2fv", symbol_prefix); + SET_UniformMatrix3x2fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix3x4fv) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix3x4fv", symbol_prefix); + SET_UniformMatrix3x4fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix4x2fv) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix4x2fv", symbol_prefix); + SET_UniformMatrix4x2fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix4x3fv) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix4x3fv", symbol_prefix); + SET_UniformMatrix4x3fv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClampColor) { + snprintf(symboln, sizeof(symboln), "%sClampColor", symbol_prefix); + SET_ClampColor(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearBufferfi) { + snprintf(symboln, sizeof(symboln), "%sClearBufferfi", symbol_prefix); + SET_ClearBufferfi(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearBufferfv) { + snprintf(symboln, sizeof(symboln), "%sClearBufferfv", symbol_prefix); + SET_ClearBufferfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearBufferiv) { + snprintf(symboln, sizeof(symboln), "%sClearBufferiv", symbol_prefix); + SET_ClearBufferiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearBufferuiv) { + snprintf(symboln, sizeof(symboln), "%sClearBufferuiv", symbol_prefix); + SET_ClearBufferuiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetStringi) { + snprintf(symboln, sizeof(symboln), "%sGetStringi", symbol_prefix); + SET_GetStringi(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexBuffer) { + snprintf(symboln, sizeof(symboln), "%sTexBuffer", symbol_prefix); + SET_TexBuffer(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTexture) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTexture", symbol_prefix); + SET_FramebufferTexture(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBufferParameteri64v) { + snprintf(symboln, sizeof(symboln), "%sGetBufferParameteri64v", symbol_prefix); + SET_GetBufferParameteri64v(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetInteger64i_v) { + snprintf(symboln, sizeof(symboln), "%sGetInteger64i_v", symbol_prefix); + SET_GetInteger64i_v(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribDivisor) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribDivisor", symbol_prefix); + SET_VertexAttribDivisor(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadTransposeMatrixdARB) { + snprintf(symboln, sizeof(symboln), "%sLoadTransposeMatrixd", symbol_prefix); + SET_LoadTransposeMatrixdARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadTransposeMatrixdARB) { + snprintf(symboln, sizeof(symboln), "%sLoadTransposeMatrixdARB", symbol_prefix); + SET_LoadTransposeMatrixdARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadTransposeMatrixfARB) { + snprintf(symboln, sizeof(symboln), "%sLoadTransposeMatrixf", symbol_prefix); + SET_LoadTransposeMatrixfARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadTransposeMatrixfARB) { + snprintf(symboln, sizeof(symboln), "%sLoadTransposeMatrixfARB", symbol_prefix); + SET_LoadTransposeMatrixfARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultTransposeMatrixdARB) { + snprintf(symboln, sizeof(symboln), "%sMultTransposeMatrixd", symbol_prefix); + SET_MultTransposeMatrixdARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultTransposeMatrixdARB) { + snprintf(symboln, sizeof(symboln), "%sMultTransposeMatrixdARB", symbol_prefix); + SET_MultTransposeMatrixdARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultTransposeMatrixfARB) { + snprintf(symboln, sizeof(symboln), "%sMultTransposeMatrixf", symbol_prefix); + SET_MultTransposeMatrixfARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultTransposeMatrixfARB) { + snprintf(symboln, sizeof(symboln), "%sMultTransposeMatrixfARB", symbol_prefix); + SET_MultTransposeMatrixfARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->SampleCoverageARB) { + snprintf(symboln, sizeof(symboln), "%sSampleCoverage", symbol_prefix); + SET_SampleCoverageARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->SampleCoverageARB) { + snprintf(symboln, sizeof(symboln), "%sSampleCoverageARB", symbol_prefix); + SET_SampleCoverageARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexImage1DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexImage1D", symbol_prefix); + SET_CompressedTexImage1DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexImage1DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexImage1DARB", symbol_prefix); + SET_CompressedTexImage1DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexImage2DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexImage2D", symbol_prefix); + SET_CompressedTexImage2DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexImage2DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexImage2DARB", symbol_prefix); + SET_CompressedTexImage2DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexImage3DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexImage3D", symbol_prefix); + SET_CompressedTexImage3DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexImage3DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexImage3DARB", symbol_prefix); + SET_CompressedTexImage3DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexSubImage1DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexSubImage1D", symbol_prefix); + SET_CompressedTexSubImage1DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexSubImage1DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexSubImage1DARB", symbol_prefix); + SET_CompressedTexSubImage1DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexSubImage2DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexSubImage2D", symbol_prefix); + SET_CompressedTexSubImage2DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexSubImage2DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexSubImage2DARB", symbol_prefix); + SET_CompressedTexSubImage2DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexSubImage3DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexSubImage3D", symbol_prefix); + SET_CompressedTexSubImage3DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompressedTexSubImage3DARB) { + snprintf(symboln, sizeof(symboln), "%sCompressedTexSubImage3DARB", symbol_prefix); + SET_CompressedTexSubImage3DARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetCompressedTexImageARB) { + snprintf(symboln, sizeof(symboln), "%sGetCompressedTexImage", symbol_prefix); + SET_GetCompressedTexImageARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetCompressedTexImageARB) { + snprintf(symboln, sizeof(symboln), "%sGetCompressedTexImageARB", symbol_prefix); + SET_GetCompressedTexImageARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DisableVertexAttribArrayARB) { + snprintf(symboln, sizeof(symboln), "%sDisableVertexAttribArray", symbol_prefix); + SET_DisableVertexAttribArrayARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DisableVertexAttribArrayARB) { + snprintf(symboln, sizeof(symboln), "%sDisableVertexAttribArrayARB", symbol_prefix); + SET_DisableVertexAttribArrayARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->EnableVertexAttribArrayARB) { + snprintf(symboln, sizeof(symboln), "%sEnableVertexAttribArray", symbol_prefix); + SET_EnableVertexAttribArrayARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->EnableVertexAttribArrayARB) { + snprintf(symboln, sizeof(symboln), "%sEnableVertexAttribArrayARB", symbol_prefix); + SET_EnableVertexAttribArrayARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramEnvParameterdvARB) { + snprintf(symboln, sizeof(symboln), "%sGetProgramEnvParameterdvARB", symbol_prefix); + SET_GetProgramEnvParameterdvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramEnvParameterfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetProgramEnvParameterfvARB", symbol_prefix); + SET_GetProgramEnvParameterfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramLocalParameterdvARB) { + snprintf(symboln, sizeof(symboln), "%sGetProgramLocalParameterdvARB", symbol_prefix); + SET_GetProgramLocalParameterdvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramLocalParameterfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetProgramLocalParameterfvARB", symbol_prefix); + SET_GetProgramLocalParameterfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramStringARB) { + snprintf(symboln, sizeof(symboln), "%sGetProgramStringARB", symbol_prefix); + SET_GetProgramStringARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramivARB) { + snprintf(symboln, sizeof(symboln), "%sGetProgramivARB", symbol_prefix); + SET_GetProgramivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribdvARB) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribdv", symbol_prefix); + SET_GetVertexAttribdvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribdvARB) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribdvARB", symbol_prefix); + SET_GetVertexAttribdvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribfv", symbol_prefix); + SET_GetVertexAttribfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribfvARB", symbol_prefix); + SET_GetVertexAttribfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribivARB) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribiv", symbol_prefix); + SET_GetVertexAttribivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribivARB) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribivARB", symbol_prefix); + SET_GetVertexAttribivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4dARB) { + snprintf(symboln, sizeof(symboln), "%sProgramEnvParameter4dARB", symbol_prefix); + SET_ProgramEnvParameter4dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4dARB) { + snprintf(symboln, sizeof(symboln), "%sProgramParameter4dNV", symbol_prefix); + SET_ProgramEnvParameter4dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4dvARB) { + snprintf(symboln, sizeof(symboln), "%sProgramEnvParameter4dvARB", symbol_prefix); + SET_ProgramEnvParameter4dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4dvARB) { + snprintf(symboln, sizeof(symboln), "%sProgramParameter4dvNV", symbol_prefix); + SET_ProgramEnvParameter4dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4fARB) { + snprintf(symboln, sizeof(symboln), "%sProgramEnvParameter4fARB", symbol_prefix); + SET_ProgramEnvParameter4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4fARB) { + snprintf(symboln, sizeof(symboln), "%sProgramParameter4fNV", symbol_prefix); + SET_ProgramEnvParameter4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4fvARB) { + snprintf(symboln, sizeof(symboln), "%sProgramEnvParameter4fvARB", symbol_prefix); + SET_ProgramEnvParameter4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameter4fvARB) { + snprintf(symboln, sizeof(symboln), "%sProgramParameter4fvNV", symbol_prefix); + SET_ProgramEnvParameter4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramLocalParameter4dARB) { + snprintf(symboln, sizeof(symboln), "%sProgramLocalParameter4dARB", symbol_prefix); + SET_ProgramLocalParameter4dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramLocalParameter4dvARB) { + snprintf(symboln, sizeof(symboln), "%sProgramLocalParameter4dvARB", symbol_prefix); + SET_ProgramLocalParameter4dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramLocalParameter4fARB) { + snprintf(symboln, sizeof(symboln), "%sProgramLocalParameter4fARB", symbol_prefix); + SET_ProgramLocalParameter4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramLocalParameter4fvARB) { + snprintf(symboln, sizeof(symboln), "%sProgramLocalParameter4fvARB", symbol_prefix); + SET_ProgramLocalParameter4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramStringARB) { + snprintf(symboln, sizeof(symboln), "%sProgramStringARB", symbol_prefix); + SET_ProgramStringARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1d", symbol_prefix); + SET_VertexAttrib1dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1dARB", symbol_prefix); + SET_VertexAttrib1dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1dv", symbol_prefix); + SET_VertexAttrib1dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1dvARB", symbol_prefix); + SET_VertexAttrib1dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1f", symbol_prefix); + SET_VertexAttrib1fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1fARB", symbol_prefix); + SET_VertexAttrib1fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1fv", symbol_prefix); + SET_VertexAttrib1fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1fvARB", symbol_prefix); + SET_VertexAttrib1fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1s", symbol_prefix); + SET_VertexAttrib1sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1sARB", symbol_prefix); + SET_VertexAttrib1sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1sv", symbol_prefix); + SET_VertexAttrib1svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1svARB", symbol_prefix); + SET_VertexAttrib1svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2d", symbol_prefix); + SET_VertexAttrib2dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2dARB", symbol_prefix); + SET_VertexAttrib2dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2dv", symbol_prefix); + SET_VertexAttrib2dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2dvARB", symbol_prefix); + SET_VertexAttrib2dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2f", symbol_prefix); + SET_VertexAttrib2fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2fARB", symbol_prefix); + SET_VertexAttrib2fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2fv", symbol_prefix); + SET_VertexAttrib2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2fvARB", symbol_prefix); + SET_VertexAttrib2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2s", symbol_prefix); + SET_VertexAttrib2sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2sARB", symbol_prefix); + SET_VertexAttrib2sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2sv", symbol_prefix); + SET_VertexAttrib2svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2svARB", symbol_prefix); + SET_VertexAttrib2svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3d", symbol_prefix); + SET_VertexAttrib3dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3dARB", symbol_prefix); + SET_VertexAttrib3dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3dv", symbol_prefix); + SET_VertexAttrib3dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3dvARB", symbol_prefix); + SET_VertexAttrib3dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3f", symbol_prefix); + SET_VertexAttrib3fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3fARB", symbol_prefix); + SET_VertexAttrib3fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3fv", symbol_prefix); + SET_VertexAttrib3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3fvARB", symbol_prefix); + SET_VertexAttrib3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3s", symbol_prefix); + SET_VertexAttrib3sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3sARB", symbol_prefix); + SET_VertexAttrib3sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3sv", symbol_prefix); + SET_VertexAttrib3svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3svARB", symbol_prefix); + SET_VertexAttrib3svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NbvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4Nbv", symbol_prefix); + SET_VertexAttrib4NbvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NbvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4NbvARB", symbol_prefix); + SET_VertexAttrib4NbvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4Niv", symbol_prefix); + SET_VertexAttrib4NivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4NivARB", symbol_prefix); + SET_VertexAttrib4NivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NsvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4Nsv", symbol_prefix); + SET_VertexAttrib4NsvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NsvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4NsvARB", symbol_prefix); + SET_VertexAttrib4NsvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NubARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4Nub", symbol_prefix); + SET_VertexAttrib4NubARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NubARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4NubARB", symbol_prefix); + SET_VertexAttrib4NubARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NubvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4Nubv", symbol_prefix); + SET_VertexAttrib4NubvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NubvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4NubvARB", symbol_prefix); + SET_VertexAttrib4NubvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NuivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4Nuiv", symbol_prefix); + SET_VertexAttrib4NuivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NuivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4NuivARB", symbol_prefix); + SET_VertexAttrib4NuivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NusvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4Nusv", symbol_prefix); + SET_VertexAttrib4NusvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4NusvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4NusvARB", symbol_prefix); + SET_VertexAttrib4NusvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4bvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4bv", symbol_prefix); + SET_VertexAttrib4bvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4bvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4bvARB", symbol_prefix); + SET_VertexAttrib4bvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4d", symbol_prefix); + SET_VertexAttrib4dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4dARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4dARB", symbol_prefix); + SET_VertexAttrib4dARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4dv", symbol_prefix); + SET_VertexAttrib4dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4dvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4dvARB", symbol_prefix); + SET_VertexAttrib4dvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4f", symbol_prefix); + SET_VertexAttrib4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4fARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4fARB", symbol_prefix); + SET_VertexAttrib4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4fv", symbol_prefix); + SET_VertexAttrib4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4fvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4fvARB", symbol_prefix); + SET_VertexAttrib4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4ivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4iv", symbol_prefix); + SET_VertexAttrib4ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4ivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4ivARB", symbol_prefix); + SET_VertexAttrib4ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4s", symbol_prefix); + SET_VertexAttrib4sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4sARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4sARB", symbol_prefix); + SET_VertexAttrib4sARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4sv", symbol_prefix); + SET_VertexAttrib4svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4svARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4svARB", symbol_prefix); + SET_VertexAttrib4svARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4ubvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4ubv", symbol_prefix); + SET_VertexAttrib4ubvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4ubvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4ubvARB", symbol_prefix); + SET_VertexAttrib4ubvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4uivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4uiv", symbol_prefix); + SET_VertexAttrib4uivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4uivARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4uivARB", symbol_prefix); + SET_VertexAttrib4uivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4usvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4usv", symbol_prefix); + SET_VertexAttrib4usvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4usvARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4usvARB", symbol_prefix); + SET_VertexAttrib4usvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribPointerARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribPointer", symbol_prefix); + SET_VertexAttribPointerARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribPointerARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribPointerARB", symbol_prefix); + SET_VertexAttribPointerARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindBufferARB) { + snprintf(symboln, sizeof(symboln), "%sBindBuffer", symbol_prefix); + SET_BindBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindBufferARB) { + snprintf(symboln, sizeof(symboln), "%sBindBufferARB", symbol_prefix); + SET_BindBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BufferDataARB) { + snprintf(symboln, sizeof(symboln), "%sBufferData", symbol_prefix); + SET_BufferDataARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BufferDataARB) { + snprintf(symboln, sizeof(symboln), "%sBufferDataARB", symbol_prefix); + SET_BufferDataARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BufferSubDataARB) { + snprintf(symboln, sizeof(symboln), "%sBufferSubData", symbol_prefix); + SET_BufferSubDataARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BufferSubDataARB) { + snprintf(symboln, sizeof(symboln), "%sBufferSubDataARB", symbol_prefix); + SET_BufferSubDataARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteBuffersARB) { + snprintf(symboln, sizeof(symboln), "%sDeleteBuffers", symbol_prefix); + SET_DeleteBuffersARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteBuffersARB) { + snprintf(symboln, sizeof(symboln), "%sDeleteBuffersARB", symbol_prefix); + SET_DeleteBuffersARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenBuffersARB) { + snprintf(symboln, sizeof(symboln), "%sGenBuffers", symbol_prefix); + SET_GenBuffersARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenBuffersARB) { + snprintf(symboln, sizeof(symboln), "%sGenBuffersARB", symbol_prefix); + SET_GenBuffersARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBufferParameterivARB) { + snprintf(symboln, sizeof(symboln), "%sGetBufferParameteriv", symbol_prefix); + SET_GetBufferParameterivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBufferParameterivARB) { + snprintf(symboln, sizeof(symboln), "%sGetBufferParameterivARB", symbol_prefix); + SET_GetBufferParameterivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBufferPointervARB) { + snprintf(symboln, sizeof(symboln), "%sGetBufferPointerv", symbol_prefix); + SET_GetBufferPointervARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBufferPointervARB) { + snprintf(symboln, sizeof(symboln), "%sGetBufferPointervARB", symbol_prefix); + SET_GetBufferPointervARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBufferSubDataARB) { + snprintf(symboln, sizeof(symboln), "%sGetBufferSubData", symbol_prefix); + SET_GetBufferSubDataARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBufferSubDataARB) { + snprintf(symboln, sizeof(symboln), "%sGetBufferSubDataARB", symbol_prefix); + SET_GetBufferSubDataARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsBufferARB) { + snprintf(symboln, sizeof(symboln), "%sIsBuffer", symbol_prefix); + SET_IsBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsBufferARB) { + snprintf(symboln, sizeof(symboln), "%sIsBufferARB", symbol_prefix); + SET_IsBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MapBufferARB) { + snprintf(symboln, sizeof(symboln), "%sMapBuffer", symbol_prefix); + SET_MapBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->MapBufferARB) { + snprintf(symboln, sizeof(symboln), "%sMapBufferARB", symbol_prefix); + SET_MapBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UnmapBufferARB) { + snprintf(symboln, sizeof(symboln), "%sUnmapBuffer", symbol_prefix); + SET_UnmapBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UnmapBufferARB) { + snprintf(symboln, sizeof(symboln), "%sUnmapBufferARB", symbol_prefix); + SET_UnmapBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BeginQueryARB) { + snprintf(symboln, sizeof(symboln), "%sBeginQuery", symbol_prefix); + SET_BeginQueryARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BeginQueryARB) { + snprintf(symboln, sizeof(symboln), "%sBeginQueryARB", symbol_prefix); + SET_BeginQueryARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteQueriesARB) { + snprintf(symboln, sizeof(symboln), "%sDeleteQueries", symbol_prefix); + SET_DeleteQueriesARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteQueriesARB) { + snprintf(symboln, sizeof(symboln), "%sDeleteQueriesARB", symbol_prefix); + SET_DeleteQueriesARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndQueryARB) { + snprintf(symboln, sizeof(symboln), "%sEndQuery", symbol_prefix); + SET_EndQueryARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndQueryARB) { + snprintf(symboln, sizeof(symboln), "%sEndQueryARB", symbol_prefix); + SET_EndQueryARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenQueriesARB) { + snprintf(symboln, sizeof(symboln), "%sGenQueries", symbol_prefix); + SET_GenQueriesARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenQueriesARB) { + snprintf(symboln, sizeof(symboln), "%sGenQueriesARB", symbol_prefix); + SET_GenQueriesARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryObjectivARB) { + snprintf(symboln, sizeof(symboln), "%sGetQueryObjectiv", symbol_prefix); + SET_GetQueryObjectivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryObjectivARB) { + snprintf(symboln, sizeof(symboln), "%sGetQueryObjectivARB", symbol_prefix); + SET_GetQueryObjectivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryObjectuivARB) { + snprintf(symboln, sizeof(symboln), "%sGetQueryObjectuiv", symbol_prefix); + SET_GetQueryObjectuivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryObjectuivARB) { + snprintf(symboln, sizeof(symboln), "%sGetQueryObjectuivARB", symbol_prefix); + SET_GetQueryObjectuivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryivARB) { + snprintf(symboln, sizeof(symboln), "%sGetQueryiv", symbol_prefix); + SET_GetQueryivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryivARB) { + snprintf(symboln, sizeof(symboln), "%sGetQueryivARB", symbol_prefix); + SET_GetQueryivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsQueryARB) { + snprintf(symboln, sizeof(symboln), "%sIsQuery", symbol_prefix); + SET_IsQueryARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsQueryARB) { + snprintf(symboln, sizeof(symboln), "%sIsQueryARB", symbol_prefix); + SET_IsQueryARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->AttachObjectARB) { + snprintf(symboln, sizeof(symboln), "%sAttachObjectARB", symbol_prefix); + SET_AttachObjectARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompileShaderARB) { + snprintf(symboln, sizeof(symboln), "%sCompileShader", symbol_prefix); + SET_CompileShaderARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CompileShaderARB) { + snprintf(symboln, sizeof(symboln), "%sCompileShaderARB", symbol_prefix); + SET_CompileShaderARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CreateProgramObjectARB) { + snprintf(symboln, sizeof(symboln), "%sCreateProgramObjectARB", symbol_prefix); + SET_CreateProgramObjectARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->CreateShaderObjectARB) { + snprintf(symboln, sizeof(symboln), "%sCreateShaderObjectARB", symbol_prefix); + SET_CreateShaderObjectARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteObjectARB) { + snprintf(symboln, sizeof(symboln), "%sDeleteObjectARB", symbol_prefix); + SET_DeleteObjectARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DetachObjectARB) { + snprintf(symboln, sizeof(symboln), "%sDetachObjectARB", symbol_prefix); + SET_DetachObjectARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetActiveUniformARB) { + snprintf(symboln, sizeof(symboln), "%sGetActiveUniform", symbol_prefix); + SET_GetActiveUniformARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetActiveUniformARB) { + snprintf(symboln, sizeof(symboln), "%sGetActiveUniformARB", symbol_prefix); + SET_GetActiveUniformARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetAttachedObjectsARB) { + snprintf(symboln, sizeof(symboln), "%sGetAttachedObjectsARB", symbol_prefix); + SET_GetAttachedObjectsARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetHandleARB) { + snprintf(symboln, sizeof(symboln), "%sGetHandleARB", symbol_prefix); + SET_GetHandleARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetInfoLogARB) { + snprintf(symboln, sizeof(symboln), "%sGetInfoLogARB", symbol_prefix); + SET_GetInfoLogARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetObjectParameterfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetObjectParameterfvARB", symbol_prefix); + SET_GetObjectParameterfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetObjectParameterivARB) { + snprintf(symboln, sizeof(symboln), "%sGetObjectParameterivARB", symbol_prefix); + SET_GetObjectParameterivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetShaderSourceARB) { + snprintf(symboln, sizeof(symboln), "%sGetShaderSource", symbol_prefix); + SET_GetShaderSourceARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetShaderSourceARB) { + snprintf(symboln, sizeof(symboln), "%sGetShaderSourceARB", symbol_prefix); + SET_GetShaderSourceARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformLocationARB) { + snprintf(symboln, sizeof(symboln), "%sGetUniformLocation", symbol_prefix); + SET_GetUniformLocationARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformLocationARB) { + snprintf(symboln, sizeof(symboln), "%sGetUniformLocationARB", symbol_prefix); + SET_GetUniformLocationARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetUniformfv", symbol_prefix); + SET_GetUniformfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetUniformfvARB", symbol_prefix); + SET_GetUniformfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformivARB) { + snprintf(symboln, sizeof(symboln), "%sGetUniformiv", symbol_prefix); + SET_GetUniformivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformivARB) { + snprintf(symboln, sizeof(symboln), "%sGetUniformivARB", symbol_prefix); + SET_GetUniformivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->LinkProgramARB) { + snprintf(symboln, sizeof(symboln), "%sLinkProgram", symbol_prefix); + SET_LinkProgramARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->LinkProgramARB) { + snprintf(symboln, sizeof(symboln), "%sLinkProgramARB", symbol_prefix); + SET_LinkProgramARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ShaderSourceARB) { + snprintf(symboln, sizeof(symboln), "%sShaderSource", symbol_prefix); + SET_ShaderSourceARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ShaderSourceARB) { + snprintf(symboln, sizeof(symboln), "%sShaderSourceARB", symbol_prefix); + SET_ShaderSourceARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1f", symbol_prefix); + SET_Uniform1fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1fARB", symbol_prefix); + SET_Uniform1fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1fv", symbol_prefix); + SET_Uniform1fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1fvARB", symbol_prefix); + SET_Uniform1fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1i", symbol_prefix); + SET_Uniform1iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1iARB", symbol_prefix); + SET_Uniform1iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1iv", symbol_prefix); + SET_Uniform1ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform1ivARB", symbol_prefix); + SET_Uniform1ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2f", symbol_prefix); + SET_Uniform2fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2fARB", symbol_prefix); + SET_Uniform2fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2fv", symbol_prefix); + SET_Uniform2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2fvARB", symbol_prefix); + SET_Uniform2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2i", symbol_prefix); + SET_Uniform2iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2iARB", symbol_prefix); + SET_Uniform2iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2iv", symbol_prefix); + SET_Uniform2ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform2ivARB", symbol_prefix); + SET_Uniform2ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3f", symbol_prefix); + SET_Uniform3fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3fARB", symbol_prefix); + SET_Uniform3fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3fv", symbol_prefix); + SET_Uniform3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3fvARB", symbol_prefix); + SET_Uniform3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3i", symbol_prefix); + SET_Uniform3iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3iARB", symbol_prefix); + SET_Uniform3iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3iv", symbol_prefix); + SET_Uniform3ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform3ivARB", symbol_prefix); + SET_Uniform3ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4f", symbol_prefix); + SET_Uniform4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4fARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4fARB", symbol_prefix); + SET_Uniform4fARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4fv", symbol_prefix); + SET_Uniform4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4fvARB", symbol_prefix); + SET_Uniform4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4i", symbol_prefix); + SET_Uniform4iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4iARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4iARB", symbol_prefix); + SET_Uniform4iARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4iv", symbol_prefix); + SET_Uniform4ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4ivARB) { + snprintf(symboln, sizeof(symboln), "%sUniform4ivARB", symbol_prefix); + SET_Uniform4ivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix2fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix2fv", symbol_prefix); + SET_UniformMatrix2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix2fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix2fvARB", symbol_prefix); + SET_UniformMatrix2fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix3fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix3fv", symbol_prefix); + SET_UniformMatrix3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix3fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix3fvARB", symbol_prefix); + SET_UniformMatrix3fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix4fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix4fv", symbol_prefix); + SET_UniformMatrix4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UniformMatrix4fvARB) { + snprintf(symboln, sizeof(symboln), "%sUniformMatrix4fvARB", symbol_prefix); + SET_UniformMatrix4fvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UseProgramObjectARB) { + snprintf(symboln, sizeof(symboln), "%sUseProgram", symbol_prefix); + SET_UseProgramObjectARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->UseProgramObjectARB) { + snprintf(symboln, sizeof(symboln), "%sUseProgramObjectARB", symbol_prefix); + SET_UseProgramObjectARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ValidateProgramARB) { + snprintf(symboln, sizeof(symboln), "%sValidateProgram", symbol_prefix); + SET_ValidateProgramARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ValidateProgramARB) { + snprintf(symboln, sizeof(symboln), "%sValidateProgramARB", symbol_prefix); + SET_ValidateProgramARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindAttribLocationARB) { + snprintf(symboln, sizeof(symboln), "%sBindAttribLocation", symbol_prefix); + SET_BindAttribLocationARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindAttribLocationARB) { + snprintf(symboln, sizeof(symboln), "%sBindAttribLocationARB", symbol_prefix); + SET_BindAttribLocationARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetActiveAttribARB) { + snprintf(symboln, sizeof(symboln), "%sGetActiveAttrib", symbol_prefix); + SET_GetActiveAttribARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetActiveAttribARB) { + snprintf(symboln, sizeof(symboln), "%sGetActiveAttribARB", symbol_prefix); + SET_GetActiveAttribARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetAttribLocationARB) { + snprintf(symboln, sizeof(symboln), "%sGetAttribLocation", symbol_prefix); + SET_GetAttribLocationARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetAttribLocationARB) { + snprintf(symboln, sizeof(symboln), "%sGetAttribLocationARB", symbol_prefix); + SET_GetAttribLocationARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawBuffersARB) { + snprintf(symboln, sizeof(symboln), "%sDrawBuffers", symbol_prefix); + SET_DrawBuffersARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawBuffersARB) { + snprintf(symboln, sizeof(symboln), "%sDrawBuffersARB", symbol_prefix); + SET_DrawBuffersARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawBuffersARB) { + snprintf(symboln, sizeof(symboln), "%sDrawBuffersATI", symbol_prefix); + SET_DrawBuffersARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClampColorARB) { + snprintf(symboln, sizeof(symboln), "%sClampColorARB", symbol_prefix); + SET_ClampColorARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawArraysInstancedARB) { + snprintf(symboln, sizeof(symboln), "%sDrawArraysInstancedARB", symbol_prefix); + SET_DrawArraysInstancedARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawArraysInstancedARB) { + snprintf(symboln, sizeof(symboln), "%sDrawArraysInstancedEXT", symbol_prefix); + SET_DrawArraysInstancedARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawArraysInstancedARB) { + snprintf(symboln, sizeof(symboln), "%sDrawArraysInstanced", symbol_prefix); + SET_DrawArraysInstancedARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawElementsInstancedARB) { + snprintf(symboln, sizeof(symboln), "%sDrawElementsInstancedARB", symbol_prefix); + SET_DrawElementsInstancedARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawElementsInstancedARB) { + snprintf(symboln, sizeof(symboln), "%sDrawElementsInstancedEXT", symbol_prefix); + SET_DrawElementsInstancedARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawElementsInstancedARB) { + snprintf(symboln, sizeof(symboln), "%sDrawElementsInstanced", symbol_prefix); + SET_DrawElementsInstancedARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->RenderbufferStorageMultisample) { + snprintf(symboln, sizeof(symboln), "%sRenderbufferStorageMultisample", symbol_prefix); + SET_RenderbufferStorageMultisample(disp, dlsym(handle, symboln)); + } + + + if(!disp->RenderbufferStorageMultisample) { + snprintf(symboln, sizeof(symboln), "%sRenderbufferStorageMultisampleEXT", symbol_prefix); + SET_RenderbufferStorageMultisample(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTextureARB) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTextureARB", symbol_prefix); + SET_FramebufferTextureARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTextureFaceARB) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTextureFaceARB", symbol_prefix); + SET_FramebufferTextureFaceARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramParameteriARB) { + snprintf(symboln, sizeof(symboln), "%sProgramParameteriARB", symbol_prefix); + SET_ProgramParameteriARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribDivisorARB) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribDivisorARB", symbol_prefix); + SET_VertexAttribDivisorARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->FlushMappedBufferRange) { + snprintf(symboln, sizeof(symboln), "%sFlushMappedBufferRange", symbol_prefix); + SET_FlushMappedBufferRange(disp, dlsym(handle, symboln)); + } + + + if(!disp->MapBufferRange) { + snprintf(symboln, sizeof(symboln), "%sMapBufferRange", symbol_prefix); + SET_MapBufferRange(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexBufferARB) { + snprintf(symboln, sizeof(symboln), "%sTexBufferARB", symbol_prefix); + SET_TexBufferARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindVertexArray) { + snprintf(symboln, sizeof(symboln), "%sBindVertexArray", symbol_prefix); + SET_BindVertexArray(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenVertexArrays) { + snprintf(symboln, sizeof(symboln), "%sGenVertexArrays", symbol_prefix); + SET_GenVertexArrays(disp, dlsym(handle, symboln)); + } + + + if(!disp->CopyBufferSubData) { + snprintf(symboln, sizeof(symboln), "%sCopyBufferSubData", symbol_prefix); + SET_CopyBufferSubData(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClientWaitSync) { + snprintf(symboln, sizeof(symboln), "%sClientWaitSync", symbol_prefix); + SET_ClientWaitSync(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteSync) { + snprintf(symboln, sizeof(symboln), "%sDeleteSync", symbol_prefix); + SET_DeleteSync(disp, dlsym(handle, symboln)); + } + + + if(!disp->FenceSync) { + snprintf(symboln, sizeof(symboln), "%sFenceSync", symbol_prefix); + SET_FenceSync(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetInteger64v) { + snprintf(symboln, sizeof(symboln), "%sGetInteger64v", symbol_prefix); + SET_GetInteger64v(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetSynciv) { + snprintf(symboln, sizeof(symboln), "%sGetSynciv", symbol_prefix); + SET_GetSynciv(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsSync) { + snprintf(symboln, sizeof(symboln), "%sIsSync", symbol_prefix); + SET_IsSync(disp, dlsym(handle, symboln)); + } + + + if(!disp->WaitSync) { + snprintf(symboln, sizeof(symboln), "%sWaitSync", symbol_prefix); + SET_WaitSync(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawElementsBaseVertex) { + snprintf(symboln, sizeof(symboln), "%sDrawElementsBaseVertex", symbol_prefix); + SET_DrawElementsBaseVertex(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawElementsInstancedBaseVertex) { + snprintf(symboln, sizeof(symboln), "%sDrawElementsInstancedBaseVertex", symbol_prefix); + SET_DrawElementsInstancedBaseVertex(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawRangeElementsBaseVertex) { + snprintf(symboln, sizeof(symboln), "%sDrawRangeElementsBaseVertex", symbol_prefix); + SET_DrawRangeElementsBaseVertex(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiDrawElementsBaseVertex) { + snprintf(symboln, sizeof(symboln), "%sMultiDrawElementsBaseVertex", symbol_prefix); + SET_MultiDrawElementsBaseVertex(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquationSeparateiARB) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationSeparateiARB", symbol_prefix); + SET_BlendEquationSeparateiARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquationSeparateiARB) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationSeparateIndexedAMD", symbol_prefix); + SET_BlendEquationSeparateiARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquationiARB) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationiARB", symbol_prefix); + SET_BlendEquationiARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquationiARB) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationIndexedAMD", symbol_prefix); + SET_BlendEquationiARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFuncSeparateiARB) { + snprintf(symboln, sizeof(symboln), "%sBlendFuncSeparateiARB", symbol_prefix); + SET_BlendFuncSeparateiARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFuncSeparateiARB) { + snprintf(symboln, sizeof(symboln), "%sBlendFuncSeparateIndexedAMD", symbol_prefix); + SET_BlendFuncSeparateiARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFunciARB) { + snprintf(symboln, sizeof(symboln), "%sBlendFunciARB", symbol_prefix); + SET_BlendFunciARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFunciARB) { + snprintf(symboln, sizeof(symboln), "%sBlendFuncIndexedAMD", symbol_prefix); + SET_BlendFunciARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindSampler) { + snprintf(symboln, sizeof(symboln), "%sBindSampler", symbol_prefix); + SET_BindSampler(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteSamplers) { + snprintf(symboln, sizeof(symboln), "%sDeleteSamplers", symbol_prefix); + SET_DeleteSamplers(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenSamplers) { + snprintf(symboln, sizeof(symboln), "%sGenSamplers", symbol_prefix); + SET_GenSamplers(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetSamplerParameterIiv) { + snprintf(symboln, sizeof(symboln), "%sGetSamplerParameterIiv", symbol_prefix); + SET_GetSamplerParameterIiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetSamplerParameterIuiv) { + snprintf(symboln, sizeof(symboln), "%sGetSamplerParameterIuiv", symbol_prefix); + SET_GetSamplerParameterIuiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetSamplerParameterfv) { + snprintf(symboln, sizeof(symboln), "%sGetSamplerParameterfv", symbol_prefix); + SET_GetSamplerParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetSamplerParameteriv) { + snprintf(symboln, sizeof(symboln), "%sGetSamplerParameteriv", symbol_prefix); + SET_GetSamplerParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsSampler) { + snprintf(symboln, sizeof(symboln), "%sIsSampler", symbol_prefix); + SET_IsSampler(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplerParameterIiv) { + snprintf(symboln, sizeof(symboln), "%sSamplerParameterIiv", symbol_prefix); + SET_SamplerParameterIiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplerParameterIuiv) { + snprintf(symboln, sizeof(symboln), "%sSamplerParameterIuiv", symbol_prefix); + SET_SamplerParameterIuiv(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplerParameterf) { + snprintf(symboln, sizeof(symboln), "%sSamplerParameterf", symbol_prefix); + SET_SamplerParameterf(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplerParameterfv) { + snprintf(symboln, sizeof(symboln), "%sSamplerParameterfv", symbol_prefix); + SET_SamplerParameterfv(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplerParameteri) { + snprintf(symboln, sizeof(symboln), "%sSamplerParameteri", symbol_prefix); + SET_SamplerParameteri(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplerParameteriv) { + snprintf(symboln, sizeof(symboln), "%sSamplerParameteriv", symbol_prefix); + SET_SamplerParameteriv(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindTransformFeedback) { + snprintf(symboln, sizeof(symboln), "%sBindTransformFeedback", symbol_prefix); + SET_BindTransformFeedback(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteTransformFeedbacks) { + snprintf(symboln, sizeof(symboln), "%sDeleteTransformFeedbacks", symbol_prefix); + SET_DeleteTransformFeedbacks(disp, dlsym(handle, symboln)); + } + + + if(!disp->DrawTransformFeedback) { + snprintf(symboln, sizeof(symboln), "%sDrawTransformFeedback", symbol_prefix); + SET_DrawTransformFeedback(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenTransformFeedbacks) { + snprintf(symboln, sizeof(symboln), "%sGenTransformFeedbacks", symbol_prefix); + SET_GenTransformFeedbacks(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsTransformFeedback) { + snprintf(symboln, sizeof(symboln), "%sIsTransformFeedback", symbol_prefix); + SET_IsTransformFeedback(disp, dlsym(handle, symboln)); + } + + + if(!disp->PauseTransformFeedback) { + snprintf(symboln, sizeof(symboln), "%sPauseTransformFeedback", symbol_prefix); + SET_PauseTransformFeedback(disp, dlsym(handle, symboln)); + } + + + if(!disp->ResumeTransformFeedback) { + snprintf(symboln, sizeof(symboln), "%sResumeTransformFeedback", symbol_prefix); + SET_ResumeTransformFeedback(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearDepthf) { + snprintf(symboln, sizeof(symboln), "%sClearDepthf", symbol_prefix); + SET_ClearDepthf(disp, dlsym(handle, symboln)); + } + + + if(!disp->DepthRangef) { + snprintf(symboln, sizeof(symboln), "%sDepthRangef", symbol_prefix); + SET_DepthRangef(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetShaderPrecisionFormat) { + snprintf(symboln, sizeof(symboln), "%sGetShaderPrecisionFormat", symbol_prefix); + SET_GetShaderPrecisionFormat(disp, dlsym(handle, symboln)); + } + + + if(!disp->ReleaseShaderCompiler) { + snprintf(symboln, sizeof(symboln), "%sReleaseShaderCompiler", symbol_prefix); + SET_ReleaseShaderCompiler(disp, dlsym(handle, symboln)); + } + + + if(!disp->ShaderBinary) { + snprintf(symboln, sizeof(symboln), "%sShaderBinary", symbol_prefix); + SET_ShaderBinary(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetGraphicsResetStatusARB) { + snprintf(symboln, sizeof(symboln), "%sGetGraphicsResetStatusARB", symbol_prefix); + SET_GetGraphicsResetStatusARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnColorTableARB) { + snprintf(symboln, sizeof(symboln), "%sGetnColorTableARB", symbol_prefix); + SET_GetnColorTableARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnCompressedTexImageARB) { + snprintf(symboln, sizeof(symboln), "%sGetnCompressedTexImageARB", symbol_prefix); + SET_GetnCompressedTexImageARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnConvolutionFilterARB) { + snprintf(symboln, sizeof(symboln), "%sGetnConvolutionFilterARB", symbol_prefix); + SET_GetnConvolutionFilterARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnHistogramARB) { + snprintf(symboln, sizeof(symboln), "%sGetnHistogramARB", symbol_prefix); + SET_GetnHistogramARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnMapdvARB) { + snprintf(symboln, sizeof(symboln), "%sGetnMapdvARB", symbol_prefix); + SET_GetnMapdvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnMapfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetnMapfvARB", symbol_prefix); + SET_GetnMapfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnMapivARB) { + snprintf(symboln, sizeof(symboln), "%sGetnMapivARB", symbol_prefix); + SET_GetnMapivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnMinmaxARB) { + snprintf(symboln, sizeof(symboln), "%sGetnMinmaxARB", symbol_prefix); + SET_GetnMinmaxARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnPixelMapfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetnPixelMapfvARB", symbol_prefix); + SET_GetnPixelMapfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnPixelMapuivARB) { + snprintf(symboln, sizeof(symboln), "%sGetnPixelMapuivARB", symbol_prefix); + SET_GetnPixelMapuivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnPixelMapusvARB) { + snprintf(symboln, sizeof(symboln), "%sGetnPixelMapusvARB", symbol_prefix); + SET_GetnPixelMapusvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnPolygonStippleARB) { + snprintf(symboln, sizeof(symboln), "%sGetnPolygonStippleARB", symbol_prefix); + SET_GetnPolygonStippleARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnSeparableFilterARB) { + snprintf(symboln, sizeof(symboln), "%sGetnSeparableFilterARB", symbol_prefix); + SET_GetnSeparableFilterARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnTexImageARB) { + snprintf(symboln, sizeof(symboln), "%sGetnTexImageARB", symbol_prefix); + SET_GetnTexImageARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnUniformdvARB) { + snprintf(symboln, sizeof(symboln), "%sGetnUniformdvARB", symbol_prefix); + SET_GetnUniformdvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnUniformfvARB) { + snprintf(symboln, sizeof(symboln), "%sGetnUniformfvARB", symbol_prefix); + SET_GetnUniformfvARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnUniformivARB) { + snprintf(symboln, sizeof(symboln), "%sGetnUniformivARB", symbol_prefix); + SET_GetnUniformivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetnUniformuivARB) { + snprintf(symboln, sizeof(symboln), "%sGetnUniformuivARB", symbol_prefix); + SET_GetnUniformuivARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->ReadnPixelsARB) { + snprintf(symboln, sizeof(symboln), "%sReadnPixelsARB", symbol_prefix); + SET_ReadnPixelsARB(disp, dlsym(handle, symboln)); + } + + + if(!disp->PolygonOffsetEXT) { + snprintf(symboln, sizeof(symboln), "%sPolygonOffsetEXT", symbol_prefix); + SET_PolygonOffsetEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPixelTexGenParameterfvSGIS) { + snprintf(symboln, sizeof(symboln), "%sGetPixelTexGenParameterfvSGIS", symbol_prefix); + SET_GetPixelTexGenParameterfvSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetPixelTexGenParameterivSGIS) { + snprintf(symboln, sizeof(symboln), "%sGetPixelTexGenParameterivSGIS", symbol_prefix); + SET_GetPixelTexGenParameterivSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelTexGenParameterfSGIS) { + snprintf(symboln, sizeof(symboln), "%sPixelTexGenParameterfSGIS", symbol_prefix); + SET_PixelTexGenParameterfSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelTexGenParameterfvSGIS) { + snprintf(symboln, sizeof(symboln), "%sPixelTexGenParameterfvSGIS", symbol_prefix); + SET_PixelTexGenParameterfvSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelTexGenParameteriSGIS) { + snprintf(symboln, sizeof(symboln), "%sPixelTexGenParameteriSGIS", symbol_prefix); + SET_PixelTexGenParameteriSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelTexGenParameterivSGIS) { + snprintf(symboln, sizeof(symboln), "%sPixelTexGenParameterivSGIS", symbol_prefix); + SET_PixelTexGenParameterivSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->SampleMaskSGIS) { + snprintf(symboln, sizeof(symboln), "%sSampleMaskSGIS", symbol_prefix); + SET_SampleMaskSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->SampleMaskSGIS) { + snprintf(symboln, sizeof(symboln), "%sSampleMaskEXT", symbol_prefix); + SET_SampleMaskSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplePatternSGIS) { + snprintf(symboln, sizeof(symboln), "%sSamplePatternSGIS", symbol_prefix); + SET_SamplePatternSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->SamplePatternSGIS) { + snprintf(symboln, sizeof(symboln), "%sSamplePatternEXT", symbol_prefix); + SET_SamplePatternSGIS(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sColorPointerEXT", symbol_prefix); + SET_ColorPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->EdgeFlagPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sEdgeFlagPointerEXT", symbol_prefix); + SET_EdgeFlagPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->IndexPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sIndexPointerEXT", symbol_prefix); + SET_IndexPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->NormalPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sNormalPointerEXT", symbol_prefix); + SET_NormalPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexCoordPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sTexCoordPointerEXT", symbol_prefix); + SET_TexCoordPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexPointerEXT", symbol_prefix); + SET_VertexPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterf", symbol_prefix); + SET_PointParameterfEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterfARB", symbol_prefix); + SET_PointParameterfEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterfEXT", symbol_prefix); + SET_PointParameterfEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterfSGIS", symbol_prefix); + SET_PointParameterfEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfvEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterfv", symbol_prefix); + SET_PointParameterfvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfvEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterfvARB", symbol_prefix); + SET_PointParameterfvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfvEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterfvEXT", symbol_prefix); + SET_PointParameterfvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterfvEXT) { + snprintf(symboln, sizeof(symboln), "%sPointParameterfvSGIS", symbol_prefix); + SET_PointParameterfvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->LockArraysEXT) { + snprintf(symboln, sizeof(symboln), "%sLockArraysEXT", symbol_prefix); + SET_LockArraysEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->UnlockArraysEXT) { + snprintf(symboln, sizeof(symboln), "%sUnlockArraysEXT", symbol_prefix); + SET_UnlockArraysEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3bEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3b", symbol_prefix); + SET_SecondaryColor3bEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3bEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3bEXT", symbol_prefix); + SET_SecondaryColor3bEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3bvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3bv", symbol_prefix); + SET_SecondaryColor3bvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3bvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3bvEXT", symbol_prefix); + SET_SecondaryColor3bvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3dEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3d", symbol_prefix); + SET_SecondaryColor3dEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3dEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3dEXT", symbol_prefix); + SET_SecondaryColor3dEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3dvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3dv", symbol_prefix); + SET_SecondaryColor3dvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3dvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3dvEXT", symbol_prefix); + SET_SecondaryColor3dvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3fEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3f", symbol_prefix); + SET_SecondaryColor3fEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3fEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3fEXT", symbol_prefix); + SET_SecondaryColor3fEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3fvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3fv", symbol_prefix); + SET_SecondaryColor3fvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3fvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3fvEXT", symbol_prefix); + SET_SecondaryColor3fvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3iEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3i", symbol_prefix); + SET_SecondaryColor3iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3iEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3iEXT", symbol_prefix); + SET_SecondaryColor3iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3ivEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3iv", symbol_prefix); + SET_SecondaryColor3ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3ivEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3ivEXT", symbol_prefix); + SET_SecondaryColor3ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3sEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3s", symbol_prefix); + SET_SecondaryColor3sEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3sEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3sEXT", symbol_prefix); + SET_SecondaryColor3sEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3svEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3sv", symbol_prefix); + SET_SecondaryColor3svEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3svEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3svEXT", symbol_prefix); + SET_SecondaryColor3svEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3ubEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3ub", symbol_prefix); + SET_SecondaryColor3ubEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3ubEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3ubEXT", symbol_prefix); + SET_SecondaryColor3ubEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3ubvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3ubv", symbol_prefix); + SET_SecondaryColor3ubvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3ubvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3ubvEXT", symbol_prefix); + SET_SecondaryColor3ubvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3uiEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3ui", symbol_prefix); + SET_SecondaryColor3uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3uiEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3uiEXT", symbol_prefix); + SET_SecondaryColor3uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3uivEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3uiv", symbol_prefix); + SET_SecondaryColor3uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3uivEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3uivEXT", symbol_prefix); + SET_SecondaryColor3uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3usEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3us", symbol_prefix); + SET_SecondaryColor3usEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3usEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3usEXT", symbol_prefix); + SET_SecondaryColor3usEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3usvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3usv", symbol_prefix); + SET_SecondaryColor3usvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColor3usvEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColor3usvEXT", symbol_prefix); + SET_SecondaryColor3usvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColorPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColorPointer", symbol_prefix); + SET_SecondaryColorPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->SecondaryColorPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sSecondaryColorPointerEXT", symbol_prefix); + SET_SecondaryColorPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiDrawArraysEXT) { + snprintf(symboln, sizeof(symboln), "%sMultiDrawArrays", symbol_prefix); + SET_MultiDrawArraysEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiDrawArraysEXT) { + snprintf(symboln, sizeof(symboln), "%sMultiDrawArraysEXT", symbol_prefix); + SET_MultiDrawArraysEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiDrawElementsEXT) { + snprintf(symboln, sizeof(symboln), "%sMultiDrawElements", symbol_prefix); + SET_MultiDrawElementsEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiDrawElementsEXT) { + snprintf(symboln, sizeof(symboln), "%sMultiDrawElementsEXT", symbol_prefix); + SET_MultiDrawElementsEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoordPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoordPointer", symbol_prefix); + SET_FogCoordPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoordPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoordPointerEXT", symbol_prefix); + SET_FogCoordPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoorddEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoordd", symbol_prefix); + SET_FogCoorddEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoorddEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoorddEXT", symbol_prefix); + SET_FogCoorddEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoorddvEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoorddv", symbol_prefix); + SET_FogCoorddvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoorddvEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoorddvEXT", symbol_prefix); + SET_FogCoorddvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoordfEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoordf", symbol_prefix); + SET_FogCoordfEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoordfEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoordfEXT", symbol_prefix); + SET_FogCoordfEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoordfvEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoordfv", symbol_prefix); + SET_FogCoordfvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FogCoordfvEXT) { + snprintf(symboln, sizeof(symboln), "%sFogCoordfvEXT", symbol_prefix); + SET_FogCoordfvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->PixelTexGenSGIX) { + snprintf(symboln, sizeof(symboln), "%sPixelTexGenSGIX", symbol_prefix); + SET_PixelTexGenSGIX(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFuncSeparateEXT) { + snprintf(symboln, sizeof(symboln), "%sBlendFuncSeparate", symbol_prefix); + SET_BlendFuncSeparateEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFuncSeparateEXT) { + snprintf(symboln, sizeof(symboln), "%sBlendFuncSeparateEXT", symbol_prefix); + SET_BlendFuncSeparateEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendFuncSeparateEXT) { + snprintf(symboln, sizeof(symboln), "%sBlendFuncSeparateINGR", symbol_prefix); + SET_BlendFuncSeparateEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FlushVertexArrayRangeNV) { + snprintf(symboln, sizeof(symboln), "%sFlushVertexArrayRangeNV", symbol_prefix); + SET_FlushVertexArrayRangeNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexArrayRangeNV) { + snprintf(symboln, sizeof(symboln), "%sVertexArrayRangeNV", symbol_prefix); + SET_VertexArrayRangeNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->CombinerInputNV) { + snprintf(symboln, sizeof(symboln), "%sCombinerInputNV", symbol_prefix); + SET_CombinerInputNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->CombinerOutputNV) { + snprintf(symboln, sizeof(symboln), "%sCombinerOutputNV", symbol_prefix); + SET_CombinerOutputNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->CombinerParameterfNV) { + snprintf(symboln, sizeof(symboln), "%sCombinerParameterfNV", symbol_prefix); + SET_CombinerParameterfNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->CombinerParameterfvNV) { + snprintf(symboln, sizeof(symboln), "%sCombinerParameterfvNV", symbol_prefix); + SET_CombinerParameterfvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->CombinerParameteriNV) { + snprintf(symboln, sizeof(symboln), "%sCombinerParameteriNV", symbol_prefix); + SET_CombinerParameteriNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->CombinerParameterivNV) { + snprintf(symboln, sizeof(symboln), "%sCombinerParameterivNV", symbol_prefix); + SET_CombinerParameterivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->FinalCombinerInputNV) { + snprintf(symboln, sizeof(symboln), "%sFinalCombinerInputNV", symbol_prefix); + SET_FinalCombinerInputNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetCombinerInputParameterfvNV) { + snprintf(symboln, sizeof(symboln), "%sGetCombinerInputParameterfvNV", symbol_prefix); + SET_GetCombinerInputParameterfvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetCombinerInputParameterivNV) { + snprintf(symboln, sizeof(symboln), "%sGetCombinerInputParameterivNV", symbol_prefix); + SET_GetCombinerInputParameterivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetCombinerOutputParameterfvNV) { + snprintf(symboln, sizeof(symboln), "%sGetCombinerOutputParameterfvNV", symbol_prefix); + SET_GetCombinerOutputParameterfvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetCombinerOutputParameterivNV) { + snprintf(symboln, sizeof(symboln), "%sGetCombinerOutputParameterivNV", symbol_prefix); + SET_GetCombinerOutputParameterivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFinalCombinerInputParameterfvNV) { + snprintf(symboln, sizeof(symboln), "%sGetFinalCombinerInputParameterfvNV", symbol_prefix); + SET_GetFinalCombinerInputParameterfvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFinalCombinerInputParameterivNV) { + snprintf(symboln, sizeof(symboln), "%sGetFinalCombinerInputParameterivNV", symbol_prefix); + SET_GetFinalCombinerInputParameterivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ResizeBuffersMESA) { + snprintf(symboln, sizeof(symboln), "%sResizeBuffersMESA", symbol_prefix); + SET_ResizeBuffersMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2dMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2d", symbol_prefix); + SET_WindowPos2dMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2dMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2dARB", symbol_prefix); + SET_WindowPos2dMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2dMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2dMESA", symbol_prefix); + SET_WindowPos2dMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2dvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2dv", symbol_prefix); + SET_WindowPos2dvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2dvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2dvARB", symbol_prefix); + SET_WindowPos2dvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2dvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2dvMESA", symbol_prefix); + SET_WindowPos2dvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2fMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2f", symbol_prefix); + SET_WindowPos2fMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2fMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2fARB", symbol_prefix); + SET_WindowPos2fMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2fMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2fMESA", symbol_prefix); + SET_WindowPos2fMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2fvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2fv", symbol_prefix); + SET_WindowPos2fvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2fvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2fvARB", symbol_prefix); + SET_WindowPos2fvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2fvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2fvMESA", symbol_prefix); + SET_WindowPos2fvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2iMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2i", symbol_prefix); + SET_WindowPos2iMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2iMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2iARB", symbol_prefix); + SET_WindowPos2iMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2iMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2iMESA", symbol_prefix); + SET_WindowPos2iMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2ivMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2iv", symbol_prefix); + SET_WindowPos2ivMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2ivMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2ivARB", symbol_prefix); + SET_WindowPos2ivMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2ivMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2ivMESA", symbol_prefix); + SET_WindowPos2ivMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2sMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2s", symbol_prefix); + SET_WindowPos2sMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2sMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2sARB", symbol_prefix); + SET_WindowPos2sMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2sMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2sMESA", symbol_prefix); + SET_WindowPos2sMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2svMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2sv", symbol_prefix); + SET_WindowPos2svMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2svMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2svARB", symbol_prefix); + SET_WindowPos2svMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos2svMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos2svMESA", symbol_prefix); + SET_WindowPos2svMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3dMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3d", symbol_prefix); + SET_WindowPos3dMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3dMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3dARB", symbol_prefix); + SET_WindowPos3dMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3dMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3dMESA", symbol_prefix); + SET_WindowPos3dMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3dvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3dv", symbol_prefix); + SET_WindowPos3dvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3dvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3dvARB", symbol_prefix); + SET_WindowPos3dvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3dvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3dvMESA", symbol_prefix); + SET_WindowPos3dvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3fMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3f", symbol_prefix); + SET_WindowPos3fMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3fMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3fARB", symbol_prefix); + SET_WindowPos3fMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3fMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3fMESA", symbol_prefix); + SET_WindowPos3fMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3fvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3fv", symbol_prefix); + SET_WindowPos3fvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3fvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3fvARB", symbol_prefix); + SET_WindowPos3fvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3fvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3fvMESA", symbol_prefix); + SET_WindowPos3fvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3iMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3i", symbol_prefix); + SET_WindowPos3iMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3iMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3iARB", symbol_prefix); + SET_WindowPos3iMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3iMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3iMESA", symbol_prefix); + SET_WindowPos3iMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3ivMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3iv", symbol_prefix); + SET_WindowPos3ivMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3ivMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3ivARB", symbol_prefix); + SET_WindowPos3ivMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3ivMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3ivMESA", symbol_prefix); + SET_WindowPos3ivMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3sMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3s", symbol_prefix); + SET_WindowPos3sMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3sMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3sARB", symbol_prefix); + SET_WindowPos3sMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3sMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3sMESA", symbol_prefix); + SET_WindowPos3sMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3svMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3sv", symbol_prefix); + SET_WindowPos3svMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3svMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3svARB", symbol_prefix); + SET_WindowPos3svMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos3svMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos3svMESA", symbol_prefix); + SET_WindowPos3svMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4dMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4dMESA", symbol_prefix); + SET_WindowPos4dMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4dvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4dvMESA", symbol_prefix); + SET_WindowPos4dvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4fMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4fMESA", symbol_prefix); + SET_WindowPos4fMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4fvMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4fvMESA", symbol_prefix); + SET_WindowPos4fvMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4iMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4iMESA", symbol_prefix); + SET_WindowPos4iMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4ivMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4ivMESA", symbol_prefix); + SET_WindowPos4ivMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4sMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4sMESA", symbol_prefix); + SET_WindowPos4sMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->WindowPos4svMESA) { + snprintf(symboln, sizeof(symboln), "%sWindowPos4svMESA", symbol_prefix); + SET_WindowPos4svMESA(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiModeDrawArraysIBM) { + snprintf(symboln, sizeof(symboln), "%sMultiModeDrawArraysIBM", symbol_prefix); + SET_MultiModeDrawArraysIBM(disp, dlsym(handle, symboln)); + } + + + if(!disp->MultiModeDrawElementsIBM) { + snprintf(symboln, sizeof(symboln), "%sMultiModeDrawElementsIBM", symbol_prefix); + SET_MultiModeDrawElementsIBM(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteFencesNV) { + snprintf(symboln, sizeof(symboln), "%sDeleteFencesNV", symbol_prefix); + SET_DeleteFencesNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->FinishFenceNV) { + snprintf(symboln, sizeof(symboln), "%sFinishFenceNV", symbol_prefix); + SET_FinishFenceNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenFencesNV) { + snprintf(symboln, sizeof(symboln), "%sGenFencesNV", symbol_prefix); + SET_GenFencesNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFenceivNV) { + snprintf(symboln, sizeof(symboln), "%sGetFenceivNV", symbol_prefix); + SET_GetFenceivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsFenceNV) { + snprintf(symboln, sizeof(symboln), "%sIsFenceNV", symbol_prefix); + SET_IsFenceNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->SetFenceNV) { + snprintf(symboln, sizeof(symboln), "%sSetFenceNV", symbol_prefix); + SET_SetFenceNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->TestFenceNV) { + snprintf(symboln, sizeof(symboln), "%sTestFenceNV", symbol_prefix); + SET_TestFenceNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->AreProgramsResidentNV) { + snprintf(symboln, sizeof(symboln), "%sAreProgramsResidentNV", symbol_prefix); + SET_AreProgramsResidentNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindProgramNV) { + snprintf(symboln, sizeof(symboln), "%sBindProgramARB", symbol_prefix); + SET_BindProgramNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindProgramNV) { + snprintf(symboln, sizeof(symboln), "%sBindProgramNV", symbol_prefix); + SET_BindProgramNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteProgramsNV) { + snprintf(symboln, sizeof(symboln), "%sDeleteProgramsARB", symbol_prefix); + SET_DeleteProgramsNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteProgramsNV) { + snprintf(symboln, sizeof(symboln), "%sDeleteProgramsNV", symbol_prefix); + SET_DeleteProgramsNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ExecuteProgramNV) { + snprintf(symboln, sizeof(symboln), "%sExecuteProgramNV", symbol_prefix); + SET_ExecuteProgramNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenProgramsNV) { + snprintf(symboln, sizeof(symboln), "%sGenProgramsARB", symbol_prefix); + SET_GenProgramsNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenProgramsNV) { + snprintf(symboln, sizeof(symboln), "%sGenProgramsNV", symbol_prefix); + SET_GenProgramsNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramParameterdvNV) { + snprintf(symboln, sizeof(symboln), "%sGetProgramParameterdvNV", symbol_prefix); + SET_GetProgramParameterdvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramParameterfvNV) { + snprintf(symboln, sizeof(symboln), "%sGetProgramParameterfvNV", symbol_prefix); + SET_GetProgramParameterfvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramStringNV) { + snprintf(symboln, sizeof(symboln), "%sGetProgramStringNV", symbol_prefix); + SET_GetProgramStringNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramivNV) { + snprintf(symboln, sizeof(symboln), "%sGetProgramivNV", symbol_prefix); + SET_GetProgramivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTrackMatrixivNV) { + snprintf(symboln, sizeof(symboln), "%sGetTrackMatrixivNV", symbol_prefix); + SET_GetTrackMatrixivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribPointervNV) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribPointerv", symbol_prefix); + SET_GetVertexAttribPointervNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribPointervNV) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribPointervARB", symbol_prefix); + SET_GetVertexAttribPointervNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribPointervNV) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribPointervNV", symbol_prefix); + SET_GetVertexAttribPointervNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribdvNV) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribdvNV", symbol_prefix); + SET_GetVertexAttribdvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribfvNV) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribfvNV", symbol_prefix); + SET_GetVertexAttribfvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribivNV) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribivNV", symbol_prefix); + SET_GetVertexAttribivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsProgramNV) { + snprintf(symboln, sizeof(symboln), "%sIsProgramARB", symbol_prefix); + SET_IsProgramNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsProgramNV) { + snprintf(symboln, sizeof(symboln), "%sIsProgramNV", symbol_prefix); + SET_IsProgramNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->LoadProgramNV) { + snprintf(symboln, sizeof(symboln), "%sLoadProgramNV", symbol_prefix); + SET_LoadProgramNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramParameters4dvNV) { + snprintf(symboln, sizeof(symboln), "%sProgramParameters4dvNV", symbol_prefix); + SET_ProgramParameters4dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramParameters4fvNV) { + snprintf(symboln, sizeof(symboln), "%sProgramParameters4fvNV", symbol_prefix); + SET_ProgramParameters4fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->RequestResidentProgramsNV) { + snprintf(symboln, sizeof(symboln), "%sRequestResidentProgramsNV", symbol_prefix); + SET_RequestResidentProgramsNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->TrackMatrixNV) { + snprintf(symboln, sizeof(symboln), "%sTrackMatrixNV", symbol_prefix); + SET_TrackMatrixNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1dNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1dNV", symbol_prefix); + SET_VertexAttrib1dNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1dvNV", symbol_prefix); + SET_VertexAttrib1dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1fNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1fNV", symbol_prefix); + SET_VertexAttrib1fNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1fvNV", symbol_prefix); + SET_VertexAttrib1fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1sNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1sNV", symbol_prefix); + SET_VertexAttrib1sNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib1svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib1svNV", symbol_prefix); + SET_VertexAttrib1svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2dNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2dNV", symbol_prefix); + SET_VertexAttrib2dNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2dvNV", symbol_prefix); + SET_VertexAttrib2dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2fNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2fNV", symbol_prefix); + SET_VertexAttrib2fNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2fvNV", symbol_prefix); + SET_VertexAttrib2fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2sNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2sNV", symbol_prefix); + SET_VertexAttrib2sNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib2svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib2svNV", symbol_prefix); + SET_VertexAttrib2svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3dNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3dNV", symbol_prefix); + SET_VertexAttrib3dNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3dvNV", symbol_prefix); + SET_VertexAttrib3dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3fNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3fNV", symbol_prefix); + SET_VertexAttrib3fNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3fvNV", symbol_prefix); + SET_VertexAttrib3fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3sNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3sNV", symbol_prefix); + SET_VertexAttrib3sNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib3svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib3svNV", symbol_prefix); + SET_VertexAttrib3svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4dNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4dNV", symbol_prefix); + SET_VertexAttrib4dNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4dvNV", symbol_prefix); + SET_VertexAttrib4dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4fNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4fNV", symbol_prefix); + SET_VertexAttrib4fNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4fvNV", symbol_prefix); + SET_VertexAttrib4fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4sNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4sNV", symbol_prefix); + SET_VertexAttrib4sNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4svNV", symbol_prefix); + SET_VertexAttrib4svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4ubNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4ubNV", symbol_prefix); + SET_VertexAttrib4ubNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttrib4ubvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttrib4ubvNV", symbol_prefix); + SET_VertexAttrib4ubvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribPointerNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribPointerNV", symbol_prefix); + SET_VertexAttribPointerNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs1dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs1dvNV", symbol_prefix); + SET_VertexAttribs1dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs1fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs1fvNV", symbol_prefix); + SET_VertexAttribs1fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs1svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs1svNV", symbol_prefix); + SET_VertexAttribs1svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs2dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs2dvNV", symbol_prefix); + SET_VertexAttribs2dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs2fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs2fvNV", symbol_prefix); + SET_VertexAttribs2fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs2svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs2svNV", symbol_prefix); + SET_VertexAttribs2svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs3dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs3dvNV", symbol_prefix); + SET_VertexAttribs3dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs3fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs3fvNV", symbol_prefix); + SET_VertexAttribs3fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs3svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs3svNV", symbol_prefix); + SET_VertexAttribs3svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs4dvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs4dvNV", symbol_prefix); + SET_VertexAttribs4dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs4fvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs4fvNV", symbol_prefix); + SET_VertexAttribs4fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs4svNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs4svNV", symbol_prefix); + SET_VertexAttribs4svNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribs4ubvNV) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribs4ubvNV", symbol_prefix); + SET_VertexAttribs4ubvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexBumpParameterfvATI) { + snprintf(symboln, sizeof(symboln), "%sGetTexBumpParameterfvATI", symbol_prefix); + SET_GetTexBumpParameterfvATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexBumpParameterivATI) { + snprintf(symboln, sizeof(symboln), "%sGetTexBumpParameterivATI", symbol_prefix); + SET_GetTexBumpParameterivATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexBumpParameterfvATI) { + snprintf(symboln, sizeof(symboln), "%sTexBumpParameterfvATI", symbol_prefix); + SET_TexBumpParameterfvATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexBumpParameterivATI) { + snprintf(symboln, sizeof(symboln), "%sTexBumpParameterivATI", symbol_prefix); + SET_TexBumpParameterivATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->AlphaFragmentOp1ATI) { + snprintf(symboln, sizeof(symboln), "%sAlphaFragmentOp1ATI", symbol_prefix); + SET_AlphaFragmentOp1ATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->AlphaFragmentOp2ATI) { + snprintf(symboln, sizeof(symboln), "%sAlphaFragmentOp2ATI", symbol_prefix); + SET_AlphaFragmentOp2ATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->AlphaFragmentOp3ATI) { + snprintf(symboln, sizeof(symboln), "%sAlphaFragmentOp3ATI", symbol_prefix); + SET_AlphaFragmentOp3ATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->BeginFragmentShaderATI) { + snprintf(symboln, sizeof(symboln), "%sBeginFragmentShaderATI", symbol_prefix); + SET_BeginFragmentShaderATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindFragmentShaderATI) { + snprintf(symboln, sizeof(symboln), "%sBindFragmentShaderATI", symbol_prefix); + SET_BindFragmentShaderATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorFragmentOp1ATI) { + snprintf(symboln, sizeof(symboln), "%sColorFragmentOp1ATI", symbol_prefix); + SET_ColorFragmentOp1ATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorFragmentOp2ATI) { + snprintf(symboln, sizeof(symboln), "%sColorFragmentOp2ATI", symbol_prefix); + SET_ColorFragmentOp2ATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorFragmentOp3ATI) { + snprintf(symboln, sizeof(symboln), "%sColorFragmentOp3ATI", symbol_prefix); + SET_ColorFragmentOp3ATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteFragmentShaderATI) { + snprintf(symboln, sizeof(symboln), "%sDeleteFragmentShaderATI", symbol_prefix); + SET_DeleteFragmentShaderATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndFragmentShaderATI) { + snprintf(symboln, sizeof(symboln), "%sEndFragmentShaderATI", symbol_prefix); + SET_EndFragmentShaderATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenFragmentShadersATI) { + snprintf(symboln, sizeof(symboln), "%sGenFragmentShadersATI", symbol_prefix); + SET_GenFragmentShadersATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->PassTexCoordATI) { + snprintf(symboln, sizeof(symboln), "%sPassTexCoordATI", symbol_prefix); + SET_PassTexCoordATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->SampleMapATI) { + snprintf(symboln, sizeof(symboln), "%sSampleMapATI", symbol_prefix); + SET_SampleMapATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->SetFragmentShaderConstantATI) { + snprintf(symboln, sizeof(symboln), "%sSetFragmentShaderConstantATI", symbol_prefix); + SET_SetFragmentShaderConstantATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameteriNV) { + snprintf(symboln, sizeof(symboln), "%sPointParameteri", symbol_prefix); + SET_PointParameteriNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameteriNV) { + snprintf(symboln, sizeof(symboln), "%sPointParameteriNV", symbol_prefix); + SET_PointParameteriNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterivNV) { + snprintf(symboln, sizeof(symboln), "%sPointParameteriv", symbol_prefix); + SET_PointParameterivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->PointParameterivNV) { + snprintf(symboln, sizeof(symboln), "%sPointParameterivNV", symbol_prefix); + SET_PointParameterivNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ActiveStencilFaceEXT) { + snprintf(symboln, sizeof(symboln), "%sActiveStencilFaceEXT", symbol_prefix); + SET_ActiveStencilFaceEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindVertexArrayAPPLE) { + snprintf(symboln, sizeof(symboln), "%sBindVertexArrayAPPLE", symbol_prefix); + SET_BindVertexArrayAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteVertexArraysAPPLE) { + snprintf(symboln, sizeof(symboln), "%sDeleteVertexArrays", symbol_prefix); + SET_DeleteVertexArraysAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteVertexArraysAPPLE) { + snprintf(symboln, sizeof(symboln), "%sDeleteVertexArraysAPPLE", symbol_prefix); + SET_DeleteVertexArraysAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenVertexArraysAPPLE) { + snprintf(symboln, sizeof(symboln), "%sGenVertexArraysAPPLE", symbol_prefix); + SET_GenVertexArraysAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsVertexArrayAPPLE) { + snprintf(symboln, sizeof(symboln), "%sIsVertexArray", symbol_prefix); + SET_IsVertexArrayAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsVertexArrayAPPLE) { + snprintf(symboln, sizeof(symboln), "%sIsVertexArrayAPPLE", symbol_prefix); + SET_IsVertexArrayAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramNamedParameterdvNV) { + snprintf(symboln, sizeof(symboln), "%sGetProgramNamedParameterdvNV", symbol_prefix); + SET_GetProgramNamedParameterdvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetProgramNamedParameterfvNV) { + snprintf(symboln, sizeof(symboln), "%sGetProgramNamedParameterfvNV", symbol_prefix); + SET_GetProgramNamedParameterfvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramNamedParameter4dNV) { + snprintf(symboln, sizeof(symboln), "%sProgramNamedParameter4dNV", symbol_prefix); + SET_ProgramNamedParameter4dNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramNamedParameter4dvNV) { + snprintf(symboln, sizeof(symboln), "%sProgramNamedParameter4dvNV", symbol_prefix); + SET_ProgramNamedParameter4dvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramNamedParameter4fNV) { + snprintf(symboln, sizeof(symboln), "%sProgramNamedParameter4fNV", symbol_prefix); + SET_ProgramNamedParameter4fNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramNamedParameter4fvNV) { + snprintf(symboln, sizeof(symboln), "%sProgramNamedParameter4fvNV", symbol_prefix); + SET_ProgramNamedParameter4fvNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->PrimitiveRestartIndexNV) { + snprintf(symboln, sizeof(symboln), "%sPrimitiveRestartIndexNV", symbol_prefix); + SET_PrimitiveRestartIndexNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->PrimitiveRestartIndexNV) { + snprintf(symboln, sizeof(symboln), "%sPrimitiveRestartIndex", symbol_prefix); + SET_PrimitiveRestartIndexNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->PrimitiveRestartNV) { + snprintf(symboln, sizeof(symboln), "%sPrimitiveRestartNV", symbol_prefix); + SET_PrimitiveRestartNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->DepthBoundsEXT) { + snprintf(symboln, sizeof(symboln), "%sDepthBoundsEXT", symbol_prefix); + SET_DepthBoundsEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquationSeparateEXT) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationSeparate", symbol_prefix); + SET_BlendEquationSeparateEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquationSeparateEXT) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationSeparateEXT", symbol_prefix); + SET_BlendEquationSeparateEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlendEquationSeparateEXT) { + snprintf(symboln, sizeof(symboln), "%sBlendEquationSeparateATI", symbol_prefix); + SET_BlendEquationSeparateEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindFramebufferEXT) { + snprintf(symboln, sizeof(symboln), "%sBindFramebuffer", symbol_prefix); + SET_BindFramebufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindFramebufferEXT) { + snprintf(symboln, sizeof(symboln), "%sBindFramebufferEXT", symbol_prefix); + SET_BindFramebufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindRenderbufferEXT) { + snprintf(symboln, sizeof(symboln), "%sBindRenderbuffer", symbol_prefix); + SET_BindRenderbufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindRenderbufferEXT) { + snprintf(symboln, sizeof(symboln), "%sBindRenderbufferEXT", symbol_prefix); + SET_BindRenderbufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->CheckFramebufferStatusEXT) { + snprintf(symboln, sizeof(symboln), "%sCheckFramebufferStatus", symbol_prefix); + SET_CheckFramebufferStatusEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->CheckFramebufferStatusEXT) { + snprintf(symboln, sizeof(symboln), "%sCheckFramebufferStatusEXT", symbol_prefix); + SET_CheckFramebufferStatusEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteFramebuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sDeleteFramebuffers", symbol_prefix); + SET_DeleteFramebuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteFramebuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sDeleteFramebuffersEXT", symbol_prefix); + SET_DeleteFramebuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteRenderbuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sDeleteRenderbuffers", symbol_prefix); + SET_DeleteRenderbuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->DeleteRenderbuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sDeleteRenderbuffersEXT", symbol_prefix); + SET_DeleteRenderbuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferRenderbufferEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferRenderbuffer", symbol_prefix); + SET_FramebufferRenderbufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferRenderbufferEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferRenderbufferEXT", symbol_prefix); + SET_FramebufferRenderbufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTexture1DEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTexture1D", symbol_prefix); + SET_FramebufferTexture1DEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTexture1DEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTexture1DEXT", symbol_prefix); + SET_FramebufferTexture1DEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTexture2DEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTexture2D", symbol_prefix); + SET_FramebufferTexture2DEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTexture2DEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTexture2DEXT", symbol_prefix); + SET_FramebufferTexture2DEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTexture3DEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTexture3D", symbol_prefix); + SET_FramebufferTexture3DEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTexture3DEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTexture3DEXT", symbol_prefix); + SET_FramebufferTexture3DEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenFramebuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sGenFramebuffers", symbol_prefix); + SET_GenFramebuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenFramebuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sGenFramebuffersEXT", symbol_prefix); + SET_GenFramebuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenRenderbuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sGenRenderbuffers", symbol_prefix); + SET_GenRenderbuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenRenderbuffersEXT) { + snprintf(symboln, sizeof(symboln), "%sGenRenderbuffersEXT", symbol_prefix); + SET_GenRenderbuffersEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenerateMipmapEXT) { + snprintf(symboln, sizeof(symboln), "%sGenerateMipmap", symbol_prefix); + SET_GenerateMipmapEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GenerateMipmapEXT) { + snprintf(symboln, sizeof(symboln), "%sGenerateMipmapEXT", symbol_prefix); + SET_GenerateMipmapEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFramebufferAttachmentParameterivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetFramebufferAttachmentParameteriv", symbol_prefix); + SET_GetFramebufferAttachmentParameterivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFramebufferAttachmentParameterivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetFramebufferAttachmentParameterivEXT", symbol_prefix); + SET_GetFramebufferAttachmentParameterivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetRenderbufferParameterivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetRenderbufferParameteriv", symbol_prefix); + SET_GetRenderbufferParameterivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetRenderbufferParameterivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetRenderbufferParameterivEXT", symbol_prefix); + SET_GetRenderbufferParameterivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsFramebufferEXT) { + snprintf(symboln, sizeof(symboln), "%sIsFramebuffer", symbol_prefix); + SET_IsFramebufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsFramebufferEXT) { + snprintf(symboln, sizeof(symboln), "%sIsFramebufferEXT", symbol_prefix); + SET_IsFramebufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsRenderbufferEXT) { + snprintf(symboln, sizeof(symboln), "%sIsRenderbuffer", symbol_prefix); + SET_IsRenderbufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsRenderbufferEXT) { + snprintf(symboln, sizeof(symboln), "%sIsRenderbufferEXT", symbol_prefix); + SET_IsRenderbufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->RenderbufferStorageEXT) { + snprintf(symboln, sizeof(symboln), "%sRenderbufferStorage", symbol_prefix); + SET_RenderbufferStorageEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->RenderbufferStorageEXT) { + snprintf(symboln, sizeof(symboln), "%sRenderbufferStorageEXT", symbol_prefix); + SET_RenderbufferStorageEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlitFramebufferEXT) { + snprintf(symboln, sizeof(symboln), "%sBlitFramebuffer", symbol_prefix); + SET_BlitFramebufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BlitFramebufferEXT) { + snprintf(symboln, sizeof(symboln), "%sBlitFramebufferEXT", symbol_prefix); + SET_BlitFramebufferEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BufferParameteriAPPLE) { + snprintf(symboln, sizeof(symboln), "%sBufferParameteriAPPLE", symbol_prefix); + SET_BufferParameteriAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->FlushMappedBufferRangeAPPLE) { + snprintf(symboln, sizeof(symboln), "%sFlushMappedBufferRangeAPPLE", symbol_prefix); + SET_FlushMappedBufferRangeAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindFragDataLocationEXT) { + snprintf(symboln, sizeof(symboln), "%sBindFragDataLocationEXT", symbol_prefix); + SET_BindFragDataLocationEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindFragDataLocationEXT) { + snprintf(symboln, sizeof(symboln), "%sBindFragDataLocation", symbol_prefix); + SET_BindFragDataLocationEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFragDataLocationEXT) { + snprintf(symboln, sizeof(symboln), "%sGetFragDataLocationEXT", symbol_prefix); + SET_GetFragDataLocationEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetFragDataLocationEXT) { + snprintf(symboln, sizeof(symboln), "%sGetFragDataLocation", symbol_prefix); + SET_GetFragDataLocationEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformuivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetUniformuivEXT", symbol_prefix); + SET_GetUniformuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetUniformuivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetUniformuiv", symbol_prefix); + SET_GetUniformuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribIivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribIivEXT", symbol_prefix); + SET_GetVertexAttribIivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribIivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribIiv", symbol_prefix); + SET_GetVertexAttribIivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribIuivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribIuivEXT", symbol_prefix); + SET_GetVertexAttribIuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetVertexAttribIuivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetVertexAttribIuiv", symbol_prefix); + SET_GetVertexAttribIuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform1uiEXT", symbol_prefix); + SET_Uniform1uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform1ui", symbol_prefix); + SET_Uniform1uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform1uivEXT", symbol_prefix); + SET_Uniform1uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform1uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform1uiv", symbol_prefix); + SET_Uniform1uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform2uiEXT", symbol_prefix); + SET_Uniform2uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform2ui", symbol_prefix); + SET_Uniform2uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform2uivEXT", symbol_prefix); + SET_Uniform2uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform2uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform2uiv", symbol_prefix); + SET_Uniform2uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform3uiEXT", symbol_prefix); + SET_Uniform3uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform3ui", symbol_prefix); + SET_Uniform3uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform3uivEXT", symbol_prefix); + SET_Uniform3uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform3uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform3uiv", symbol_prefix); + SET_Uniform3uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform4uiEXT", symbol_prefix); + SET_Uniform4uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4uiEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform4ui", symbol_prefix); + SET_Uniform4uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform4uivEXT", symbol_prefix); + SET_Uniform4uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->Uniform4uivEXT) { + snprintf(symboln, sizeof(symboln), "%sUniform4uiv", symbol_prefix); + SET_Uniform4uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1iEXT", symbol_prefix); + SET_VertexAttribI1iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1i", symbol_prefix); + SET_VertexAttribI1iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1ivEXT", symbol_prefix); + SET_VertexAttribI1ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1iv", symbol_prefix); + SET_VertexAttribI1ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1uiEXT", symbol_prefix); + SET_VertexAttribI1uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1ui", symbol_prefix); + SET_VertexAttribI1uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1uivEXT", symbol_prefix); + SET_VertexAttribI1uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI1uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI1uiv", symbol_prefix); + SET_VertexAttribI1uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2iEXT", symbol_prefix); + SET_VertexAttribI2iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2i", symbol_prefix); + SET_VertexAttribI2iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2ivEXT", symbol_prefix); + SET_VertexAttribI2ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2iv", symbol_prefix); + SET_VertexAttribI2ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2uiEXT", symbol_prefix); + SET_VertexAttribI2uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2ui", symbol_prefix); + SET_VertexAttribI2uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2uivEXT", symbol_prefix); + SET_VertexAttribI2uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI2uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI2uiv", symbol_prefix); + SET_VertexAttribI2uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3iEXT", symbol_prefix); + SET_VertexAttribI3iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3i", symbol_prefix); + SET_VertexAttribI3iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3ivEXT", symbol_prefix); + SET_VertexAttribI3ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3iv", symbol_prefix); + SET_VertexAttribI3ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3uiEXT", symbol_prefix); + SET_VertexAttribI3uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3ui", symbol_prefix); + SET_VertexAttribI3uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3uivEXT", symbol_prefix); + SET_VertexAttribI3uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI3uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI3uiv", symbol_prefix); + SET_VertexAttribI3uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4bvEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4bvEXT", symbol_prefix); + SET_VertexAttribI4bvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4bvEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4bv", symbol_prefix); + SET_VertexAttribI4bvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4iEXT", symbol_prefix); + SET_VertexAttribI4iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4iEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4i", symbol_prefix); + SET_VertexAttribI4iEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4ivEXT", symbol_prefix); + SET_VertexAttribI4ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4ivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4iv", symbol_prefix); + SET_VertexAttribI4ivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4svEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4svEXT", symbol_prefix); + SET_VertexAttribI4svEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4svEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4sv", symbol_prefix); + SET_VertexAttribI4svEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4ubvEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4ubvEXT", symbol_prefix); + SET_VertexAttribI4ubvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4ubvEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4ubv", symbol_prefix); + SET_VertexAttribI4ubvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4uiEXT", symbol_prefix); + SET_VertexAttribI4uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4uiEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4ui", symbol_prefix); + SET_VertexAttribI4uiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4uivEXT", symbol_prefix); + SET_VertexAttribI4uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4uivEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4uiv", symbol_prefix); + SET_VertexAttribI4uivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4usvEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4usvEXT", symbol_prefix); + SET_VertexAttribI4usvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribI4usvEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribI4usv", symbol_prefix); + SET_VertexAttribI4usvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribIPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribIPointerEXT", symbol_prefix); + SET_VertexAttribIPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->VertexAttribIPointerEXT) { + snprintf(symboln, sizeof(symboln), "%sVertexAttribIPointer", symbol_prefix); + SET_VertexAttribIPointerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTextureLayerEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTextureLayer", symbol_prefix); + SET_FramebufferTextureLayerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->FramebufferTextureLayerEXT) { + snprintf(symboln, sizeof(symboln), "%sFramebufferTextureLayerEXT", symbol_prefix); + SET_FramebufferTextureLayerEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorMaskIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sColorMaskIndexedEXT", symbol_prefix); + SET_ColorMaskIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->ColorMaskIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sColorMaski", symbol_prefix); + SET_ColorMaskIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->DisableIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sDisableIndexedEXT", symbol_prefix); + SET_DisableIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->DisableIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sDisablei", symbol_prefix); + SET_DisableIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->EnableIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sEnableIndexedEXT", symbol_prefix); + SET_EnableIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->EnableIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sEnablei", symbol_prefix); + SET_EnableIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBooleanIndexedvEXT) { + snprintf(symboln, sizeof(symboln), "%sGetBooleanIndexedvEXT", symbol_prefix); + SET_GetBooleanIndexedvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetBooleanIndexedvEXT) { + snprintf(symboln, sizeof(symboln), "%sGetBooleani_v", symbol_prefix); + SET_GetBooleanIndexedvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetIntegerIndexedvEXT) { + snprintf(symboln, sizeof(symboln), "%sGetIntegerIndexedvEXT", symbol_prefix); + SET_GetIntegerIndexedvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetIntegerIndexedvEXT) { + snprintf(symboln, sizeof(symboln), "%sGetIntegeri_v", symbol_prefix); + SET_GetIntegerIndexedvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsEnabledIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sIsEnabledIndexedEXT", symbol_prefix); + SET_IsEnabledIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->IsEnabledIndexedEXT) { + snprintf(symboln, sizeof(symboln), "%sIsEnabledi", symbol_prefix); + SET_IsEnabledIndexedEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearColorIiEXT) { + snprintf(symboln, sizeof(symboln), "%sClearColorIiEXT", symbol_prefix); + SET_ClearColorIiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->ClearColorIuiEXT) { + snprintf(symboln, sizeof(symboln), "%sClearColorIuiEXT", symbol_prefix); + SET_ClearColorIuiEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexParameterIivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetTexParameterIivEXT", symbol_prefix); + SET_GetTexParameterIivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexParameterIivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetTexParameterIiv", symbol_prefix); + SET_GetTexParameterIivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexParameterIuivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetTexParameterIuivEXT", symbol_prefix); + SET_GetTexParameterIuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexParameterIuivEXT) { + snprintf(symboln, sizeof(symboln), "%sGetTexParameterIuiv", symbol_prefix); + SET_GetTexParameterIuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameterIivEXT) { + snprintf(symboln, sizeof(symboln), "%sTexParameterIivEXT", symbol_prefix); + SET_TexParameterIivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameterIivEXT) { + snprintf(symboln, sizeof(symboln), "%sTexParameterIiv", symbol_prefix); + SET_TexParameterIivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameterIuivEXT) { + snprintf(symboln, sizeof(symboln), "%sTexParameterIuivEXT", symbol_prefix); + SET_TexParameterIuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TexParameterIuivEXT) { + snprintf(symboln, sizeof(symboln), "%sTexParameterIuiv", symbol_prefix); + SET_TexParameterIuivEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BeginConditionalRenderNV) { + snprintf(symboln, sizeof(symboln), "%sBeginConditionalRenderNV", symbol_prefix); + SET_BeginConditionalRenderNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->BeginConditionalRenderNV) { + snprintf(symboln, sizeof(symboln), "%sBeginConditionalRender", symbol_prefix); + SET_BeginConditionalRenderNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndConditionalRenderNV) { + snprintf(symboln, sizeof(symboln), "%sEndConditionalRenderNV", symbol_prefix); + SET_EndConditionalRenderNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndConditionalRenderNV) { + snprintf(symboln, sizeof(symboln), "%sEndConditionalRender", symbol_prefix); + SET_EndConditionalRenderNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->BeginTransformFeedbackEXT) { + snprintf(symboln, sizeof(symboln), "%sBeginTransformFeedbackEXT", symbol_prefix); + SET_BeginTransformFeedbackEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BeginTransformFeedbackEXT) { + snprintf(symboln, sizeof(symboln), "%sBeginTransformFeedback", symbol_prefix); + SET_BeginTransformFeedbackEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindBufferBaseEXT) { + snprintf(symboln, sizeof(symboln), "%sBindBufferBaseEXT", symbol_prefix); + SET_BindBufferBaseEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindBufferBaseEXT) { + snprintf(symboln, sizeof(symboln), "%sBindBufferBase", symbol_prefix); + SET_BindBufferBaseEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindBufferOffsetEXT) { + snprintf(symboln, sizeof(symboln), "%sBindBufferOffsetEXT", symbol_prefix); + SET_BindBufferOffsetEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindBufferRangeEXT) { + snprintf(symboln, sizeof(symboln), "%sBindBufferRangeEXT", symbol_prefix); + SET_BindBufferRangeEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->BindBufferRangeEXT) { + snprintf(symboln, sizeof(symboln), "%sBindBufferRange", symbol_prefix); + SET_BindBufferRangeEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndTransformFeedbackEXT) { + snprintf(symboln, sizeof(symboln), "%sEndTransformFeedbackEXT", symbol_prefix); + SET_EndTransformFeedbackEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->EndTransformFeedbackEXT) { + snprintf(symboln, sizeof(symboln), "%sEndTransformFeedback", symbol_prefix); + SET_EndTransformFeedbackEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTransformFeedbackVaryingEXT) { + snprintf(symboln, sizeof(symboln), "%sGetTransformFeedbackVaryingEXT", symbol_prefix); + SET_GetTransformFeedbackVaryingEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTransformFeedbackVaryingEXT) { + snprintf(symboln, sizeof(symboln), "%sGetTransformFeedbackVarying", symbol_prefix); + SET_GetTransformFeedbackVaryingEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TransformFeedbackVaryingsEXT) { + snprintf(symboln, sizeof(symboln), "%sTransformFeedbackVaryingsEXT", symbol_prefix); + SET_TransformFeedbackVaryingsEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TransformFeedbackVaryingsEXT) { + snprintf(symboln, sizeof(symboln), "%sTransformFeedbackVaryings", symbol_prefix); + SET_TransformFeedbackVaryingsEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProvokingVertexEXT) { + snprintf(symboln, sizeof(symboln), "%sProvokingVertexEXT", symbol_prefix); + SET_ProvokingVertexEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProvokingVertexEXT) { + snprintf(symboln, sizeof(symboln), "%sProvokingVertex", symbol_prefix); + SET_ProvokingVertexEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetTexParameterPointervAPPLE) { + snprintf(symboln, sizeof(symboln), "%sGetTexParameterPointervAPPLE", symbol_prefix); + SET_GetTexParameterPointervAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->TextureRangeAPPLE) { + snprintf(symboln, sizeof(symboln), "%sTextureRangeAPPLE", symbol_prefix); + SET_TextureRangeAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetObjectParameterivAPPLE) { + snprintf(symboln, sizeof(symboln), "%sGetObjectParameterivAPPLE", symbol_prefix); + SET_GetObjectParameterivAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->ObjectPurgeableAPPLE) { + snprintf(symboln, sizeof(symboln), "%sObjectPurgeableAPPLE", symbol_prefix); + SET_ObjectPurgeableAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->ObjectUnpurgeableAPPLE) { + snprintf(symboln, sizeof(symboln), "%sObjectUnpurgeableAPPLE", symbol_prefix); + SET_ObjectUnpurgeableAPPLE(disp, dlsym(handle, symboln)); + } + + + if(!disp->ActiveProgramEXT) { + snprintf(symboln, sizeof(symboln), "%sActiveProgramEXT", symbol_prefix); + SET_ActiveProgramEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->CreateShaderProgramEXT) { + snprintf(symboln, sizeof(symboln), "%sCreateShaderProgramEXT", symbol_prefix); + SET_CreateShaderProgramEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->UseShaderProgramEXT) { + snprintf(symboln, sizeof(symboln), "%sUseShaderProgramEXT", symbol_prefix); + SET_UseShaderProgramEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->TextureBarrierNV) { + snprintf(symboln, sizeof(symboln), "%sTextureBarrierNV", symbol_prefix); + SET_TextureBarrierNV(disp, dlsym(handle, symboln)); + } + + + if(!disp->StencilFuncSeparateATI) { + snprintf(symboln, sizeof(symboln), "%sStencilFuncSeparateATI", symbol_prefix); + SET_StencilFuncSeparateATI(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramEnvParameters4fvEXT) { + snprintf(symboln, sizeof(symboln), "%sProgramEnvParameters4fvEXT", symbol_prefix); + SET_ProgramEnvParameters4fvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->ProgramLocalParameters4fvEXT) { + snprintf(symboln, sizeof(symboln), "%sProgramLocalParameters4fvEXT", symbol_prefix); + SET_ProgramLocalParameters4fvEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryObjecti64vEXT) { + snprintf(symboln, sizeof(symboln), "%sGetQueryObjecti64vEXT", symbol_prefix); + SET_GetQueryObjecti64vEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->GetQueryObjectui64vEXT) { + snprintf(symboln, sizeof(symboln), "%sGetQueryObjectui64vEXT", symbol_prefix); + SET_GetQueryObjectui64vEXT(disp, dlsym(handle, symboln)); + } + + + if(!disp->EGLImageTargetRenderbufferStorageOES) { + snprintf(symboln, sizeof(symboln), "%sEGLImageTargetRenderbufferStorageOES", symbol_prefix); + SET_EGLImageTargetRenderbufferStorageOES(disp, dlsym(handle, symboln)); + } + + + if(!disp->EGLImageTargetTexture2DOES) { + snprintf(symboln, sizeof(symboln), "%sEGLImageTargetTexture2DOES", symbol_prefix); + SET_EGLImageTargetTexture2DOES(disp, dlsym(handle, symboln)); + } + + + return disp; +} + diff --git a/mesalib/src/mapi/glapi/sources.mak b/mesalib/src/mapi/glapi/sources.mak index 39e18d16f..dfc6cc6db 100644 --- a/mesalib/src/mapi/glapi/sources.mak +++ b/mesalib/src/mapi/glapi/sources.mak @@ -1,18 +1,19 @@ -# src/mapi/glapi/sources.mak
-
-GLAPI_SOURCES = \
- glapi_dispatch.c \
- glapi_entrypoint.c \
- glapi_getproc.c \
- glapi_nop.c \
- glthread.c \
- glapi.c
-
-X86_API = \
- glapi_x86.S
-
-X86-64_API = \
- glapi_x86-64.S
-
-SPARC_API = \
- glapi_sparc.S
+# src/mapi/glapi/sources.mak + +GLAPI_SOURCES = \ + glapi_dispatch.c \ + glapi_entrypoint.c \ + glapi_gentable.c \ + glapi_getproc.c \ + glapi_nop.c \ + glthread.c \ + glapi.c + +X86_API = \ + glapi_x86.S + +X86-64_API = \ + glapi_x86-64.S + +SPARC_API = \ + glapi_sparc.S diff --git a/mesalib/src/mapi/mapi/entry_x86-64_tls.h b/mesalib/src/mapi/mapi/entry_x86-64_tls.h index d3b606c8a..72d4125a6 100644 --- a/mesalib/src/mapi/mapi/entry_x86-64_tls.h +++ b/mesalib/src/mapi/mapi/entry_x86-64_tls.h @@ -76,10 +76,12 @@ entry_patch_public(void) { } +static char +x86_64_entry_start[]; + mapi_func entry_get_public(int slot) { - extern char x86_64_entry_start[]; return (mapi_func) (x86_64_entry_start + slot * 32); } diff --git a/mesalib/src/mapi/mapi/entry_x86_tls.h b/mesalib/src/mapi/mapi/entry_x86_tls.h index 5169069a1..de918128e 100644 --- a/mesalib/src/mapi/mapi/entry_x86_tls.h +++ b/mesalib/src/mapi/mapi/entry_x86_tls.h @@ -86,12 +86,13 @@ __asm__(".text"); extern unsigned long x86_current_tls(); +static char x86_entry_start[]; +static char x86_entry_end[]; + void entry_patch_public(void) { #ifndef GLX_X86_READONLY_TEXT - extern char x86_entry_start[]; - extern char x86_entry_end[]; char patch[8] = { 0x65, 0xa1, 0x00, 0x00, 0x00, 0x00, /* movl %gs:0x0, %eax */ 0x90, 0x90 /* nop's */ @@ -108,7 +109,6 @@ entry_patch_public(void) mapi_func entry_get_public(int slot) { - extern char x86_entry_start[]; return (mapi_func) (x86_entry_start + slot * 16); } diff --git a/mesalib/src/mapi/mapi/entry_x86_tsd.h b/mesalib/src/mapi/mapi/entry_x86_tsd.h index 1491478d4..c479c199e 100644 --- a/mesalib/src/mapi/mapi/entry_x86_tsd.h +++ b/mesalib/src/mapi/mapi/entry_x86_tsd.h @@ -60,6 +60,9 @@ __asm__(".balign 32\n" #include <string.h> #include "u_execmem.h" +static const char x86_entry_start[]; +static const char x86_entry_end[]; + void entry_patch_public(void) { @@ -68,7 +71,6 @@ entry_patch_public(void) mapi_func entry_get_public(int slot) { - extern const char x86_entry_start[]; return (mapi_func) (x86_entry_start + slot * X86_ENTRY_SIZE); } @@ -84,7 +86,6 @@ entry_patch(mapi_func entry, int slot) mapi_func entry_generate(int slot) { - extern const char x86_entry_end[]; const char *code_templ = x86_entry_end - X86_ENTRY_SIZE; void *code; mapi_func entry; diff --git a/mesalib/src/mesa/state_tracker/st_draw.c b/mesalib/src/mesa/state_tracker/st_draw.c index 56955d357..dd26db2f6 100644 --- a/mesalib/src/mesa/state_tracker/st_draw.c +++ b/mesalib/src/mesa/state_tracker/st_draw.c @@ -650,7 +650,8 @@ st_draw_vbo(struct gl_context *ctx, struct pipe_draw_info info; unsigned i, num_instances = 1; GLboolean new_array = - st->dirty.st && (st->dirty.mesa & (_NEW_ARRAY | _NEW_PROGRAM)) != 0; + st->dirty.st && + (st->dirty.mesa & (_NEW_ARRAY | _NEW_PROGRAM | _NEW_BUFFER_OBJECT)) != 0; /* Mesa core state should have been validated already */ assert(ctx->NewState == 0x0); |