gallium: add condition parameter to render_condition
[mesa.git] / src / gallium / drivers / galahad / glhd_context.c
index 6dfee2c7a71645fcefa3df241a860cdc39a0eca6..ee9de058bb03aeef8e53e8d4650284197211e78c 100644 (file)
@@ -37,7 +37,7 @@
 
 
 static void
-galahad_destroy(struct pipe_context *_pipe)
+galahad_context_destroy(struct pipe_context *_pipe)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
@@ -48,83 +48,42 @@ galahad_destroy(struct pipe_context *_pipe)
 }
 
 static void
-galahad_draw_arrays(struct pipe_context *_pipe,
-                     unsigned prim,
-                     unsigned start,
-                     unsigned count)
+galahad_context_draw_vbo(struct pipe_context *_pipe,
+                 const struct pipe_draw_info *info)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
-   pipe->draw_arrays(pipe,
-                     prim,
-                     start,
-                     count);
-}
-
-static void
-galahad_draw_elements(struct pipe_context *_pipe,
-                       struct pipe_resource *_indexResource,
-                       unsigned indexSize,
-                       int indexBias,
-                       unsigned prim,
-                       unsigned start,
-                       unsigned count)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct galahad_resource *glhd_resource = galahad_resource(_indexResource);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-   struct pipe_resource *indexResource = glhd_resource->resource;
-
-   pipe->draw_elements(pipe,
-                       indexResource,
-                       indexSize,
-                       indexBias,
-                       prim,
-                       start,
-                       count);
-}
-
-static void
-galahad_draw_range_elements(struct pipe_context *_pipe,
-                             struct pipe_resource *_indexResource,
-                             unsigned indexSize,
-                             int indexBias,
-                             unsigned minIndex,
-                             unsigned maxIndex,
-                             unsigned mode,
-                             unsigned start,
-                             unsigned count)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct galahad_resource *glhd_resource = galahad_resource(_indexResource);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-   struct pipe_resource *indexResource = glhd_resource->resource;
+   /* XXX we should check that all bound resources are unmapped
+    * before drawing.
+    */
 
-   pipe->draw_range_elements(pipe,
-                             indexResource,
-                             indexSize,
-                             indexBias,
-                             minIndex,
-                             maxIndex,
-                             mode,
-                             start,
-                             count);
+   pipe->draw_vbo(pipe, info);
 }
 
 static struct pipe_query *
-galahad_create_query(struct pipe_context *_pipe,
+galahad_context_create_query(struct pipe_context *_pipe,
                       unsigned query_type)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
+   if (query_type == PIPE_QUERY_OCCLUSION_COUNTER &&
+      !pipe->screen->get_param(pipe->screen, PIPE_CAP_OCCLUSION_QUERY)) {
+      glhd_error("Occlusion query requested but not supported");
+   }
+
+   if (query_type == PIPE_QUERY_TIME_ELAPSED &&
+      !pipe->screen->get_param(pipe->screen, PIPE_CAP_QUERY_TIME_ELAPSED)) {
+      glhd_error("Timer query requested but not supported");
+   }
+
    return pipe->create_query(pipe,
                              query_type);
 }
 
 static void
-galahad_destroy_query(struct pipe_context *_pipe,
+galahad_context_destroy_query(struct pipe_context *_pipe,
                        struct pipe_query *query)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -135,7 +94,7 @@ galahad_destroy_query(struct pipe_context *_pipe,
 }
 
 static void
-galahad_begin_query(struct pipe_context *_pipe,
+galahad_context_begin_query(struct pipe_context *_pipe,
                      struct pipe_query *query)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -146,7 +105,7 @@ galahad_begin_query(struct pipe_context *_pipe,
 }
 
 static void
-galahad_end_query(struct pipe_context *_pipe,
+galahad_context_end_query(struct pipe_context *_pipe,
                    struct pipe_query *query)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -157,10 +116,10 @@ galahad_end_query(struct pipe_context *_pipe,
 }
 
 static boolean
-galahad_get_query_result(struct pipe_context *_pipe,
+galahad_context_get_query_result(struct pipe_context *_pipe,
                           struct pipe_query *query,
                           boolean wait,
-                          void *result)
+                          union pipe_query_result *result)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
@@ -172,18 +131,25 @@ galahad_get_query_result(struct pipe_context *_pipe,
 }
 
 static void *
-galahad_create_blend_state(struct pipe_context *_pipe,
+galahad_context_create_blend_state(struct pipe_context *_pipe,
                             const struct pipe_blend_state *blend)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
+   if (blend->logicop_enable) {
+      if (blend->rt[0].blend_enable) {
+         glhd_warn("Blending enabled for render target 0, but logicops "
+            "are enabled");
+      }
+   }
+
    return pipe->create_blend_state(pipe,
                                    blend);
 }
 
 static void
-galahad_bind_blend_state(struct pipe_context *_pipe,
+galahad_context_bind_blend_state(struct pipe_context *_pipe,
                           void *blend)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -194,7 +160,7 @@ galahad_bind_blend_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_delete_blend_state(struct pipe_context *_pipe,
+galahad_context_delete_blend_state(struct pipe_context *_pipe,
                             void *blend)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -205,7 +171,7 @@ galahad_delete_blend_state(struct pipe_context *_pipe,
 }
 
 static void *
-galahad_create_sampler_state(struct pipe_context *_pipe,
+galahad_context_create_sampler_state(struct pipe_context *_pipe,
                               const struct pipe_sampler_state *sampler)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -216,33 +182,66 @@ galahad_create_sampler_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_bind_fragment_sampler_states(struct pipe_context *_pipe,
-                                      unsigned num_samplers,
-                                      void **samplers)
+galahad_context_bind_sampler_states(struct pipe_context *_pipe,
+                                    unsigned shader,
+                                    unsigned start,
+                                    unsigned num_samplers,
+                                    void **samplers)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
-   pipe->bind_fragment_sampler_states(pipe,
-                                      num_samplers,
-                                      samplers);
+   if (num_samplers > PIPE_MAX_SAMPLERS) {
+      glhd_error("%u samplers requested, "
+         "but only %u are permitted by API",
+         num_samplers, PIPE_MAX_SAMPLERS);
+   }
+
+   switch (shader) {
+   case PIPE_SHADER_VERTEX:
+      pipe->bind_vertex_sampler_states(pipe, num_samplers, samplers);
+      break;
+   case PIPE_SHADER_FRAGMENT:
+      pipe->bind_fragment_sampler_states(pipe, num_samplers, samplers);
+      break;
+   case PIPE_SHADER_GEOMETRY:
+      pipe->bind_geometry_sampler_states(pipe, num_samplers, samplers);
+      break;
+   default:
+      assert(0);
+   }
+}
+
+static void
+galahad_context_bind_vertex_sampler_states(struct pipe_context *_pipe,
+                                           unsigned num_samplers,
+                                           void **samplers)
+{
+   galahad_context_bind_sampler_states(_pipe, PIPE_SHADER_VERTEX,
+                                       0, num_samplers, samplers);
 }
 
 static void
-galahad_bind_vertex_sampler_states(struct pipe_context *_pipe,
-                                    unsigned num_samplers,
-                                    void **samplers)
+galahad_context_bind_fragment_sampler_states(struct pipe_context *_pipe,
+                                             unsigned num_samplers,
+                                             void **samplers)
 {
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
+   galahad_context_bind_sampler_states(_pipe, PIPE_SHADER_FRAGMENT,
+                                       0, num_samplers, samplers);
+}
 
-   pipe->bind_vertex_sampler_states(pipe,
-                                    num_samplers,
-                                    samplers);
+static void
+galahad_context_bind_geometry_sampler_states(struct pipe_context *_pipe,
+                                             unsigned num_samplers,
+                                             void **samplers)
+{
+   galahad_context_bind_sampler_states(_pipe, PIPE_SHADER_GEOMETRY,
+                                       0, num_samplers, samplers);
 }
 
+
 static void
-galahad_delete_sampler_state(struct pipe_context *_pipe,
+galahad_context_delete_sampler_state(struct pipe_context *_pipe,
                               void *sampler)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -253,18 +252,28 @@ galahad_delete_sampler_state(struct pipe_context *_pipe,
 }
 
 static void *
-galahad_create_rasterizer_state(struct pipe_context *_pipe,
+galahad_context_create_rasterizer_state(struct pipe_context *_pipe,
                                  const struct pipe_rasterizer_state *rasterizer)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
+   if (rasterizer->point_quad_rasterization) {
+       if (rasterizer->point_smooth) {
+           glhd_warn("Point smoothing requested but ignored");
+       }
+   } else {
+       if (rasterizer->sprite_coord_enable) {
+           glhd_warn("Point sprites requested but ignored");
+       }
+   }
+
    return pipe->create_rasterizer_state(pipe,
                                         rasterizer);
 }
 
 static void
-galahad_bind_rasterizer_state(struct pipe_context *_pipe,
+galahad_context_bind_rasterizer_state(struct pipe_context *_pipe,
                                void *rasterizer)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -275,7 +284,7 @@ galahad_bind_rasterizer_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_delete_rasterizer_state(struct pipe_context *_pipe,
+galahad_context_delete_rasterizer_state(struct pipe_context *_pipe,
                                  void *rasterizer)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -286,7 +295,7 @@ galahad_delete_rasterizer_state(struct pipe_context *_pipe,
 }
 
 static void *
-galahad_create_depth_stencil_alpha_state(struct pipe_context *_pipe,
+galahad_context_create_depth_stencil_alpha_state(struct pipe_context *_pipe,
                                           const struct pipe_depth_stencil_alpha_state *depth_stencil_alpha)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -297,7 +306,7 @@ galahad_create_depth_stencil_alpha_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_bind_depth_stencil_alpha_state(struct pipe_context *_pipe,
+galahad_context_bind_depth_stencil_alpha_state(struct pipe_context *_pipe,
                                         void *depth_stencil_alpha)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -308,7 +317,7 @@ galahad_bind_depth_stencil_alpha_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_delete_depth_stencil_alpha_state(struct pipe_context *_pipe,
+galahad_context_delete_depth_stencil_alpha_state(struct pipe_context *_pipe,
                                           void *depth_stencil_alpha)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -318,88 +327,57 @@ galahad_delete_depth_stencil_alpha_state(struct pipe_context *_pipe,
                                           depth_stencil_alpha);
 }
 
-static void *
-galahad_create_fs_state(struct pipe_context *_pipe,
-                         const struct pipe_shader_state *fs)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-
-   return pipe->create_fs_state(pipe,
-                                fs);
-}
-
-static void
-galahad_bind_fs_state(struct pipe_context *_pipe,
-                       void *fs)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-
-   pipe->bind_fs_state(pipe,
-                       fs);
-}
-
-static void
-galahad_delete_fs_state(struct pipe_context *_pipe,
-                         void *fs)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-
-   pipe->delete_fs_state(pipe,
-                         fs);
-}
-
-static void *
-galahad_create_vs_state(struct pipe_context *_pipe,
-                         const struct pipe_shader_state *vs)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-
-   return pipe->create_vs_state(pipe,
-                                vs);
-}
-
-static void
-galahad_bind_vs_state(struct pipe_context *_pipe,
-                       void *vs)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-
-   pipe->bind_vs_state(pipe,
-                       vs);
-}
-
-static void
-galahad_delete_vs_state(struct pipe_context *_pipe,
-                         void *vs)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
+#define GLHD_SHADER_STATE(shader_type) \
+   static void * \
+   galahad_context_create_##shader_type##_state(struct pipe_context *_pipe, \
+                            const struct pipe_shader_state *state) \
+   { \
+      struct galahad_context *glhd_pipe = galahad_context(_pipe); \
+      struct pipe_context *pipe = glhd_pipe->pipe; \
+      return pipe->create_##shader_type##_state(pipe, state); \
+   } \
+   \
+   static void \
+   galahad_context_bind_##shader_type##_state(struct pipe_context *_pipe, \
+                                              void *state) \
+   { \
+      struct galahad_context *glhd_pipe = galahad_context(_pipe); \
+      struct pipe_context *pipe = glhd_pipe->pipe; \
+      pipe->bind_##shader_type##_state(pipe, state); \
+   } \
+   \
+   static void \
+   galahad_context_delete_##shader_type##_state(struct pipe_context *_pipe, \
+                                                void *state) \
+   { \
+      struct galahad_context *glhd_pipe = galahad_context(_pipe); \
+      struct pipe_context *pipe = glhd_pipe->pipe; \
+      pipe->delete_##shader_type##_state(pipe, state); \
+   }
 
-   pipe->delete_vs_state(pipe,
-                         vs);
-}
+GLHD_SHADER_STATE(fs)
+GLHD_SHADER_STATE(vs)
+GLHD_SHADER_STATE(gs)
 
+#undef GLHD_SHADER_STATE
 
 static void *
-galahad_create_vertex_elements_state(struct pipe_context *_pipe,
+galahad_context_create_vertex_elements_state(struct pipe_context *_pipe,
                                       unsigned num_elements,
                                       const struct pipe_vertex_element *vertex_elements)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
+   /* XXX check if stride lines up with element size, at least for floats */
+
    return pipe->create_vertex_elements_state(pipe,
                                              num_elements,
                                              vertex_elements);
 }
 
 static void
-galahad_bind_vertex_elements_state(struct pipe_context *_pipe,
+galahad_context_bind_vertex_elements_state(struct pipe_context *_pipe,
                                     void *velems)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -410,7 +388,7 @@ galahad_bind_vertex_elements_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_delete_vertex_elements_state(struct pipe_context *_pipe,
+galahad_context_delete_vertex_elements_state(struct pipe_context *_pipe,
                                       void *velems)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -421,7 +399,7 @@ galahad_delete_vertex_elements_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_set_blend_color(struct pipe_context *_pipe,
+galahad_context_set_blend_color(struct pipe_context *_pipe,
                          const struct pipe_blend_color *blend_color)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -432,7 +410,7 @@ galahad_set_blend_color(struct pipe_context *_pipe,
 }
 
 static void
-galahad_set_stencil_ref(struct pipe_context *_pipe,
+galahad_context_set_stencil_ref(struct pipe_context *_pipe,
                          const struct pipe_stencil_ref *stencil_ref)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -443,7 +421,7 @@ galahad_set_stencil_ref(struct pipe_context *_pipe,
 }
 
 static void
-galahad_set_clip_state(struct pipe_context *_pipe,
+galahad_context_set_clip_state(struct pipe_context *_pipe,
                         const struct pipe_clip_state *clip)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -454,7 +432,7 @@ galahad_set_clip_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_set_sample_mask(struct pipe_context *_pipe,
+galahad_context_set_sample_mask(struct pipe_context *_pipe,
                          unsigned sample_mask)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -465,30 +443,42 @@ galahad_set_sample_mask(struct pipe_context *_pipe,
 }
 
 static void
-galahad_set_constant_buffer(struct pipe_context *_pipe,
+galahad_context_set_constant_buffer(struct pipe_context *_pipe,
                              uint shader,
                              uint index,
-                             struct pipe_resource *_resource)
+                             struct pipe_constant_buffer *_cb)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
-   struct pipe_resource *unwrapped_resource;
-   struct pipe_resource *resource = NULL;
+   struct pipe_constant_buffer cb;
+
+   if (shader >= PIPE_SHADER_TYPES) {
+      glhd_error("Unknown shader type %u", shader);
+   }
+
+   if (index &&
+      index >=
+         pipe->screen->get_shader_param(pipe->screen, shader, PIPE_SHADER_CAP_MAX_CONST_BUFFERS)) {
+      glhd_error("Access to constant buffer %u requested, "
+         "but only %d are supported",
+         index,
+         pipe->screen->get_shader_param(pipe->screen, shader, PIPE_SHADER_CAP_MAX_CONST_BUFFERS));
+   }
 
    /* XXX hmm? unwrap the input state */
-   if (_resource) {
-      unwrapped_resource = galahad_resource_unwrap(_resource);
-      resource = unwrapped_resource;
+   if (_cb) {
+      cb = *_cb;
+      cb.buffer = galahad_resource_unwrap(_cb->buffer);
    }
 
    pipe->set_constant_buffer(pipe,
                              shader,
                              index,
-                             resource);
+                             _cb ? &cb : NULL);
 }
 
 static void
-galahad_set_framebuffer_state(struct pipe_context *_pipe,
+galahad_context_set_framebuffer_state(struct pipe_context *_pipe,
                                const struct pipe_framebuffer_state *_state)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -497,6 +487,16 @@ galahad_set_framebuffer_state(struct pipe_context *_pipe,
    struct pipe_framebuffer_state *state = NULL;
    unsigned i;
 
+   if (_state->nr_cbufs > PIPE_MAX_COLOR_BUFS) {
+      glhd_error("%d render targets bound, but only %d are permitted by API",
+         _state->nr_cbufs, PIPE_MAX_COLOR_BUFS);
+   } else if (_state->nr_cbufs >
+      pipe->screen->get_param(pipe->screen, PIPE_CAP_MAX_RENDER_TARGETS)) {
+      glhd_warn("%d render targets bound, but only %d are supported",
+         _state->nr_cbufs,
+         pipe->screen->get_param(pipe->screen, PIPE_CAP_MAX_RENDER_TARGETS));
+   }
+
    /* unwrap the input state */
    if (_state) {
       memcpy(&unwrapped_state, _state, sizeof(unwrapped_state));
@@ -513,7 +513,7 @@ galahad_set_framebuffer_state(struct pipe_context *_pipe,
 }
 
 static void
-galahad_set_polygon_stipple(struct pipe_context *_pipe,
+galahad_context_set_polygon_stipple(struct pipe_context *_pipe,
                              const struct pipe_poly_stipple *poly_stipple)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -524,31 +524,37 @@ galahad_set_polygon_stipple(struct pipe_context *_pipe,
 }
 
 static void
-galahad_set_scissor_state(struct pipe_context *_pipe,
+galahad_context_set_scissor_states(struct pipe_context *_pipe,
+                                   unsigned start_slot,
+                                   unsigned num_scissors,
                            const struct pipe_scissor_state *scissor)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
-   pipe->set_scissor_state(pipe,
-                           scissor);
+   pipe->set_scissor_states(pipe, start_slot, num_scissors,
+                            scissor);
 }
 
 static void
-galahad_set_viewport_state(struct pipe_context *_pipe,
+galahad_context_set_viewport_states(struct pipe_context *_pipe,
+                                    unsigned start_slot,
+                                    unsigned num_viewports,
                             const struct pipe_viewport_state *viewport)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
 
-   pipe->set_viewport_state(pipe,
-                            viewport);
+   pipe->set_viewport_states(pipe, start_slot, num_viewports,
+                             viewport);
 }
 
 static void
-galahad_set_fragment_sampler_views(struct pipe_context *_pipe,
-                                    unsigned num,
-                                    struct pipe_sampler_view **_views)
+galahad_context_set_sampler_views(struct pipe_context *_pipe,
+                                  unsigned shader,
+                                  unsigned start,
+                                  unsigned num,
+                                  struct pipe_sampler_view **_views)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct pipe_context *pipe = glhd_pipe->pipe;
@@ -565,35 +571,51 @@ galahad_set_fragment_sampler_views(struct pipe_context *_pipe,
       views = unwrapped_views;
    }
 
-   pipe->set_fragment_sampler_views(pipe, num, views);
+   switch (shader) {
+   case PIPE_SHADER_VERTEX:
+      pipe->set_vertex_sampler_views(pipe, num, views);
+      break;
+   case PIPE_SHADER_FRAGMENT:
+      pipe->set_fragment_sampler_views(pipe, num, views);
+      break;
+   case PIPE_SHADER_GEOMETRY:
+      pipe->set_geometry_sampler_views(pipe, num, views);
+      break;
+   default:
+      assert(0);
+   }
 }
 
 static void
-galahad_set_vertex_sampler_views(struct pipe_context *_pipe,
-                                  unsigned num,
-                                  struct pipe_sampler_view **_views)
+galahad_context_set_vertex_sampler_views(struct pipe_context *_pipe,
+                                         unsigned num,
+                                         struct pipe_sampler_view **_views)
 {
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-   struct pipe_sampler_view *unwrapped_views[PIPE_MAX_VERTEX_SAMPLERS];
-   struct pipe_sampler_view **views = NULL;
-   unsigned i;
-
-   if (_views) {
-      for (i = 0; i < num; i++)
-         unwrapped_views[i] = galahad_sampler_view_unwrap(_views[i]);
-      for (; i < PIPE_MAX_VERTEX_SAMPLERS; i++)
-         unwrapped_views[i] = NULL;
+   galahad_context_set_sampler_views(_pipe, PIPE_SHADER_VERTEX,
+                                     0, num, _views);
+}
 
-      views = unwrapped_views;
-   }
+static void
+galahad_context_set_fragment_sampler_views(struct pipe_context *_pipe,
+                                           unsigned num,
+                                           struct pipe_sampler_view **_views)
+{
+   galahad_context_set_sampler_views(_pipe, PIPE_SHADER_FRAGMENT,
+                                     0, num, _views);
+}
 
-   pipe->set_vertex_sampler_views(pipe, num, views);
+static void
+galahad_context_set_geometry_sampler_views(struct pipe_context *_pipe,
+                                           unsigned num,
+                                           struct pipe_sampler_view **_views)
+{
+   galahad_context_set_sampler_views(_pipe, PIPE_SHADER_GEOMETRY,
+                                     0, num, _views);
 }
 
 static void
-galahad_set_vertex_buffers(struct pipe_context *_pipe,
-                            unsigned num_buffers,
+galahad_context_set_vertex_buffers(struct pipe_context *_pipe,
+                            unsigned start_slot, unsigned num_buffers,
                             const struct pipe_vertex_buffer *_buffers)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
@@ -602,7 +624,7 @@ galahad_set_vertex_buffers(struct pipe_context *_pipe,
    struct pipe_vertex_buffer *buffers = NULL;
    unsigned i;
 
-   if (num_buffers) {
+   if (num_buffers && _buffers) {
       memcpy(unwrapped_buffers, _buffers, num_buffers * sizeof(*_buffers));
       for (i = 0; i < num_buffers; i++)
          unwrapped_buffers[i].buffer = galahad_resource_unwrap(_buffers[i].buffer);
@@ -610,23 +632,91 @@ galahad_set_vertex_buffers(struct pipe_context *_pipe,
    }
 
    pipe->set_vertex_buffers(pipe,
-                            num_buffers,
+                            start_slot, num_buffers,
                             buffers);
 }
+
+static void
+galahad_context_set_index_buffer(struct pipe_context *_pipe,
+                         const struct pipe_index_buffer *_ib)
+{
+   struct galahad_context *glhd_pipe = galahad_context(_pipe);
+   struct pipe_context *pipe = glhd_pipe->pipe;
+   struct pipe_index_buffer unwrapped_ib, *ib = NULL;
+
+   if (_ib) {
+      if (_ib->buffer || _ib->user_buffer) {
+         switch (_ib->index_size) {
+         case 1:
+         case 2:
+         case 4:
+            break;
+         default:
+            glhd_warn("unrecognized index size %d", _ib->index_size);
+            break;
+         }
+      }
+      else if (_ib->offset || _ib->index_size) {
+         glhd_warn("non-indexed state with index offset %d and index size %d",
+               _ib->offset, _ib->index_size);
+      }
+
+      unwrapped_ib = *_ib;
+      unwrapped_ib.buffer = galahad_resource_unwrap(_ib->buffer);
+      ib = &unwrapped_ib;
+   }
+
+   pipe->set_index_buffer(pipe, ib);
+}
+
+static INLINE struct pipe_stream_output_target *
+galahad_context_create_stream_output_target(struct pipe_context *_pipe,
+                                            struct pipe_resource *_res,
+                                            unsigned buffer_offset,
+                                            unsigned buffer_size)
+{
+   struct galahad_context *glhd_pipe = galahad_context(_pipe);
+   struct galahad_resource *glhd_resource_res = galahad_resource(_res);
+   struct pipe_context *pipe = glhd_pipe->pipe;
+   struct pipe_resource *res = glhd_resource_res->resource;
+
+   return pipe->create_stream_output_target(pipe,
+                                            res, buffer_offset, buffer_size);
+}
+
+static INLINE void
+galahad_context_stream_output_target_destroy(
+   struct pipe_context *_pipe,
+   struct pipe_stream_output_target *target)
+{
+   struct galahad_context *glhd_pipe = galahad_context(_pipe);
+   struct pipe_context *pipe = glhd_pipe->pipe;
+
+   pipe->stream_output_target_destroy(pipe, target);
+}
+
+static INLINE void
+galahad_context_set_stream_output_targets(struct pipe_context *_pipe,
+                                          unsigned num_targets,
+                                          struct pipe_stream_output_target **tgs,
+                                          unsigned append_bitmask)
+{
+   struct galahad_context *glhd_pipe = galahad_context(_pipe);
+   struct pipe_context *pipe = glhd_pipe->pipe;
+
+   pipe->set_stream_output_targets(pipe, num_targets, tgs, append_bitmask);
+}
+
 static void
-galahad_resource_copy_region(struct pipe_context *_pipe,
-                              struct pipe_resource *_dst,
-                              struct pipe_subresource subdst,
-                              unsigned dstx,
-                              unsigned dsty,
-                              unsigned dstz,
-                              struct pipe_resource *_src,
-                              struct pipe_subresource subsrc,
-                              unsigned srcx,
-                              unsigned srcy,
-                              unsigned srcz,
-                              unsigned width,
-                              unsigned height)
+galahad_context_resource_copy_region(struct pipe_context *_pipe,
+                                     struct pipe_resource *_dst,
+                                     unsigned dst_level,
+                                     unsigned dstx,
+                                     unsigned dsty,
+                                     unsigned dstz,
+                                     struct pipe_resource *_src,
+                                     unsigned src_level,
+                                     const struct pipe_box *src_box)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
    struct galahad_resource *glhd_resource_dst = galahad_resource(_dst);
@@ -636,30 +726,66 @@ galahad_resource_copy_region(struct pipe_context *_pipe,
    struct pipe_resource *src = glhd_resource_src->resource;
 
    if (_dst->format != _src->format) {
-      glhd_warn("Format mismatch: Source is %s, destination is %s",
-         util_format_short_name(_src->format),
-         util_format_short_name(_dst->format));
+      const struct util_format_description *src_desc =
+         util_format_description(_src->format);
+      const struct util_format_description *dst_desc =
+         util_format_description(_dst->format);
+      if (!util_is_format_compatible(src_desc, dst_desc))
+         glhd_warn("Format mismatch: Source is %s, destination is %s",
+            src_desc->short_name,
+            dst_desc->short_name);
+   }
+
+   if ((_src->target == PIPE_BUFFER && _dst->target != PIPE_BUFFER) ||
+       (_src->target != PIPE_BUFFER && _dst->target == PIPE_BUFFER)) {
+      glhd_warn("Resource target mismatch: Source is %i, destination is %i",
+                _src->target, _dst->target);
    }
 
    pipe->resource_copy_region(pipe,
                               dst,
-                              subdst,
+                              dst_level,
                               dstx,
                               dsty,
                               dstz,
                               src,
-                              subsrc,
-                              srcx,
-                              srcy,
-                              srcz,
-                              width,
-                              height);
+                              src_level,
+                              src_box);
 }
 
 static void
-galahad_clear(struct pipe_context *_pipe,
+galahad_context_blit(struct pipe_context *_pipe,
+                     const struct pipe_blit_info *_info)
+{
+   struct galahad_context *glhd_pipe = galahad_context(_pipe);
+   struct pipe_context *pipe = glhd_pipe->pipe;
+   struct pipe_blit_info info = *_info;
+
+   info.dst.resource = galahad_resource_unwrap(info.dst.resource);
+   info.src.resource = galahad_resource_unwrap(info.src.resource);
+
+   if (info.dst.box.width < 0 ||
+       info.dst.box.height < 0)
+      glhd_error("Destination dimensions are negative");
+
+   if (info.filter != PIPE_TEX_FILTER_NEAREST &&
+       info.src.resource->target != PIPE_TEXTURE_3D &&
+       info.dst.box.depth != info.src.box.depth)
+      glhd_error("Filtering in z-direction on non-3D texture");
+
+   if (util_format_is_depth_or_stencil(info.dst.format) !=
+       util_format_is_depth_or_stencil(info.src.format))
+      glhd_error("Invalid format conversion: %s <- %s\n",
+                 util_format_name(info.dst.format),
+                 util_format_name(info.src.format));
+
+   pipe->blit(pipe, &info);
+}
+
+static void
+galahad_context_clear(struct pipe_context *_pipe,
                unsigned buffers,
-               const float *rgba,
+               const union pipe_color_union *color,
                double depth,
                unsigned stencil)
 {
@@ -668,15 +794,15 @@ galahad_clear(struct pipe_context *_pipe,
 
    pipe->clear(pipe,
                buffers,
-               rgba,
+               color,
                depth,
                stencil);
 }
 
 static void
-galahad_clear_render_target(struct pipe_context *_pipe,
+galahad_context_clear_render_target(struct pipe_context *_pipe,
                              struct pipe_surface *_dst,
-                             const float *rgba,
+                             const union pipe_color_union *color,
                              unsigned dstx, unsigned dsty,
                              unsigned width, unsigned height)
 {
@@ -687,14 +813,14 @@ galahad_clear_render_target(struct pipe_context *_pipe,
 
    pipe->clear_render_target(pipe,
                              dst,
-                             rgba,
+                             color,
                              dstx,
                              dsty,
                              width,
                              height);
 }
 static void
-galahad_clear_depth_stencil(struct pipe_context *_pipe,
+galahad_context_clear_depth_stencil(struct pipe_context *_pipe,
                              struct pipe_surface *_dst,
                              unsigned clear_flags,
                              double depth,
@@ -720,33 +846,14 @@ galahad_clear_depth_stencil(struct pipe_context *_pipe,
 }
 
 static void
-galahad_flush(struct pipe_context *_pipe,
-               unsigned flags,
-               struct pipe_fence_handle **fence)
-{
-   struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct pipe_context *pipe = glhd_pipe->pipe;
-
-   pipe->flush(pipe,
-               flags,
-               fence);
-}
-
-static unsigned int
-galahad_is_resource_referenced(struct pipe_context *_pipe,
-                                struct pipe_resource *_resource,
-                                unsigned face,
-                                unsigned level)
+galahad_context_flush(struct pipe_context *_pipe,
+                      struct pipe_fence_handle **fence,
+                      unsigned flags)
 {
    struct galahad_context *glhd_pipe = galahad_context(_pipe);
-   struct galahad_resource *glhd_resource = galahad_resource(_resource);
    struct pipe_context *pipe = glhd_pipe->pipe;
-   struct pipe_resource *resource = glhd_resource->resource;
 
-   return pipe->is_resource_referenced(pipe,
-                                       resource,
-                                       face,
-                                       level);
+   pipe->flush(pipe, fence, flags);
 }
 
 static struct pipe_sampler_view *
@@ -777,52 +884,63 @@ galahad_context_sampler_view_destroy(struct pipe_context *_pipe,
                                  galahad_sampler_view(_view));
 }
 
-static struct pipe_transfer *
-galahad_context_get_transfer(struct pipe_context *_context,
-                              struct pipe_resource *_resource,
-                              struct pipe_subresource sr,
-                              unsigned usage,
-                              const struct pipe_box *box)
+static struct pipe_surface *
+galahad_context_create_surface(struct pipe_context *_pipe,
+                                struct pipe_resource *_resource,
+                                const struct pipe_surface *templ)
 {
-   struct galahad_context *glhd_context = galahad_context(_context);
+   struct galahad_context *glhd_context = galahad_context(_pipe);
    struct galahad_resource *glhd_resource = galahad_resource(_resource);
-   struct pipe_context *context = glhd_context->pipe;
+   struct pipe_context *pipe = glhd_context->pipe;
    struct pipe_resource *resource = glhd_resource->resource;
-   struct pipe_transfer *result;
+   struct pipe_surface *result;
 
-   result = context->get_transfer(context,
-                                  resource,
-                                  sr,
-                                  usage,
-                                  box);
+   result = pipe->create_surface(pipe,
+                                 resource,
+                                 templ);
 
    if (result)
-      return galahad_transfer_create(glhd_context, glhd_resource, result);
+      return galahad_surface_create(glhd_context, glhd_resource, result);
    return NULL;
 }
 
 static void
-galahad_context_transfer_destroy(struct pipe_context *_pipe,
-                                  struct pipe_transfer *_transfer)
+galahad_context_surface_destroy(struct pipe_context *_pipe,
+                                struct pipe_surface *_surface)
 {
-   galahad_transfer_destroy(galahad_context(_pipe),
-                             galahad_transfer(_transfer));
+   galahad_surface_destroy(galahad_context(_pipe),
+                           galahad_surface(_surface));
 }
 
+
 static void *
 galahad_context_transfer_map(struct pipe_context *_context,
-                              struct pipe_transfer *_transfer)
+                             struct pipe_resource *_resource,
+                             unsigned level,
+                             unsigned usage,
+                             const struct pipe_box *box,
+                             struct pipe_transfer **transfer)
 {
    struct galahad_context *glhd_context = galahad_context(_context);
-   struct galahad_transfer *glhd_transfer = galahad_transfer(_transfer);
+   struct galahad_resource *glhd_resource = galahad_resource(_resource);
    struct pipe_context *context = glhd_context->pipe;
-   struct pipe_transfer *transfer = glhd_transfer->transfer;
-
-   return context->transfer_map(context,
-                                transfer);
-}
+   struct pipe_resource *resource = glhd_resource->resource;
+   struct pipe_transfer *result;
+   void *map;
+
+   map = context->transfer_map(context,
+                               resource,
+                               level,
+                               usage,
+                               box, &result);
+   if (!map)
+      return NULL;
 
+   glhd_resource->map_count++;
 
+   *transfer = galahad_transfer_create(glhd_context, glhd_resource, result);
+   return *transfer ? map : NULL;
+}
 
 static void
 galahad_context_transfer_flush_region(struct pipe_context *_context,
@@ -839,7 +957,6 @@ galahad_context_transfer_flush_region(struct pipe_context *_context,
                                   box);
 }
 
-
 static void
 galahad_context_transfer_unmap(struct pipe_context *_context,
                                 struct pipe_transfer *_transfer)
@@ -848,16 +965,27 @@ galahad_context_transfer_unmap(struct pipe_context *_context,
    struct galahad_transfer *glhd_transfer = galahad_transfer(_transfer);
    struct pipe_context *context = glhd_context->pipe;
    struct pipe_transfer *transfer = glhd_transfer->transfer;
+   struct galahad_resource *glhd_resource = galahad_resource(_transfer->resource);
+
+   if (glhd_resource->map_count < 1) {
+      glhd_warn("context::transfer_unmap() called too many times"
+                " (count = %d)\n", glhd_resource->map_count);      
+   }
+
+   glhd_resource->map_count--;
 
    context->transfer_unmap(context,
                            transfer);
+
+   galahad_transfer_destroy(galahad_context(_context),
+                             galahad_transfer(_transfer));
 }
 
 
 static void
 galahad_context_transfer_inline_write(struct pipe_context *_context,
                                        struct pipe_resource *_resource,
-                                       struct pipe_subresource sr,
+                                       unsigned level,
                                        unsigned usage,
                                        const struct pipe_box *box,
                                        const void *data,
@@ -871,7 +999,7 @@ galahad_context_transfer_inline_write(struct pipe_context *_context,
 
    context->transfer_inline_write(context,
                                   resource,
-                                  sr,
+                                  level,
                                   usage,
                                   box,
                                   data,
@@ -880,6 +1008,19 @@ galahad_context_transfer_inline_write(struct pipe_context *_context,
 }
 
 
+static void
+galahad_context_render_condition(struct pipe_context *_context,
+                                 struct pipe_query *query,
+                                 boolean condition,
+                                 uint mode)
+{
+   struct galahad_context *glhd_context = galahad_context(_context);
+   struct pipe_context *context = glhd_context->pipe;
+
+   context->render_condition(context, query, condition, mode);
+}
+
+
 struct pipe_context *
 galahad_context_create(struct pipe_screen *_screen, struct pipe_context *pipe)
 {
@@ -891,68 +1032,93 @@ galahad_context_create(struct pipe_screen *_screen, struct pipe_context *pipe)
       return NULL;
    }
 
-   glhd_pipe->base.winsys = NULL;
    glhd_pipe->base.screen = _screen;
    glhd_pipe->base.priv = pipe->priv; /* expose wrapped data */
    glhd_pipe->base.draw = NULL;
 
-   glhd_pipe->base.destroy = galahad_destroy;
-   glhd_pipe->base.draw_arrays = galahad_draw_arrays;
-   glhd_pipe->base.draw_elements = galahad_draw_elements;
-   glhd_pipe->base.draw_range_elements = galahad_draw_range_elements;
-   glhd_pipe->base.create_query = galahad_create_query;
-   glhd_pipe->base.destroy_query = galahad_destroy_query;
-   glhd_pipe->base.begin_query = galahad_begin_query;
-   glhd_pipe->base.end_query = galahad_end_query;
-   glhd_pipe->base.get_query_result = galahad_get_query_result;
-   glhd_pipe->base.create_blend_state = galahad_create_blend_state;
-   glhd_pipe->base.bind_blend_state = galahad_bind_blend_state;
-   glhd_pipe->base.delete_blend_state = galahad_delete_blend_state;
-   glhd_pipe->base.create_sampler_state = galahad_create_sampler_state;
-   glhd_pipe->base.bind_fragment_sampler_states = galahad_bind_fragment_sampler_states;
-   glhd_pipe->base.bind_vertex_sampler_states = galahad_bind_vertex_sampler_states;
-   glhd_pipe->base.delete_sampler_state = galahad_delete_sampler_state;
-   glhd_pipe->base.create_rasterizer_state = galahad_create_rasterizer_state;
-   glhd_pipe->base.bind_rasterizer_state = galahad_bind_rasterizer_state;
-   glhd_pipe->base.delete_rasterizer_state = galahad_delete_rasterizer_state;
-   glhd_pipe->base.create_depth_stencil_alpha_state = galahad_create_depth_stencil_alpha_state;
-   glhd_pipe->base.bind_depth_stencil_alpha_state = galahad_bind_depth_stencil_alpha_state;
-   glhd_pipe->base.delete_depth_stencil_alpha_state = galahad_delete_depth_stencil_alpha_state;
-   glhd_pipe->base.create_fs_state = galahad_create_fs_state;
-   glhd_pipe->base.bind_fs_state = galahad_bind_fs_state;
-   glhd_pipe->base.delete_fs_state = galahad_delete_fs_state;
-   glhd_pipe->base.create_vs_state = galahad_create_vs_state;
-   glhd_pipe->base.bind_vs_state = galahad_bind_vs_state;
-   glhd_pipe->base.delete_vs_state = galahad_delete_vs_state;
-   glhd_pipe->base.create_vertex_elements_state = galahad_create_vertex_elements_state;
-   glhd_pipe->base.bind_vertex_elements_state = galahad_bind_vertex_elements_state;
-   glhd_pipe->base.delete_vertex_elements_state = galahad_delete_vertex_elements_state;
-   glhd_pipe->base.set_blend_color = galahad_set_blend_color;
-   glhd_pipe->base.set_stencil_ref = galahad_set_stencil_ref;
-   glhd_pipe->base.set_clip_state = galahad_set_clip_state;
-   glhd_pipe->base.set_sample_mask = galahad_set_sample_mask;
-   glhd_pipe->base.set_constant_buffer = galahad_set_constant_buffer;
-   glhd_pipe->base.set_framebuffer_state = galahad_set_framebuffer_state;
-   glhd_pipe->base.set_polygon_stipple = galahad_set_polygon_stipple;
-   glhd_pipe->base.set_scissor_state = galahad_set_scissor_state;
-   glhd_pipe->base.set_viewport_state = galahad_set_viewport_state;
-   glhd_pipe->base.set_fragment_sampler_views = galahad_set_fragment_sampler_views;
-   glhd_pipe->base.set_vertex_sampler_views = galahad_set_vertex_sampler_views;
-   glhd_pipe->base.set_vertex_buffers = galahad_set_vertex_buffers;
-   glhd_pipe->base.resource_copy_region = galahad_resource_copy_region;
-   glhd_pipe->base.clear = galahad_clear;
-   glhd_pipe->base.clear_render_target = galahad_clear_render_target;
-   glhd_pipe->base.clear_depth_stencil = galahad_clear_depth_stencil;
-   glhd_pipe->base.flush = galahad_flush;
-   glhd_pipe->base.is_resource_referenced = galahad_is_resource_referenced;
-   glhd_pipe->base.create_sampler_view = galahad_context_create_sampler_view;
-   glhd_pipe->base.sampler_view_destroy = galahad_context_sampler_view_destroy;
-   glhd_pipe->base.get_transfer = galahad_context_get_transfer;
-   glhd_pipe->base.transfer_destroy = galahad_context_transfer_destroy;
-   glhd_pipe->base.transfer_map = galahad_context_transfer_map;
-   glhd_pipe->base.transfer_unmap = galahad_context_transfer_unmap;
-   glhd_pipe->base.transfer_flush_region = galahad_context_transfer_flush_region;
-   glhd_pipe->base.transfer_inline_write = galahad_context_transfer_inline_write;
+   glhd_pipe->base.destroy = galahad_context_destroy;
+
+#define GLHD_PIPE_INIT(_member) \
+   glhd_pipe->base . _member = pipe -> _member ? galahad_context_ ## _member : NULL
+
+   GLHD_PIPE_INIT(draw_vbo);
+   GLHD_PIPE_INIT(render_condition);
+   GLHD_PIPE_INIT(create_query);
+   GLHD_PIPE_INIT(destroy_query);
+   GLHD_PIPE_INIT(begin_query);
+   GLHD_PIPE_INIT(end_query);
+   GLHD_PIPE_INIT(get_query_result);
+   GLHD_PIPE_INIT(create_blend_state);
+   GLHD_PIPE_INIT(bind_blend_state);
+   GLHD_PIPE_INIT(delete_blend_state);
+   GLHD_PIPE_INIT(create_sampler_state);
+   GLHD_PIPE_INIT(bind_fragment_sampler_states);
+   GLHD_PIPE_INIT(bind_vertex_sampler_states);
+   GLHD_PIPE_INIT(bind_geometry_sampler_states);
+   //GLHD_PIPE_INIT(bind_compute_sampler_states);
+   GLHD_PIPE_INIT(delete_sampler_state);
+   GLHD_PIPE_INIT(create_rasterizer_state);
+   GLHD_PIPE_INIT(bind_rasterizer_state);
+   GLHD_PIPE_INIT(delete_rasterizer_state);
+   GLHD_PIPE_INIT(create_depth_stencil_alpha_state);
+   GLHD_PIPE_INIT(bind_depth_stencil_alpha_state);
+   GLHD_PIPE_INIT(delete_depth_stencil_alpha_state);
+   GLHD_PIPE_INIT(create_fs_state);
+   GLHD_PIPE_INIT(bind_fs_state);
+   GLHD_PIPE_INIT(delete_fs_state);
+   GLHD_PIPE_INIT(create_vs_state);
+   GLHD_PIPE_INIT(bind_vs_state);
+   GLHD_PIPE_INIT(delete_vs_state);
+   GLHD_PIPE_INIT(create_gs_state);
+   GLHD_PIPE_INIT(bind_gs_state);
+   GLHD_PIPE_INIT(delete_gs_state);
+   GLHD_PIPE_INIT(create_vertex_elements_state);
+   GLHD_PIPE_INIT(bind_vertex_elements_state);
+   GLHD_PIPE_INIT(delete_vertex_elements_state);
+   GLHD_PIPE_INIT(set_blend_color);
+   GLHD_PIPE_INIT(set_stencil_ref);
+   GLHD_PIPE_INIT(set_sample_mask);
+   GLHD_PIPE_INIT(set_clip_state);
+   GLHD_PIPE_INIT(set_constant_buffer);
+   GLHD_PIPE_INIT(set_framebuffer_state);
+   GLHD_PIPE_INIT(set_polygon_stipple);
+   GLHD_PIPE_INIT(set_scissor_states);
+   GLHD_PIPE_INIT(set_viewport_states);
+   GLHD_PIPE_INIT(set_fragment_sampler_views);
+   GLHD_PIPE_INIT(set_vertex_sampler_views);
+   GLHD_PIPE_INIT(set_geometry_sampler_views);
+   //GLHD_PIPE_INIT(set_compute_sampler_views);
+   //GLHD_PIPE_INIT(set_shader_resources);
+   GLHD_PIPE_INIT(set_vertex_buffers);
+   GLHD_PIPE_INIT(set_index_buffer);
+   GLHD_PIPE_INIT(create_stream_output_target);
+   GLHD_PIPE_INIT(stream_output_target_destroy);
+   GLHD_PIPE_INIT(set_stream_output_targets);
+   GLHD_PIPE_INIT(resource_copy_region);
+   GLHD_PIPE_INIT(blit);
+   GLHD_PIPE_INIT(clear);
+   GLHD_PIPE_INIT(clear_render_target);
+   GLHD_PIPE_INIT(clear_depth_stencil);
+   GLHD_PIPE_INIT(flush);
+   GLHD_PIPE_INIT(create_sampler_view);
+   GLHD_PIPE_INIT(sampler_view_destroy);
+   GLHD_PIPE_INIT(create_surface);
+   GLHD_PIPE_INIT(surface_destroy);
+   GLHD_PIPE_INIT(transfer_map);
+   GLHD_PIPE_INIT(transfer_flush_region);
+   GLHD_PIPE_INIT(transfer_unmap);
+   GLHD_PIPE_INIT(transfer_inline_write);
+   //GLHD_PIPE_INIT(texture_barrier);
+   //GLHD_PIPE_INIT(create_video_decoder);
+   //GLHD_PIPE_INIT(create_video_buffer);
+   //GLHD_PIPE_INIT(create_compute_state);
+   //GLHD_PIPE_INIT(bind_compute_state);
+   //GLHD_PIPE_INIT(delete_compute_state);
+   //GLHD_PIPE_INIT(set_compute_resources);
+   //GLHD_PIPE_INIT(set_global_binding);
+   //GLHD_PIPE_INIT(launch_grid);
+
+#undef GLHD_PIPE_INIT
 
    glhd_pipe->pipe = pipe;