st/nine: Always set point_quad_rasterization to 1
[mesa.git] / src / gallium / state_trackers / nine / nine_pipe.c
1 /*
2 * Copyright 2011 Joakim Sindholt <opensource@zhasha.com>
3 * Copyright 2013 Christoph Bumiller
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * on the rights to use, copy, modify, merge, publish, distribute, sub
9 * license, and/or sell copies of the Software, and to permit persons to whom
10 * the Software is furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice (including the next
13 * paragraph) shall be included in all copies or substantial portions of the
14 * Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,
20 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
21 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
22 * USE OR OTHER DEALINGS IN THE SOFTWARE. */
23
24 #include "device9.h"
25 #include "nine_pipe.h"
26
27 #include "cso_cache/cso_context.h"
28
29 void
30 nine_convert_dsa_state(struct cso_context *ctx, const DWORD *rs)
31 {
32 struct pipe_depth_stencil_alpha_state dsa;
33
34 memset(&dsa, 0, sizeof(dsa)); /* memcmp safety */
35
36 if (rs[D3DRS_ZENABLE]) {
37 dsa.depth.enabled = 1;
38 dsa.depth.writemask = !!rs[D3DRS_ZWRITEENABLE];
39 dsa.depth.func = d3dcmpfunc_to_pipe_func(rs[D3DRS_ZFUNC]);
40 }
41
42 if (rs[D3DRS_STENCILENABLE]) {
43 dsa.stencil[0].enabled = 1;
44 dsa.stencil[0].func = d3dcmpfunc_to_pipe_func(rs[D3DRS_STENCILFUNC]);
45 dsa.stencil[0].fail_op = d3dstencilop_to_pipe_stencil_op(rs[D3DRS_STENCILFAIL]);
46 dsa.stencil[0].zpass_op = d3dstencilop_to_pipe_stencil_op(rs[D3DRS_STENCILPASS]);
47 dsa.stencil[0].zfail_op = d3dstencilop_to_pipe_stencil_op(rs[D3DRS_STENCILZFAIL]);
48 dsa.stencil[0].valuemask = rs[D3DRS_STENCILMASK];
49 dsa.stencil[0].writemask = rs[D3DRS_STENCILWRITEMASK];
50
51 if (rs[D3DRS_TWOSIDEDSTENCILMODE]) {
52 dsa.stencil[1].enabled = 1;
53 dsa.stencil[1].func = d3dcmpfunc_to_pipe_func(rs[D3DRS_CCW_STENCILFUNC]);
54 dsa.stencil[1].fail_op = d3dstencilop_to_pipe_stencil_op(rs[D3DRS_CCW_STENCILFAIL]);
55 dsa.stencil[1].zpass_op = d3dstencilop_to_pipe_stencil_op(rs[D3DRS_CCW_STENCILPASS]);
56 dsa.stencil[1].zfail_op = d3dstencilop_to_pipe_stencil_op(rs[D3DRS_CCW_STENCILZFAIL]);
57 dsa.stencil[1].valuemask = dsa.stencil[0].valuemask;
58 dsa.stencil[1].writemask = dsa.stencil[0].writemask;
59 }
60 }
61
62 if (rs[D3DRS_ALPHATESTENABLE]) {
63 dsa.alpha.enabled = 1;
64 dsa.alpha.func = d3dcmpfunc_to_pipe_func(rs[D3DRS_ALPHAFUNC]);
65 dsa.alpha.ref_value = (float)rs[D3DRS_ALPHAREF] / 255.0f;
66 }
67
68 cso_set_depth_stencil_alpha(ctx, &dsa);
69 }
70
71 /* TODO: Keep a static copy in device so we don't have to memset every time ? */
72 void
73 nine_convert_rasterizer_state(struct cso_context *ctx, const DWORD *rs)
74 {
75 struct pipe_rasterizer_state rast;
76
77 memset(&rast, 0, sizeof(rast)); /* memcmp safety */
78
79 rast.flatshade = rs[D3DRS_SHADEMODE] == D3DSHADE_FLAT;
80 /* rast.light_twoside = 0; */
81 /* rast.clamp_fragment_color = 0; */
82 /* rast.clamp_vertex_color = 0; */
83 /* rast.front_ccw = 0; */
84 rast.cull_face = d3dcull_to_pipe_face(rs[D3DRS_CULLMODE]);
85 rast.fill_front = d3dfillmode_to_pipe_polygon_mode(rs[D3DRS_FILLMODE]);
86 rast.fill_back = rast.fill_front;
87 rast.offset_tri = !!(rs[D3DRS_DEPTHBIAS] | rs[D3DRS_SLOPESCALEDEPTHBIAS]);
88 rast.offset_line = rast.offset_tri; /* triangles in wireframe mode */
89 rast.offset_point = 0; /* XXX ? */
90 rast.scissor = !!rs[D3DRS_SCISSORTESTENABLE];
91 /* rast.poly_smooth = 0; */
92 /* rast.poly_stipple_enable = 0; */
93 /* rast.point_smooth = 0; */
94 rast.sprite_coord_mode = PIPE_SPRITE_COORD_UPPER_LEFT;
95 rast.point_quad_rasterization = 1;
96 rast.point_size_per_vertex = rs[NINED3DRS_VSPOINTSIZE];
97 rast.multisample = !!rs[D3DRS_MULTISAMPLEANTIALIAS];
98 rast.line_smooth = !!rs[D3DRS_ANTIALIASEDLINEENABLE];
99 /* rast.line_stipple_enable = 0; */
100 rast.line_last_pixel = !!rs[D3DRS_LASTPIXEL];
101 rast.flatshade_first = 1;
102 /* rast.half_pixel_center = 0; */
103 /* rast.lower_left_origin = 0; */
104 /* rast.bottom_edge_rule = 0; */
105 /* rast.rasterizer_discard = 0; */
106 rast.depth_clip = 1;
107 rast.clip_halfz = 1;
108 rast.clip_plane_enable = rs[D3DRS_CLIPPLANEENABLE];
109 /* rast.line_stipple_factor = 0; */
110 /* rast.line_stipple_pattern = 0; */
111 rast.sprite_coord_enable = rs[D3DRS_POINTSPRITEENABLE] ? 0xff : 0x00;
112 rast.line_width = 1.0f;
113 rast.point_size = rs[NINED3DRS_VSPOINTSIZE] ? 1.0f : asfloat(rs[D3DRS_POINTSIZE]); /* XXX: D3DRS_POINTSIZE_MIN/MAX */
114 rast.offset_units = asfloat(rs[D3DRS_DEPTHBIAS]) * asfloat(rs[NINED3DRS_ZBIASSCALE]);
115 rast.offset_scale = asfloat(rs[D3DRS_SLOPESCALEDEPTHBIAS]);
116 /* rast.offset_clamp = 0.0f; */
117
118 cso_set_rasterizer(ctx, &rast);
119 }
120
121 static inline void
122 nine_convert_blend_state_fixup(struct pipe_blend_state *blend, const DWORD *rs)
123 {
124 if (unlikely(rs[D3DRS_SRCBLEND] == D3DBLEND_BOTHSRCALPHA ||
125 rs[D3DRS_SRCBLEND] == D3DBLEND_BOTHINVSRCALPHA)) {
126 blend->rt[0].rgb_dst_factor = (rs[D3DRS_SRCBLEND] == D3DBLEND_BOTHSRCALPHA) ?
127 PIPE_BLENDFACTOR_INV_SRC_ALPHA : PIPE_BLENDFACTOR_SRC_ALPHA;
128 if (!rs[D3DRS_SEPARATEALPHABLENDENABLE])
129 blend->rt[0].alpha_dst_factor = blend->rt[0].rgb_dst_factor;
130 } else
131 if (unlikely(rs[D3DRS_SEPARATEALPHABLENDENABLE] &&
132 (rs[D3DRS_SRCBLENDALPHA] == D3DBLEND_BOTHSRCALPHA ||
133 rs[D3DRS_SRCBLENDALPHA] == D3DBLEND_BOTHINVSRCALPHA))) {
134 blend->rt[0].alpha_dst_factor = (rs[D3DRS_SRCBLENDALPHA] == D3DBLEND_BOTHSRCALPHA) ?
135 PIPE_BLENDFACTOR_INV_SRC_ALPHA : PIPE_BLENDFACTOR_SRC_ALPHA;
136 }
137 }
138
139 void
140 nine_convert_blend_state(struct cso_context *ctx, const DWORD *rs)
141 {
142 struct pipe_blend_state blend;
143
144 memset(&blend, 0, sizeof(blend)); /* memcmp safety */
145
146 blend.dither = !!rs[D3DRS_DITHERENABLE];
147
148 /* blend.alpha_to_one = 0; */
149 blend.alpha_to_coverage = !!rs[NINED3DRS_ALPHACOVERAGE];
150
151 blend.rt[0].blend_enable = !!rs[D3DRS_ALPHABLENDENABLE];
152 if (blend.rt[0].blend_enable) {
153 blend.rt[0].rgb_func = d3dblendop_to_pipe_blend(rs[D3DRS_BLENDOP]);
154 blend.rt[0].rgb_src_factor = d3dblend_color_to_pipe_blendfactor(rs[D3DRS_SRCBLEND]);
155 blend.rt[0].rgb_dst_factor = d3dblend_color_to_pipe_blendfactor(rs[D3DRS_DESTBLEND]);
156 if (rs[D3DRS_SEPARATEALPHABLENDENABLE]) {
157 blend.rt[0].alpha_func = d3dblendop_to_pipe_blend(rs[D3DRS_BLENDOPALPHA]);
158 blend.rt[0].alpha_src_factor = d3dblend_alpha_to_pipe_blendfactor(rs[D3DRS_SRCBLENDALPHA]);
159 blend.rt[0].alpha_dst_factor = d3dblend_alpha_to_pipe_blendfactor(rs[D3DRS_DESTBLENDALPHA]);
160 } else {
161 /* TODO: Just copy the rgb values ? SRC1_x may differ ... */
162 blend.rt[0].alpha_func = blend.rt[0].rgb_func;
163 blend.rt[0].alpha_src_factor = d3dblend_alpha_to_pipe_blendfactor(rs[D3DRS_SRCBLEND]);
164 blend.rt[0].alpha_dst_factor = d3dblend_alpha_to_pipe_blendfactor(rs[D3DRS_DESTBLEND]);
165 }
166 nine_convert_blend_state_fixup(&blend, rs); /* for BOTH[INV]SRCALPHA */
167 }
168 blend.rt[0].colormask = rs[D3DRS_COLORWRITEENABLE];
169
170 if (rs[D3DRS_COLORWRITEENABLE1] != rs[D3DRS_COLORWRITEENABLE] ||
171 rs[D3DRS_COLORWRITEENABLE2] != rs[D3DRS_COLORWRITEENABLE] ||
172 rs[D3DRS_COLORWRITEENABLE3] != rs[D3DRS_COLORWRITEENABLE]) {
173 unsigned i;
174 blend.independent_blend_enable = TRUE;
175 for (i = 1; i < 4; ++i)
176 blend.rt[i] = blend.rt[0];
177 blend.rt[1].colormask = rs[D3DRS_COLORWRITEENABLE1];
178 blend.rt[2].colormask = rs[D3DRS_COLORWRITEENABLE2];
179 blend.rt[3].colormask = rs[D3DRS_COLORWRITEENABLE3];
180 }
181
182 /* blend.force_srgb = !!rs[D3DRS_SRGBWRITEENABLE]; */
183
184 cso_set_blend(ctx, &blend);
185 }
186
187 void
188 nine_convert_sampler_state(struct cso_context *ctx, int idx, const DWORD *ss)
189 {
190 struct pipe_sampler_state samp;
191
192 assert(idx >= 0 &&
193 (idx < NINE_MAX_SAMPLERS_PS || idx >= NINE_SAMPLER_VS(0)) &&
194 (idx < NINE_MAX_SAMPLERS));
195
196 memset(&samp, 0, sizeof(samp)); /* memcmp safety */
197
198 if (ss[D3DSAMP_MIPFILTER] != D3DTEXF_NONE) {
199 samp.lod_bias = asfloat(ss[D3DSAMP_MIPMAPLODBIAS]);
200 samp.min_lod = ss[NINED3DSAMP_MINLOD];
201 samp.min_mip_filter = (ss[D3DSAMP_MIPFILTER] == D3DTEXF_POINT) ? PIPE_TEX_FILTER_NEAREST : PIPE_TEX_FILTER_LINEAR;
202 } else {
203 samp.min_mip_filter = PIPE_TEX_MIPFILTER_NONE;
204 }
205 samp.max_lod = 15.0f;
206 samp.wrap_s = d3dtextureaddress_to_pipe_tex_wrap(ss[D3DSAMP_ADDRESSU]);
207 samp.wrap_t = d3dtextureaddress_to_pipe_tex_wrap(ss[D3DSAMP_ADDRESSV]);
208 samp.wrap_r = d3dtextureaddress_to_pipe_tex_wrap(ss[D3DSAMP_ADDRESSW]);
209 samp.min_img_filter = ss[D3DSAMP_MINFILTER] == D3DTEXF_POINT ? PIPE_TEX_FILTER_NEAREST : PIPE_TEX_FILTER_LINEAR;
210 samp.mag_img_filter = ss[D3DSAMP_MAGFILTER] == D3DTEXF_POINT ? PIPE_TEX_FILTER_NEAREST : PIPE_TEX_FILTER_LINEAR;
211 if (ss[D3DSAMP_MINFILTER] == D3DTEXF_ANISOTROPIC ||
212 ss[D3DSAMP_MAGFILTER] == D3DTEXF_ANISOTROPIC)
213 samp.max_anisotropy = ss[D3DSAMP_MAXANISOTROPY];
214 samp.compare_mode = ss[NINED3DSAMP_SHADOW] ? PIPE_TEX_COMPARE_R_TO_TEXTURE : PIPE_TEX_COMPARE_NONE;
215 samp.compare_func = PIPE_FUNC_LEQUAL;
216 samp.normalized_coords = 1;
217 samp.seamless_cube_map = 1;
218 d3dcolor_to_pipe_color_union(&samp.border_color, ss[D3DSAMP_BORDERCOLOR]);
219
220 /* see nine_state.h */
221 if (idx < NINE_MAX_SAMPLERS_PS)
222 cso_single_sampler(ctx, PIPE_SHADER_FRAGMENT, idx - NINE_SAMPLER_PS(0), &samp);
223 else
224 cso_single_sampler(ctx, PIPE_SHADER_VERTEX, idx - NINE_SAMPLER_VS(0), &samp);
225 }
226
227 void
228 nine_pipe_context_clear(struct NineDevice9 *This)
229 {
230 struct pipe_context *pipe = This->pipe;
231 struct cso_context *cso = This->cso;
232 pipe->bind_vs_state(pipe, NULL);
233 pipe->bind_fs_state(pipe, NULL);
234
235 /* Don't unbind constant buffers, they're device-private and
236 * do not change on Reset.
237 */
238
239 cso_set_samplers(cso, PIPE_SHADER_VERTEX, 0, NULL);
240 cso_set_samplers(cso, PIPE_SHADER_FRAGMENT, 0, NULL);
241
242 pipe->set_sampler_views(pipe, PIPE_SHADER_FRAGMENT, 0, 0, NULL);
243 pipe->set_sampler_views(pipe, PIPE_SHADER_VERTEX, 0, 0, NULL);
244
245 pipe->set_vertex_buffers(pipe, 0, This->caps.MaxStreams, NULL);
246 pipe->set_index_buffer(pipe, NULL);
247 }
248
249 const enum pipe_format nine_d3d9_to_pipe_format_map[120] =
250 {
251 [D3DFMT_UNKNOWN] = PIPE_FORMAT_NONE,
252 [D3DFMT_R8G8B8] = PIPE_FORMAT_NONE,
253 [D3DFMT_A8R8G8B8] = PIPE_FORMAT_B8G8R8A8_UNORM,
254 [D3DFMT_X8R8G8B8] = PIPE_FORMAT_B8G8R8X8_UNORM,
255 [D3DFMT_R5G6B5] = PIPE_FORMAT_B5G6R5_UNORM,
256 [D3DFMT_X1R5G5B5] = PIPE_FORMAT_B5G5R5X1_UNORM,
257 [D3DFMT_A1R5G5B5] = PIPE_FORMAT_B5G5R5A1_UNORM,
258 [D3DFMT_A4R4G4B4] = PIPE_FORMAT_B4G4R4A4_UNORM,
259 [D3DFMT_R3G3B2] = PIPE_FORMAT_B2G3R3_UNORM,
260 [D3DFMT_A8] = PIPE_FORMAT_A8_UNORM,
261 [D3DFMT_A8R3G3B2] = PIPE_FORMAT_NONE,
262 [D3DFMT_X4R4G4B4] = PIPE_FORMAT_B4G4R4X4_UNORM,
263 [D3DFMT_A2B10G10R10] = PIPE_FORMAT_R10G10B10A2_UNORM,
264 [D3DFMT_A8B8G8R8] = PIPE_FORMAT_R8G8B8A8_UNORM,
265 [D3DFMT_X8B8G8R8] = PIPE_FORMAT_R8G8B8X8_UNORM,
266 [D3DFMT_G16R16] = PIPE_FORMAT_R16G16_UNORM,
267 [D3DFMT_A2R10G10B10] = PIPE_FORMAT_B10G10R10A2_UNORM,
268 [D3DFMT_A16B16G16R16] = PIPE_FORMAT_R16G16B16A16_UNORM,
269 [D3DFMT_A8P8] = PIPE_FORMAT_NONE,
270 [D3DFMT_P8] = PIPE_FORMAT_NONE,
271 [D3DFMT_L8] = PIPE_FORMAT_L8_UNORM,
272 [D3DFMT_A8L8] = PIPE_FORMAT_L8A8_UNORM,
273 [D3DFMT_A4L4] = PIPE_FORMAT_L4A4_UNORM,
274 [D3DFMT_V8U8] = PIPE_FORMAT_R8G8_SNORM,
275 [D3DFMT_L6V5U5] = PIPE_FORMAT_NONE,
276 [D3DFMT_X8L8V8U8] = PIPE_FORMAT_NONE,
277 [D3DFMT_Q8W8V8U8] = PIPE_FORMAT_R8G8B8A8_SNORM,
278 [D3DFMT_V16U16] = PIPE_FORMAT_R16G16_SNORM,
279 [D3DFMT_A2W10V10U10] = PIPE_FORMAT_R10SG10SB10SA2U_NORM,
280 [D3DFMT_D16_LOCKABLE] = PIPE_FORMAT_Z16_UNORM,
281 [D3DFMT_D32] = PIPE_FORMAT_Z32_UNORM,
282 [D3DFMT_D15S1] = PIPE_FORMAT_Z24_UNORM_S8_UINT,
283 [D3DFMT_D24S8] = PIPE_FORMAT_S8_UINT_Z24_UNORM,
284 [D3DFMT_D24X8] = PIPE_FORMAT_X8Z24_UNORM,
285 [D3DFMT_D24X4S4] = PIPE_FORMAT_Z24_UNORM_S8_UINT,
286 [D3DFMT_D16] = PIPE_FORMAT_Z16_UNORM,
287 [D3DFMT_D32F_LOCKABLE] = PIPE_FORMAT_Z32_FLOAT,
288 [D3DFMT_D24FS8] = PIPE_FORMAT_Z32_FLOAT_S8X24_UINT,
289 [D3DFMT_D32_LOCKABLE] = PIPE_FORMAT_NONE,
290 [D3DFMT_S8_LOCKABLE] = PIPE_FORMAT_NONE,
291 [D3DFMT_L16] = PIPE_FORMAT_L16_UNORM,
292 [D3DFMT_VERTEXDATA] = PIPE_FORMAT_NONE,
293 [D3DFMT_INDEX16] = PIPE_FORMAT_R16_UINT,
294 [D3DFMT_INDEX32] = PIPE_FORMAT_R32_UINT,
295 [D3DFMT_Q16W16V16U16] = PIPE_FORMAT_R16G16B16A16_SNORM,
296 [D3DFMT_R16F] = PIPE_FORMAT_R16_FLOAT,
297 [D3DFMT_G16R16F] = PIPE_FORMAT_R16G16_FLOAT,
298 [D3DFMT_A16B16G16R16F] = PIPE_FORMAT_R16G16B16A16_FLOAT,
299 [D3DFMT_R32F] = PIPE_FORMAT_R32_FLOAT,
300 [D3DFMT_G32R32F] = PIPE_FORMAT_R32G32_FLOAT,
301 [D3DFMT_A32B32G32R32F] = PIPE_FORMAT_R32G32B32A32_FLOAT,
302 [D3DFMT_CxV8U8] = PIPE_FORMAT_NONE,
303 [D3DFMT_A1] = PIPE_FORMAT_NONE,
304 [D3DFMT_A2B10G10R10_XR_BIAS] = PIPE_FORMAT_NONE,
305 };
306
307 const D3DFORMAT nine_pipe_to_d3d9_format_map[PIPE_FORMAT_COUNT] =
308 {
309 [PIPE_FORMAT_NONE] = D3DFMT_UNKNOWN,
310
311 /* [PIPE_FORMAT_B8G8R8_UNORM] = D3DFMT_R8G8B8, */
312 [PIPE_FORMAT_B8G8R8A8_UNORM] = D3DFMT_A8R8G8B8,
313 [PIPE_FORMAT_B8G8R8X8_UNORM] = D3DFMT_X8R8G8B8,
314 [PIPE_FORMAT_B5G6R5_UNORM] = D3DFMT_R5G6B5,
315 [PIPE_FORMAT_B5G5R5X1_UNORM] = D3DFMT_X1R5G5B5,
316 [PIPE_FORMAT_B5G5R5A1_UNORM] = D3DFMT_A1R5G5B5,
317 [PIPE_FORMAT_B4G4R4A4_UNORM] = D3DFMT_A4R4G4B4,
318 [PIPE_FORMAT_B2G3R3_UNORM] = D3DFMT_R3G3B2,
319 [PIPE_FORMAT_A8_UNORM] = D3DFMT_A8,
320 /* [PIPE_FORMAT_B2G3R3A8_UNORM] = D3DFMT_A8R3G3B2, */
321 [PIPE_FORMAT_B4G4R4X4_UNORM] = D3DFMT_X4R4G4B4,
322 [PIPE_FORMAT_R10G10B10A2_UNORM] = D3DFMT_A2B10G10R10,
323 [PIPE_FORMAT_R8G8B8A8_UNORM] = D3DFMT_A8B8G8R8,
324 [PIPE_FORMAT_R8G8B8X8_UNORM] = D3DFMT_X8B8G8R8,
325 [PIPE_FORMAT_R16G16_UNORM] = D3DFMT_G16R16,
326 [PIPE_FORMAT_B10G10R10A2_UNORM] = D3DFMT_A2R10G10B10,
327 [PIPE_FORMAT_R16G16B16A16_UNORM] = D3DFMT_A16B16G16R16,
328
329 [PIPE_FORMAT_R8_UINT] = D3DFMT_P8,
330 [PIPE_FORMAT_R8A8_UINT] = D3DFMT_A8P8,
331
332 [PIPE_FORMAT_L8_UNORM] = D3DFMT_L8,
333 [PIPE_FORMAT_L8A8_UNORM] = D3DFMT_A8L8,
334 [PIPE_FORMAT_L4A4_UNORM] = D3DFMT_A4L4,
335
336 [PIPE_FORMAT_R8G8_SNORM] = D3DFMT_V8U8,
337 /* [PIPE_FORMAT_?] = D3DFMT_L6V5U5, */
338 /* [PIPE_FORMAT_?] = D3DFMT_X8L8V8U8, */
339 [PIPE_FORMAT_R8G8B8A8_SNORM] = D3DFMT_Q8W8V8U8,
340 [PIPE_FORMAT_R16G16_SNORM] = D3DFMT_V16U16,
341 [PIPE_FORMAT_R10SG10SB10SA2U_NORM] = D3DFMT_A2W10V10U10,
342
343 [PIPE_FORMAT_YUYV] = D3DFMT_UYVY,
344 /* [PIPE_FORMAT_YUY2] = D3DFMT_YUY2, */
345 [PIPE_FORMAT_DXT1_RGBA] = D3DFMT_DXT1,
346 /* [PIPE_FORMAT_DXT2_RGBA] = D3DFMT_DXT2, */
347 [PIPE_FORMAT_DXT3_RGBA] = D3DFMT_DXT3,
348 /* [PIPE_FORMAT_DXT4_RGBA] = D3DFMT_DXT4, */
349 [PIPE_FORMAT_DXT5_RGBA] = D3DFMT_DXT5,
350 /* [PIPE_FORMAT_?] = D3DFMT_MULTI2_ARGB8, (MET) */
351 [PIPE_FORMAT_R8G8_B8G8_UNORM] = D3DFMT_R8G8_B8G8, /* XXX: order */
352 [PIPE_FORMAT_G8R8_G8B8_UNORM] = D3DFMT_G8R8_G8B8,
353
354 [PIPE_FORMAT_Z16_UNORM] = D3DFMT_D16_LOCKABLE,
355 [PIPE_FORMAT_Z32_UNORM] = D3DFMT_D32,
356 /* [PIPE_FORMAT_Z15_UNORM_S1_UINT] = D3DFMT_D15S1, */
357 [PIPE_FORMAT_S8_UINT_Z24_UNORM] = D3DFMT_D24S8,
358 [PIPE_FORMAT_X8Z24_UNORM] = D3DFMT_D24X8,
359 [PIPE_FORMAT_L16_UNORM] = D3DFMT_L16,
360 [PIPE_FORMAT_Z32_FLOAT] = D3DFMT_D32F_LOCKABLE,
361 /* [PIPE_FORMAT_Z24_FLOAT_S8_UINT] = D3DFMT_D24FS8, */
362
363 [PIPE_FORMAT_R16_UINT] = D3DFMT_INDEX16,
364 [PIPE_FORMAT_R32_UINT] = D3DFMT_INDEX32,
365 [PIPE_FORMAT_R16G16B16A16_SNORM] = D3DFMT_Q16W16V16U16,
366
367 [PIPE_FORMAT_R16_FLOAT] = D3DFMT_R16F,
368 [PIPE_FORMAT_R32_FLOAT] = D3DFMT_R32F,
369 [PIPE_FORMAT_R16G16_FLOAT] = D3DFMT_G16R16F,
370 [PIPE_FORMAT_R32G32_FLOAT] = D3DFMT_G32R32F,
371 [PIPE_FORMAT_R16G16B16A16_FLOAT] = D3DFMT_A16B16G16R16F,
372 [PIPE_FORMAT_R32G32B32A32_FLOAT] = D3DFMT_A32B32G32R32F,
373
374 /* [PIPE_FORMAT_?] = D3DFMT_CxV8U8, */
375 };