Merge branch 'mesa_7_5_branch' into mesa_7_6_branch
[mesa.git] / src / gallium / drivers / nv50 / nv50_draw.c
index c6ed6838c6a1ef50d617cc473674dc7d576efef6..2f6f607261e573e958544f893a5f3d434249e287 100644 (file)
@@ -1,55 +1,89 @@
-#include "draw/draw_private.h"
-#include "pipe/p_util.h"
+/*
+ * Copyright 2008 Ben Skeggs
+ *
+ * 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
+ * THE AUTHORS 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 "draw/draw_pipe.h"
 
 #include "nv50_context.h"
 
-struct nv50_draw_stage {
-       struct draw_stage draw;
+struct nv50_render_stage {
+       struct draw_stage stage;
        struct nv50_context *nv50;
 };
 
+static INLINE struct nv50_render_stage *
+nv50_render_stage(struct draw_stage *stage)
+{
+       return (struct nv50_render_stage *)stage;
+}
+
 static void
-nv50_draw_point(struct draw_stage *draw, struct prim_header *prim)
+nv50_render_point(struct draw_stage *stage, struct prim_header *prim)
 {
        NOUVEAU_ERR("\n");
 }
 
 static void
-nv50_draw_line(struct draw_stage *draw, struct prim_header *prim)
+nv50_render_line(struct draw_stage *stage, struct prim_header *prim)
 {
        NOUVEAU_ERR("\n");
 }
 
 static void
-nv50_draw_tri(struct draw_stage *draw, struct prim_header *prim)
+nv50_render_tri(struct draw_stage *stage, struct prim_header *prim)
 {
        NOUVEAU_ERR("\n");
 }
 
 static void
-nv50_draw_flush(struct draw_stage *draw, unsigned flags)
+nv50_render_flush(struct draw_stage *stage, unsigned flags)
 {
 }
 
 static void
-nv50_draw_reset_stipple_counter(struct draw_stage *draw)
+nv50_render_reset_stipple_counter(struct draw_stage *stage)
 {
        NOUVEAU_ERR("\n");
 }
 
+static void
+nv50_render_destroy(struct draw_stage *stage)
+{
+       FREE(stage);
+}
+
 struct draw_stage *
 nv50_draw_render_stage(struct nv50_context *nv50)
 {
-       struct nv50_draw_stage *nv50draw = CALLOC_STRUCT(nv50_draw_stage);
+       struct nv50_render_stage *rs = CALLOC_STRUCT(nv50_render_stage);
 
-       nv50draw->nv50 = nv50;
-       nv50draw->draw.draw = nv50->draw;
-       nv50draw->draw.point = nv50_draw_point;
-       nv50draw->draw.line = nv50_draw_line;
-       nv50draw->draw.tri = nv50_draw_tri;
-       nv50draw->draw.flush = nv50_draw_flush;
-       nv50draw->draw.reset_stipple_counter = nv50_draw_reset_stipple_counter;
+       rs->nv50 = nv50;
+       rs->stage.draw = nv50->draw;
+       rs->stage.destroy = nv50_render_destroy;
+       rs->stage.point = nv50_render_point;
+       rs->stage.line = nv50_render_line;
+       rs->stage.tri = nv50_render_tri;
+       rs->stage.flush = nv50_render_flush;
+       rs->stage.reset_stipple_counter = nv50_render_reset_stipple_counter;
 
-       return &nv50draw->draw;
+       return &rs->stage;
 }