#include "pipe/nouveau/nouveau_gldefs.h"
#define NOUVEAU_PUSH_CONTEXT(ctx) \
- struct nv40_context *ctx = nv40
+ struct nv40_channel_context *ctx = nv40->hw
#include "pipe/nouveau/nouveau_push.h"
+#include "pipe/nouveau/nouveau_stateobj.h"
#include "nv40_state.h"
#define NOUVEAU_MSG(fmt, args...) \
fprintf(stderr, "nouveau: "fmt, ##args);
-#define NV40_NEW_VERTPROG (1 << 1)
-#define NV40_NEW_FRAGPROG (1 << 2)
-#define NV40_NEW_ARRAYS (1 << 3)
-
-struct nv40_context {
- struct pipe_context pipe;
+#define NV40_NEW_BLEND (1 << 0)
+#define NV40_NEW_RAST (1 << 1)
+#define NV40_NEW_ZSA (1 << 2)
+#define NV40_NEW_SAMPLER (1 << 3)
+#define NV40_NEW_FB (1 << 4)
+#define NV40_NEW_STIPPLE (1 << 5)
+#define NV40_NEW_SCISSOR (1 << 6)
+#define NV40_NEW_VIEWPORT (1 << 7)
+#define NV40_NEW_BCOL (1 << 8)
+#define NV40_NEW_VERTPROG (1 << 9)
+#define NV40_NEW_FRAGPROG (1 << 10)
+#define NV40_NEW_ARRAYS (1 << 11)
+
+struct nv40_channel_context {
struct nouveau_winsys *nvws;
+ unsigned refcount;
- struct draw_context *draw;
+ unsigned chipset;
- int chipset;
+ /* HW graphics objects */
struct nouveau_grobj *curie;
struct nouveau_notifier *sync;
- /* query objects */
+ /* Query object resources */
struct nouveau_notifier *query;
struct nouveau_resource *query_heap;
+ /* Vtxprog resources */
+ struct nouveau_resource *vp_exec_heap;
+ struct nouveau_resource *vp_data_heap;
+};
+
+struct nv40_context {
+ struct pipe_context pipe;
+ struct nouveau_winsys *nvws;
+
+ struct nv40_channel_context *hw;
+ struct draw_context *draw;
+
+ int chipset;
+
uint32_t dirty;
struct nv40_sampler_state *tex_sampler[PIPE_MAX_SAMPLERS];
unsigned fp_samplers;
unsigned vp_samplers;
- uint32_t rt_enable;
- struct pipe_buffer_handle *rt[4];
- struct pipe_buffer_handle *zeta;
+ struct nouveau_stateobj *so_framebuffer;
+ struct nouveau_stateobj *so_fragtex[16];
+ struct nouveau_stateobj *so_vtxbuf;
+ struct nouveau_stateobj *so_blend;
+ struct nouveau_stateobj *so_rast;
+ struct nouveau_stateobj *so_zsa;
+ struct nouveau_stateobj *so_bcol;
+ struct nouveau_stateobj *so_scissor;
+ struct nouveau_stateobj *so_viewport;
+ struct nouveau_stateobj *so_stipple;
struct {
- struct pipe_buffer_handle *buffer;
- uint32_t format;
- } tex[16];
-
- unsigned vb_enable;
- struct {
- struct pipe_buffer_handle *buffer;
- unsigned delta;
- } vb[16];
-
- struct {
- struct nouveau_resource *exec_heap;
- struct nouveau_resource *data_heap;
-
struct nv40_vertex_program *active;
struct nv40_vertex_program *current;
- struct pipe_buffer_handle *constant_buf;
+ struct pipe_buffer *constant_buf;
} vertprog;
struct {
struct nv40_fragment_program *active;
struct nv40_fragment_program *current;
- struct pipe_buffer_handle *constant_buf;
+ struct pipe_buffer *constant_buf;
} fragprog;
struct pipe_vertex_buffer vtxbuf[PIPE_ATTRIB_MAX];
struct pipe_vertex_element vtxelt[PIPE_ATTRIB_MAX];
};
-static inline struct nv40_context *
+static INLINE struct nv40_context *
nv40_context(struct pipe_context *pipe)
{
return (struct nv40_context *)pipe;
extern boolean nv40_draw_arrays(struct pipe_context *, unsigned mode,
unsigned start, unsigned count);
extern boolean nv40_draw_elements(struct pipe_context *pipe,
- struct pipe_buffer_handle *indexBuffer,
+ struct pipe_buffer *indexBuffer,
unsigned indexSize,
unsigned mode, unsigned start,
unsigned count);