Merge branch '7.8'
[mesa.git] / src / gallium / drivers / nvfx / nvfx_screen.h
1 #ifndef __NVFX_SCREEN_H__
2 #define __NVFX_SCREEN_H__
3
4 #include "nouveau/nouveau_screen.h"
5 #include "nv04_surface_2d.h"
6
7 struct nvfx_screen {
8 struct nouveau_screen base;
9
10 struct nouveau_winsys *nvws;
11
12 struct nvfx_context *cur_ctx;
13
14 unsigned is_nv4x; /* either 0 or ~0 */
15
16 /* HW graphics objects */
17 struct nv04_surface_2d *eng2d;
18 struct nouveau_grobj *eng3d;
19 struct nouveau_notifier *sync;
20
21 /* Query object resources */
22 struct nouveau_notifier *query;
23 struct nouveau_resource *query_heap;
24
25 /* Vtxprog resources */
26 struct nouveau_resource *vp_exec_heap;
27 struct nouveau_resource *vp_data_heap;
28
29 /* Current 3D state of channel */
30 struct nouveau_stateobj *state[NVFX_STATE_MAX];
31 };
32
33 static INLINE struct nvfx_screen *
34 nvfx_screen(struct pipe_screen *screen)
35 {
36 return (struct nvfx_screen *)screen;
37 }
38
39 #endif