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 struct intel_region *draw_region;
76 int pp_flag; /* 0: disable, 1: enable */
78 struct i965_kernel render_kernels[3];
83 unsigned int end_offset;
93 unsigned int end_offset;
96 unsigned int curbe_offset;
99 unsigned int sampler_offset;
102 unsigned int cc_viewport_offset;
103 int cc_viewport_size;
105 unsigned int cc_state_offset;
108 unsigned int blend_state_offset;
109 int blend_state_size;
111 unsigned int sf_clip_offset;
114 unsigned int scissor_offset;
117 void (*render_put_surface)(VADriverContextP ctx, struct object_surface *,
118 const VARectangle *src_rec,
119 const VARectangle *dst_rect,
121 void (*render_put_subpicture)(VADriverContextP ctx, struct object_surface *,
122 const VARectangle *src_rec,
123 const VARectangle *dst_rect);
124 void (*render_terminate)(VADriverContextP ctx);
127 bool i965_render_init(VADriverContextP ctx);
128 void i965_render_terminate(VADriverContextP ctx);
131 intel_render_put_surface(
132 VADriverContextP ctx,
133 struct object_surface *obj_surface,
134 const VARectangle *src_rect,
135 const VARectangle *dst_rect,
140 intel_render_put_subpicture(
141 VADriverContextP ctx,
142 struct object_surface *obj_surface,
143 const VARectangle *src_rect,
144 const VARectangle *dst_rect
147 struct gen7_surface_state;
150 gen7_render_set_surface_scs(struct gen7_surface_state *ss);
152 struct gen8_surface_state;
154 gen8_render_set_surface_scs(struct gen8_surface_state *ss);
156 extern bool gen8_render_init(VADriverContextP ctx);
158 extern bool gen9_render_init(VADriverContextP ctx);
160 #endif /* _I965_RENDER_H_ */