brw_state.h revision c791f8a1e532834ae7a517c042e9efe262b62233
1/*
2 Copyright (C) Intel Corp.  2006.  All Rights Reserved.
3 Intel funded Tungsten Graphics (http://www.tungstengraphics.com) to
4 develop this 3D driver.
5
6 Permission is hereby granted, free of charge, to any person obtaining
7 a 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, sublicense, 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:
13
14 The above copyright notice and this permission notice (including the
15 next paragraph) shall be included in all copies or substantial
16 portions of the Software.
17
18 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
21 IN NO EVENT SHALL THE COPYRIGHT OWNER(S) AND/OR ITS SUPPLIERS BE
22 LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
23 OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
24 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25
26 **********************************************************************/
27 /*
28  * Authors:
29  *   Keith Whitwell <keith@tungstengraphics.com>
30  */
31
32
33#ifndef BRW_STATE_H
34#define BRW_STATE_H
35
36#include "brw_context.h"
37
38static INLINE void
39brw_add_validated_bo(struct brw_context *brw, dri_bo *bo)
40{
41   assert(brw->state.validated_bo_count < ARRAY_SIZE(brw->state.validated_bos));
42
43   if (bo != NULL) {
44      dri_bo_reference(bo);
45      brw->state.validated_bos[brw->state.validated_bo_count++] = bo;
46   }
47};
48
49const struct brw_tracked_state brw_blend_constant_color;
50const struct brw_tracked_state brw_cc_unit;
51const struct brw_tracked_state brw_cc_vp;
52const struct brw_tracked_state brw_check_fallback;
53const struct brw_tracked_state brw_clip_prog;
54const struct brw_tracked_state brw_clip_unit;
55const struct brw_tracked_state brw_constant_buffer;
56const struct brw_tracked_state brw_curbe_offsets;
57const struct brw_tracked_state brw_invarient_state;
58const struct brw_tracked_state brw_gs_prog;
59const struct brw_tracked_state brw_gs_unit;
60const struct brw_tracked_state brw_line_stipple;
61const struct brw_tracked_state brw_aa_line_parameters;
62const struct brw_tracked_state brw_pipelined_state_pointers;
63const struct brw_tracked_state brw_binding_table_pointers;
64const struct brw_tracked_state brw_depthbuffer;
65const struct brw_tracked_state brw_polygon_stipple_offset;
66const struct brw_tracked_state brw_polygon_stipple;
67const struct brw_tracked_state brw_program_parameters;
68const struct brw_tracked_state brw_recalculate_urb_fence;
69const struct brw_tracked_state brw_sf_prog;
70const struct brw_tracked_state brw_sf_unit;
71const struct brw_tracked_state brw_sf_vp;
72const struct brw_tracked_state brw_state_base_address;
73const struct brw_tracked_state brw_urb_fence;
74const struct brw_tracked_state brw_vertex_state;
75const struct brw_tracked_state brw_vs_surfaces;
76const struct brw_tracked_state brw_vs_prog;
77const struct brw_tracked_state brw_vs_unit;
78const struct brw_tracked_state brw_wm_input_sizes;
79const struct brw_tracked_state brw_wm_prog;
80const struct brw_tracked_state brw_wm_samplers;
81const struct brw_tracked_state brw_wm_constant_surface;
82const struct brw_tracked_state brw_wm_surfaces;
83const struct brw_tracked_state brw_wm_unit;
84
85const struct brw_tracked_state brw_psp_urb_cbs;
86
87const struct brw_tracked_state brw_pipe_control;
88
89const struct brw_tracked_state brw_drawing_rect;
90const struct brw_tracked_state brw_indices;
91const struct brw_tracked_state brw_vertices;
92const struct brw_tracked_state brw_index_buffer;
93const struct brw_tracked_state gen6_binding_table_pointers;
94const struct brw_tracked_state gen6_blend_state;
95const struct brw_tracked_state gen6_cc_state_pointers;
96const struct brw_tracked_state gen6_cc_vp;
97const struct brw_tracked_state gen6_clip_state;
98const struct brw_tracked_state gen6_clip_vp;
99const struct brw_tracked_state gen6_color_calc_state;
100const struct brw_tracked_state gen6_depth_stencil_state;
101const struct brw_tracked_state gen6_gs_state;
102const struct brw_tracked_state gen6_sampler_state;
103const struct brw_tracked_state gen6_scissor_state;
104const struct brw_tracked_state gen6_sf_state;
105const struct brw_tracked_state gen6_sf_vp;
106const struct brw_tracked_state gen6_urb;
107const struct brw_tracked_state gen6_viewport_state;
108const struct brw_tracked_state gen6_vs_state;
109const struct brw_tracked_state gen6_wm_state;
110
111/**
112 * Use same key for WM and VS surfaces.
113 */
114struct brw_surface_key {
115   GLenum target, depthmode;
116   dri_bo *bo;
117   GLint format, internal_format;
118   GLint first_level, last_level;
119   GLint width, height, depth;
120   GLint pitch, cpp;
121   uint32_t tiling;
122   GLuint offset;
123};
124
125/***********************************************************************
126 * brw_state.c
127 */
128void brw_validate_state(struct brw_context *brw);
129void brw_upload_state(struct brw_context *brw);
130void brw_init_state(struct brw_context *brw);
131void brw_destroy_state(struct brw_context *brw);
132void brw_clear_validated_bos(struct brw_context *brw);
133
134/***********************************************************************
135 * brw_state_cache.c
136 */
137dri_bo *brw_cache_data(struct brw_cache *cache,
138		       enum brw_cache_id cache_id,
139		       const void *data,
140		       GLuint size,
141		       dri_bo **reloc_bufs,
142		       GLuint nr_reloc_bufs);
143
144drm_intel_bo *brw_upload_cache(struct brw_cache *cache,
145			       enum brw_cache_id cache_id,
146			       const void *key,
147			       GLuint key_sz,
148			       dri_bo **reloc_bufs,
149			       GLuint nr_reloc_bufs,
150			       const void *data,
151			       GLuint data_sz);
152
153drm_intel_bo *brw_upload_cache_with_auxdata(struct brw_cache *cache,
154					    enum brw_cache_id cache_id,
155					    const void *key,
156					    GLuint key_sz,
157					    dri_bo **reloc_bufs,
158					    GLuint nr_reloc_bufs,
159					    const void *data,
160					    GLuint data_sz,
161					    const void *aux,
162					    GLuint aux_sz,
163					    void *aux_return);
164
165dri_bo *brw_search_cache( struct brw_cache *cache,
166			  enum brw_cache_id cache_id,
167			  const void *key,
168			  GLuint key_size,
169			  dri_bo **reloc_bufs,
170			  GLuint nr_reloc_bufs,
171			  void *aux_return);
172void brw_state_cache_check_size( struct brw_context *brw );
173
174void brw_init_caches( struct brw_context *brw );
175void brw_destroy_caches( struct brw_context *brw );
176void brw_state_cache_bo_delete(struct brw_cache *cache, dri_bo *bo);
177
178/***********************************************************************
179 * brw_state_batch.c
180 */
181#define BRW_BATCH_STRUCT(brw, s) intel_batchbuffer_data( brw->intel.batch, (s), sizeof(*(s)))
182#define BRW_CACHED_BATCH_STRUCT(brw, s) brw_cached_batch_struct( brw, (s), sizeof(*(s)) )
183
184GLboolean brw_cached_batch_struct( struct brw_context *brw,
185				   const void *data,
186				   GLuint sz );
187void brw_destroy_batch_cache( struct brw_context *brw );
188void brw_clear_batch_cache( struct brw_context *brw );
189
190/* brw_wm_surface_state.c */
191dri_bo *
192brw_create_constant_surface( struct brw_context *brw,
193                             struct brw_surface_key *key );
194
195#endif
196