blob: 14bf5d83e3e1424728c27223692fa956128dfe65 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
#ifndef __NV40_STATE_H__
#define __NV40_STATE_H__
#include "pipe/p_state.h"
struct nv40_alpha_test_state {
uint32_t enabled;
uint32_t func;
uint32_t ref;
};
struct nv40_blend_state {
uint32_t b_enable;
uint32_t b_srcfunc;
uint32_t b_dstfunc;
uint32_t b_eqn;
uint32_t l_enable;
uint32_t l_op;
uint32_t c_mask;
uint32_t d_enable;
};
struct nv40_sampler_state {
uint32_t fmt;
uint32_t wrap;
uint32_t en;
uint32_t filt;
uint32_t bcol;
};
struct nv40_rasterizer_state {
uint32_t shade_model;
uint32_t line_width;
uint32_t line_smooth_en;
uint32_t line_stipple_en;
uint32_t line_stipple;
uint32_t point_size;
uint32_t poly_smooth_en;
uint32_t poly_stipple_en;
uint32_t poly_mode_front;
uint32_t poly_mode_back;
uint32_t front_face;
uint32_t cull_face;
uint32_t cull_face_en;
};
struct nv40_vertex_program {
const struct pipe_shader_state *pipe;
boolean translated;
boolean on_hw;
int start_ip;
uint32_t *insn;
int insn_len;
struct {
int pipe_id;
int hw_id;
float value[4];
} consts[256];
int num_consts;
uint32_t ir;
uint32_t or;
};
struct nv40_fragment_program {
const struct pipe_shader_state *pipe;
boolean translated;
boolean on_hw;
uint32_t *insn;
int insn_len;
struct {
int pipe_id;
int hw_id;
} consts[256];
int num_consts;
struct pipe_buffer_handle *buffer;
boolean uses_kil;
boolean writes_depth;
int num_regs;
};
struct nv40_depth_push {
uint32_t func;
uint32_t write_enable;
uint32_t test_enable;
};
struct nv40_stencil_push {
uint32_t enable;
uint32_t wmask;
uint32_t func;
uint32_t ref;
uint32_t vmask;
uint32_t fail;
uint32_t zfail;
uint32_t zpass;
};
struct nv40_depth_stencil_state {
struct nv40_depth_push depth;
union {
struct nv40_stencil_push back;
struct nv40_stencil_push front;
} stencil;
};
#endif
|