Merge commit 'origin/gallium-0.1' into gallium-0.2
[mesa.git] / src / gallium / drivers / nv30 / nv30_context.c
1 #include "draw/draw_context.h"
2 #include "pipe/p_defines.h"
3 #include "pipe/p_winsys.h"
4
5 #include "nv30_context.h"
6 #include "nv30_screen.h"
7
8 static void
9 nv30_flush(struct pipe_context *pipe, unsigned flags,
10 struct pipe_fence_handle **fence)
11 {
12 struct nv30_context *nv30 = nv30_context(pipe);
13
14 if (flags & PIPE_FLUSH_TEXTURE_CACHE) {
15 BEGIN_RING(rankine, 0x1fd8, 1);
16 OUT_RING (2);
17 BEGIN_RING(rankine, 0x1fd8, 1);
18 OUT_RING (1);
19 }
20
21 FIRE_RING(fence);
22 }
23
24 static void
25 nv30_destroy(struct pipe_context *pipe)
26 {
27 struct nv30_context *nv30 = nv30_context(pipe);
28
29 if (nv30->draw)
30 draw_destroy(nv30->draw);
31 FREE(nv30);
32 }
33
34 struct pipe_context *
35 nv30_create(struct pipe_screen *pscreen, unsigned pctx_id)
36 {
37 struct nv30_screen *screen = nv30_screen(pscreen);
38 struct pipe_winsys *ws = pscreen->winsys;
39 struct nv30_context *nv30;
40 struct nouveau_winsys *nvws = screen->nvws;
41
42 nv30 = CALLOC(1, sizeof(struct nv30_context));
43 if (!nv30)
44 return NULL;
45 nv30->screen = screen;
46 nv30->pctx_id = pctx_id;
47
48 nv30->nvws = nvws;
49
50 nv30->pipe.winsys = ws;
51 nv30->pipe.screen = pscreen;
52 nv30->pipe.destroy = nv30_destroy;
53 nv30->pipe.draw_arrays = nv30_draw_arrays;
54 nv30->pipe.draw_elements = nv30_draw_elements;
55 nv30->pipe.clear = nv30_clear;
56 nv30->pipe.flush = nv30_flush;
57
58 nv30_init_query_functions(nv30);
59 nv30_init_surface_functions(nv30);
60 nv30_init_state_functions(nv30);
61
62 /* Create, configure, and install fallback swtnl path */
63 nv30->draw = draw_create();
64 draw_wide_point_threshold(nv30->draw, 9999999.0);
65 draw_wide_line_threshold(nv30->draw, 9999999.0);
66 draw_enable_line_stipple(nv30->draw, FALSE);
67 draw_enable_point_sprites(nv30->draw, FALSE);
68 draw_set_rasterize_stage(nv30->draw, nv30_draw_render_stage(nv30));
69
70 return &nv30->pipe;
71 }
72