Merge remote branch 'origin/mesa_7_6_branch'
[mesa.git] / src / gallium / drivers / nv30 / nv30_context.c
1 #include "draw/draw_context.h"
2 #include "pipe/p_defines.h"
3 #include "pipe/internal/p_winsys_screen.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->pipe.is_texture_referenced = nouveau_is_texture_referenced;
59 nv30->pipe.is_buffer_referenced = nouveau_is_buffer_referenced;
60
61 nv30_init_query_functions(nv30);
62 nv30_init_surface_functions(nv30);
63 nv30_init_state_functions(nv30);
64
65 /* Create, configure, and install fallback swtnl path */
66 nv30->draw = draw_create();
67 draw_wide_point_threshold(nv30->draw, 9999999.0);
68 draw_wide_line_threshold(nv30->draw, 9999999.0);
69 draw_enable_line_stipple(nv30->draw, FALSE);
70 draw_enable_point_sprites(nv30->draw, FALSE);
71 draw_set_rasterize_stage(nv30->draw, nv30_draw_render_stage(nv30));
72
73 return &nv30->pipe;
74 }