1 #ifndef __NOUVEAU_SCREEN_H__
2 #define __NOUVEAU_SCREEN_H__
4 #include "pipe/p_screen.h"
5 #include "util/u_memory.h"
8 # define NOUVEAU_ENABLE_DRIVER_STATISTICS
14 extern int nouveau_mesa_debug
;
18 struct nouveau_screen
{
19 struct pipe_screen base
;
20 struct nouveau_device
*device
;
21 struct nouveau_object
*channel
;
22 struct nouveau_client
*client
;
23 struct nouveau_pushbuf
*pushbuf
;
25 unsigned vidmem_bindings
; /* PIPE_BIND_* where VRAM placement is desired */
26 unsigned sysmem_bindings
; /* PIPE_BIND_* where GART placement is desired */
27 unsigned lowmem_bindings
; /* PIPE_BIND_* that require an address < 4 GiB */
29 * For bindings with (vidmem & sysmem) bits set, PIPE_USAGE_* decides
36 struct nouveau_fence
*head
;
37 struct nouveau_fence
*tail
;
38 struct nouveau_fence
*current
;
41 void (*emit
)(struct pipe_screen
*, u32
*sequence
);
42 u32 (*update
)(struct pipe_screen
*);
45 struct nouveau_mman
*mm_VRAM
;
46 struct nouveau_mman
*mm_GART
;
48 int64_t cpu_gpu_time_delta
;
50 boolean hint_buf_keep_sysmem_copy
;
52 #ifdef NOUVEAU_ENABLE_DRIVER_STATISTICS
56 uint64_t tex_obj_current_count
;
57 uint64_t tex_obj_current_bytes
;
58 uint64_t buf_obj_current_count
;
59 uint64_t buf_obj_current_bytes_vid
;
60 uint64_t buf_obj_current_bytes_sys
;
61 uint64_t tex_transfers_rd
;
62 uint64_t tex_transfers_wr
;
63 uint64_t tex_copy_count
;
64 uint64_t tex_blit_count
;
65 uint64_t tex_cache_flush_count
;
66 uint64_t buf_transfers_rd
;
67 uint64_t buf_transfers_wr
;
68 uint64_t buf_read_bytes_staging_vid
;
69 uint64_t buf_write_bytes_direct
;
70 uint64_t buf_write_bytes_staging_vid
;
71 uint64_t buf_write_bytes_staging_sys
;
72 uint64_t buf_copy_bytes
;
73 uint64_t buf_non_kernel_fence_sync_count
;
74 uint64_t any_non_kernel_fence_sync_count
;
75 uint64_t query_sync_count
;
76 uint64_t gpu_serialize_count
;
77 uint64_t draw_calls_array
;
78 uint64_t draw_calls_indexed
;
79 uint64_t draw_calls_fallback_count
;
80 uint64_t user_buffer_upload_bytes
;
81 uint64_t constbuf_upload_count
;
82 uint64_t constbuf_upload_bytes
;
83 uint64_t pushbuf_count
;
84 uint64_t resource_validate_count
;
90 #ifdef NOUVEAU_ENABLE_DRIVER_STATISTICS
91 # define NOUVEAU_DRV_STAT(s, n, v) do { \
92 (s)->stats.named.n += (v); \
94 # define NOUVEAU_DRV_STAT_RES(r, n, v) do { \
95 nouveau_screen((r)->base.screen)->stats.named.n += (v); \
97 # define NOUVEAU_DRV_STAT_IFD(x) x
99 # define NOUVEAU_DRV_STAT(s, n, v) do { } while(0)
100 # define NOUVEAU_DRV_STAT_RES(r, n, v) do { } while(0)
101 # define NOUVEAU_DRV_STAT_IFD(x)
104 static INLINE
struct nouveau_screen
*
105 nouveau_screen(struct pipe_screen
*pscreen
)
107 return (struct nouveau_screen
*)pscreen
;
111 nouveau_screen_bo_get_handle(struct pipe_screen
*pscreen
,
112 struct nouveau_bo
*bo
,
114 struct winsys_handle
*whandle
);
116 nouveau_screen_bo_from_handle(struct pipe_screen
*pscreen
,
117 struct winsys_handle
*whandle
,
118 unsigned *out_stride
);
121 int nouveau_screen_init(struct nouveau_screen
*, struct nouveau_device
*);
122 void nouveau_screen_fini(struct nouveau_screen
*);
124 void nouveau_screen_init_vdec(struct nouveau_screen
*);