1 /**************************************************************************
3 * Copyright 2007 Tungsten Graphics, Inc., Cedar Park, Texas.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 **************************************************************************/
29 * Keith Whitwell <keith@tungstengraphics.com>
32 #include "pipe/draw/draw_context.h"
33 #include "pipe/p_defines.h"
34 #include "pipe/p_inlines.h"
35 #include "pipe/p_util.h"
37 #include "sp_context.h"
39 #include "sp_prim_setup.h"
41 #include "sp_surface.h"
42 #include "sp_tile_cache.h"
43 #include "sp_texture.h"
44 #include "sp_winsys.h"
50 * Query format support for creating a texture, drawing surface, etc.
51 * \param format the format to test
52 * \param type one of PIPE_TEXTURE, PIPE_SURFACE
55 softpipe_is_format_supported( struct pipe_context
*pipe
,
56 enum pipe_format format
, uint type
)
60 /* softpipe supports all texture formats */
63 /* softpipe supports all (off-screen) surface formats */
73 * Map any drawing surfaces which aren't already mapped
76 softpipe_map_surfaces(struct softpipe_context
*sp
)
78 struct pipe_surface
*ps
;
81 for (i
= 0; i
< sp
->framebuffer
.num_cbufs
; i
++) {
82 ps
= sp
->framebuffer
.cbufs
[i
];
83 if (ps
->buffer
&& !ps
->map
)
87 ps
= sp
->framebuffer
.zbuf
;
88 if (ps
&& ps
->buffer
&& !ps
->map
)
91 ps
= sp
->framebuffer
.sbuf
;
92 if (ps
&& ps
->buffer
&& !ps
->map
)
98 * Unmap any mapped drawing surfaces
101 softpipe_unmap_surfaces(struct softpipe_context
*sp
)
103 struct pipe_surface
*ps
;
106 for (i
= 0; i
< sp
->framebuffer
.num_cbufs
; i
++)
107 sp_flush_tile_cache(sp
, sp
->cbuf_cache
[i
]);
108 sp_flush_tile_cache(sp
, sp
->zbuf_cache
);
109 sp_flush_tile_cache(sp
, sp
->sbuf_cache
);
111 for (i
= 0; i
< sp
->framebuffer
.num_cbufs
; i
++) {
112 ps
= sp
->framebuffer
.cbufs
[i
];
114 pipe_surface_unmap(ps
);
117 ps
= sp
->framebuffer
.zbuf
;
119 pipe_surface_unmap(ps
);
121 ps
= sp
->framebuffer
.sbuf
;
123 pipe_surface_unmap(ps
);
127 static void softpipe_destroy( struct pipe_context
*pipe
)
129 struct softpipe_context
*softpipe
= softpipe_context( pipe
);
130 struct pipe_winsys
*ws
= pipe
->winsys
;
133 draw_destroy( softpipe
->draw
);
135 softpipe
->quad
.polygon_stipple
->destroy( softpipe
->quad
.polygon_stipple
);
136 softpipe
->quad
.earlyz
->destroy( softpipe
->quad
.earlyz
);
137 softpipe
->quad
.shade
->destroy( softpipe
->quad
.shade
);
138 softpipe
->quad
.alpha_test
->destroy( softpipe
->quad
.alpha_test
);
139 softpipe
->quad
.depth_test
->destroy( softpipe
->quad
.depth_test
);
140 softpipe
->quad
.stencil_test
->destroy( softpipe
->quad
.stencil_test
);
141 softpipe
->quad
.occlusion
->destroy( softpipe
->quad
.occlusion
);
142 softpipe
->quad
.coverage
->destroy( softpipe
->quad
.coverage
);
143 softpipe
->quad
.bufloop
->destroy( softpipe
->quad
.bufloop
);
144 softpipe
->quad
.blend
->destroy( softpipe
->quad
.blend
);
145 softpipe
->quad
.colormask
->destroy( softpipe
->quad
.colormask
);
146 softpipe
->quad
.output
->destroy( softpipe
->quad
.output
);
148 for (i
= 0; i
< PIPE_MAX_COLOR_BUFS
; i
++)
149 sp_destroy_tile_cache(softpipe
->cbuf_cache
[i
]);
150 sp_destroy_tile_cache(softpipe
->zbuf_cache
);
151 sp_destroy_tile_cache(softpipe
->sbuf_cache_sep
);
153 for (i
= 0; i
< PIPE_MAX_SAMPLERS
; i
++)
154 sp_destroy_tile_cache(softpipe
->tex_cache
[i
]);
156 for (i
= 0; i
< Elements(softpipe
->constants
); i
++) {
157 if (softpipe
->constants
[i
].buffer
) {
158 ws
->buffer_reference(ws
, &softpipe
->constants
[i
].buffer
, NULL
);
166 static const char *softpipe_get_name( struct pipe_context
*pipe
)
171 static const char *softpipe_get_vendor( struct pipe_context
*pipe
)
173 return "Tungsten Graphics, Inc.";
176 static int softpipe_get_param(struct pipe_context
*pipe
, int param
)
179 case PIPE_CAP_MAX_TEXTURE_IMAGE_UNITS
:
181 case PIPE_CAP_NPOT_TEXTURES
:
183 case PIPE_CAP_TWO_SIDED_STENCIL
:
189 case PIPE_CAP_ANISOTROPIC_FILTER
:
191 case PIPE_CAP_POINT_SPRITE
:
193 case PIPE_CAP_MAX_RENDER_TARGETS
:
195 case PIPE_CAP_OCCLUSION_QUERY
:
197 case PIPE_CAP_TEXTURE_SHADOW_MAP
:
199 case PIPE_CAP_MAX_TEXTURE_2D_LEVELS
:
200 return 12; /* max 2Kx2K */
201 case PIPE_CAP_MAX_TEXTURE_3D_LEVELS
:
202 return 8; /* max 128x128x128 */
203 case PIPE_CAP_MAX_TEXTURE_CUBE_LEVELS
:
204 return 12; /* max 2Kx2K */
210 static float softpipe_get_paramf(struct pipe_context
*pipe
, int param
)
213 case PIPE_CAP_MAX_LINE_WIDTH
:
215 case PIPE_CAP_MAX_LINE_WIDTH_AA
:
216 return 255.0; /* arbitrary */
218 case PIPE_CAP_MAX_POINT_WIDTH
:
220 case PIPE_CAP_MAX_POINT_WIDTH_AA
:
221 return 255.0; /* arbitrary */
223 case PIPE_CAP_MAX_TEXTURE_ANISOTROPY
:
226 case PIPE_CAP_MAX_TEXTURE_LOD_BIAS
:
227 return 16.0; /* arbitrary */
234 struct pipe_context
*softpipe_create( struct pipe_winsys
*pipe_winsys
,
235 struct softpipe_winsys
*softpipe_winsys
)
237 struct softpipe_context
*softpipe
= CALLOC_STRUCT(softpipe_context
);
240 #if defined(__i386__) || defined(__386__)
241 softpipe
->use_sse
= GETENV( "GALLIUM_NOSSE" ) == NULL
;
243 softpipe
->use_sse
= FALSE
;
246 softpipe
->dump_fs
= GETENV( "GALLIUM_DUMP_FS" ) != NULL
;
248 softpipe
->pipe
.winsys
= pipe_winsys
;
249 softpipe
->pipe
.destroy
= softpipe_destroy
;
252 softpipe
->pipe
.is_format_supported
= softpipe_is_format_supported
;
253 softpipe
->pipe
.get_name
= softpipe_get_name
;
254 softpipe
->pipe
.get_vendor
= softpipe_get_vendor
;
255 softpipe
->pipe
.get_param
= softpipe_get_param
;
256 softpipe
->pipe
.get_paramf
= softpipe_get_paramf
;
259 softpipe
->pipe
.create_blend_state
= softpipe_create_blend_state
;
260 softpipe
->pipe
.bind_blend_state
= softpipe_bind_blend_state
;
261 softpipe
->pipe
.delete_blend_state
= softpipe_delete_blend_state
;
263 softpipe
->pipe
.create_sampler_state
= softpipe_create_sampler_state
;
264 softpipe
->pipe
.bind_sampler_state
= softpipe_bind_sampler_state
;
265 softpipe
->pipe
.delete_sampler_state
= softpipe_delete_sampler_state
;
267 softpipe
->pipe
.create_depth_stencil_alpha_state
= softpipe_create_depth_stencil_state
;
268 softpipe
->pipe
.bind_depth_stencil_alpha_state
= softpipe_bind_depth_stencil_state
;
269 softpipe
->pipe
.delete_depth_stencil_alpha_state
= softpipe_delete_depth_stencil_state
;
271 softpipe
->pipe
.create_rasterizer_state
= softpipe_create_rasterizer_state
;
272 softpipe
->pipe
.bind_rasterizer_state
= softpipe_bind_rasterizer_state
;
273 softpipe
->pipe
.delete_rasterizer_state
= softpipe_delete_rasterizer_state
;
275 softpipe
->pipe
.create_fs_state
= softpipe_create_fs_state
;
276 softpipe
->pipe
.bind_fs_state
= softpipe_bind_fs_state
;
277 softpipe
->pipe
.delete_fs_state
= softpipe_delete_fs_state
;
279 softpipe
->pipe
.create_vs_state
= softpipe_create_vs_state
;
280 softpipe
->pipe
.bind_vs_state
= softpipe_bind_vs_state
;
281 softpipe
->pipe
.delete_vs_state
= softpipe_delete_vs_state
;
283 softpipe
->pipe
.set_blend_color
= softpipe_set_blend_color
;
284 softpipe
->pipe
.set_clip_state
= softpipe_set_clip_state
;
285 softpipe
->pipe
.set_constant_buffer
= softpipe_set_constant_buffer
;
286 softpipe
->pipe
.set_framebuffer_state
= softpipe_set_framebuffer_state
;
287 softpipe
->pipe
.set_polygon_stipple
= softpipe_set_polygon_stipple
;
288 softpipe
->pipe
.set_scissor_state
= softpipe_set_scissor_state
;
289 softpipe
->pipe
.set_sampler_texture
= softpipe_set_sampler_texture
;
290 softpipe
->pipe
.set_viewport_state
= softpipe_set_viewport_state
;
292 softpipe
->pipe
.set_vertex_buffer
= softpipe_set_vertex_buffer
;
293 softpipe
->pipe
.set_vertex_element
= softpipe_set_vertex_element
;
295 softpipe
->pipe
.draw_arrays
= softpipe_draw_arrays
;
296 softpipe
->pipe
.draw_elements
= softpipe_draw_elements
;
298 softpipe
->pipe
.clear
= softpipe_clear
;
299 softpipe
->pipe
.flush
= softpipe_flush
;
301 softpipe_init_query_funcs( softpipe
);
304 softpipe
->pipe
.texture_create
= softpipe_texture_create
;
305 softpipe
->pipe
.texture_release
= softpipe_texture_release
;
306 softpipe
->pipe
.get_tex_surface
= softpipe_get_tex_surface
;
309 * Alloc caches for accessing drawing surfaces and textures.
310 * Must be before quad stage setup!
312 for (i
= 0; i
< PIPE_MAX_COLOR_BUFS
; i
++)
313 softpipe
->cbuf_cache
[i
] = sp_create_tile_cache();
314 softpipe
->zbuf_cache
= sp_create_tile_cache();
315 softpipe
->sbuf_cache_sep
= sp_create_tile_cache();
316 softpipe
->sbuf_cache
= softpipe
->sbuf_cache_sep
; /* initial value */
318 for (i
= 0; i
< PIPE_MAX_SAMPLERS
; i
++)
319 softpipe
->tex_cache
[i
] = sp_create_tile_cache();
322 /* setup quad rendering stages */
323 softpipe
->quad
.polygon_stipple
= sp_quad_polygon_stipple_stage(softpipe
);
324 softpipe
->quad
.earlyz
= sp_quad_earlyz_stage(softpipe
);
325 softpipe
->quad
.shade
= sp_quad_shade_stage(softpipe
);
326 softpipe
->quad
.alpha_test
= sp_quad_alpha_test_stage(softpipe
);
327 softpipe
->quad
.depth_test
= sp_quad_depth_test_stage(softpipe
);
328 softpipe
->quad
.stencil_test
= sp_quad_stencil_test_stage(softpipe
);
329 softpipe
->quad
.occlusion
= sp_quad_occlusion_stage(softpipe
);
330 softpipe
->quad
.coverage
= sp_quad_coverage_stage(softpipe
);
331 softpipe
->quad
.bufloop
= sp_quad_bufloop_stage(softpipe
);
332 softpipe
->quad
.blend
= sp_quad_blend_stage(softpipe
);
333 softpipe
->quad
.colormask
= sp_quad_colormask_stage(softpipe
);
334 softpipe
->quad
.output
= sp_quad_output_stage(softpipe
);
336 softpipe
->winsys
= softpipe_winsys
;
339 * Create drawing context and plug our rendering stage into it.
341 softpipe
->draw
= draw_create();
342 assert(softpipe
->draw
);
343 softpipe
->setup
= sp_draw_render_stage(softpipe
);
345 if (GETENV( "SP_VBUF" ) != NULL
) {
346 softpipe
->vbuf
= sp_draw_vbuf_stage(softpipe
->draw
,
350 draw_set_rasterize_stage(softpipe
->draw
, softpipe
->vbuf
);
353 draw_set_rasterize_stage(softpipe
->draw
, softpipe
->setup
);
356 sp_init_surface_functions(softpipe
);
358 return &softpipe
->pipe
;