Path: blob/21.2-virgl/src/gallium/drivers/nouveau/nvc0/nvc0_stateobj.h
4574 views
1#ifndef __NVC0_STATEOBJ_H__2#define __NVC0_STATEOBJ_H__34#include "pipe/p_state.h"56#define SB_BEGIN_3D(so, m, s) \7(so)->state[(so)->size++] = NVC0_FIFO_PKHDR_SQ(NVC0_3D(m), s)89#define SB_IMMED_3D(so, m, d) \10(so)->state[(so)->size++] = NVC0_FIFO_PKHDR_IL(NVC0_3D(m), d)1112#define SB_DATA(so, u) (so)->state[(so)->size++] = (u)1314#include "nv50/nv50_stateobj_tex.h"1516struct nvc0_blend_stateobj {17struct pipe_blend_state pipe;18int size;19uint32_t state[72];20};2122struct nvc0_rasterizer_stateobj {23struct pipe_rasterizer_state pipe;24int size;25uint32_t state[44];26};2728struct nvc0_zsa_stateobj {29struct pipe_depth_stencil_alpha_state pipe;30int size;31uint32_t state[30];32};3334struct nvc0_constbuf {35union {36struct pipe_resource *buf;37const void *data;38} u;39uint32_t size;40uint32_t offset;41bool user; /* should only be true if u.data is valid and non-NULL */42};4344struct nvc0_vertex_element {45struct pipe_vertex_element pipe;46uint32_t state;47uint32_t state_alt; /* buffer 0 and with source offset (for translate) */48};4950struct nvc0_vertex_stateobj {51uint32_t min_instance_div[PIPE_MAX_ATTRIBS];52uint16_t vb_access_size[PIPE_MAX_ATTRIBS];53struct translate *translate;54unsigned num_elements;55uint32_t instance_elts;56uint32_t instance_bufs;57bool shared_slots;58bool need_conversion; /* e.g. VFETCH cannot convert f64 to f32 */59unsigned size; /* size of vertex in bytes (when packed) */60struct nvc0_vertex_element element[0];61};6263struct nvc0_window_rect_stateobj {64bool inclusive;65unsigned rects;66struct pipe_scissor_state rect[PIPE_MAX_WINDOW_RECTANGLES];67};6869struct nvc0_so_target {70struct pipe_stream_output_target pipe;71struct pipe_query *pq;72unsigned stride;73bool clean;74};7576static inline struct nvc0_so_target *77nvc0_so_target(struct pipe_stream_output_target *ptarg)78{79return (struct nvc0_so_target *)ptarg;80}8182#endif838485