2 * Copyright © 2006 Intel Corporation
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21 * DEALINGS IN THE SOFTWARE.
24 * Xiang Haihao <haihao.xiang@intel.com>
28 #ifndef _I965_RENDER_H_
29 #define _I965_RENDER_H_
31 #define MAX_SAMPLERS 16
32 #define MAX_RENDER_SURFACES (MAX_SAMPLERS + 1)
34 #define NUM_RENDER_KERNEL 3
36 #define VA_SRC_COLOR_MASK 0x000000f0
38 #include "i965_post_processing.h"
42 struct i965_render_state
45 dri_bo *vertex_buffer;
60 dri_bo *surface_state_binding_table_bo;
67 dri_bo *depth_stencil;
74 unsigned short interleaved_uv;
75 unsigned short inited;
76 struct intel_region *draw_region;
78 int pp_flag; /* 0: disable, 1: enable */
80 struct i965_kernel render_kernels[3];
87 unsigned int end_offset;
97 unsigned int end_offset;
100 unsigned int curbe_offset;
103 unsigned int sampler_offset;
106 unsigned int cc_viewport_offset;
107 int cc_viewport_size;
109 unsigned int cc_state_offset;
112 unsigned int blend_state_offset;
113 int blend_state_size;
115 unsigned int sf_clip_offset;
118 unsigned int scissor_offset;
121 void (*render_put_surface)(VADriverContextP ctx, struct object_surface *,
122 const VARectangle *src_rec,
123 const VARectangle *dst_rect,
125 void (*render_put_subpicture)(VADriverContextP ctx, struct object_surface *,
126 const VARectangle *src_rec,
127 const VARectangle *dst_rect);
131 bool i965_render_init(VADriverContextP ctx);
132 void i965_render_terminate(VADriverContextP ctx);
135 intel_render_put_surface(
136 VADriverContextP ctx,
137 struct object_surface *obj_surface,
138 const VARectangle *src_rect,
139 const VARectangle *dst_rect,
144 intel_render_put_subpicture(
145 VADriverContextP ctx,
146 struct object_surface *obj_surface,
147 const VARectangle *src_rect,
148 const VARectangle *dst_rect
151 struct gen7_surface_state;
154 gen7_render_set_surface_scs(struct gen7_surface_state *ss);
156 struct gen8_surface_state;
158 gen8_render_set_surface_scs(struct gen8_surface_state *ss);
160 extern bool gen8_render_init(VADriverContextP ctx);
162 extern void gen8_render_terminate(VADriverContextP ctx);
164 #endif /* _I965_RENDER_H_ */