e8578c8be6f839a7fd974ee91c8ddf81ab9e99fb
2 #ifndef __NV50_WINSYS_H__
3 #define __NV50_WINSYS_H__
8 #include "pipe/p_defines.h"
10 #include "nouveau_winsys.h"
11 #include "nouveau_buffer.h"
14 #ifndef NV04_PFIFO_MAX_PACKET_LEN
15 #define NV04_PFIFO_MAX_PACKET_LEN 2047
20 nv50_add_bufctx_resident_bo(struct nouveau_bufctx
*bufctx
, int bin
,
21 unsigned flags
, struct nouveau_bo
*bo
)
23 nouveau_bufctx_refn(bufctx
, bin
, bo
, flags
)->priv
= NULL
;
27 nv50_add_bufctx_resident(struct nouveau_bufctx
*bufctx
, int bin
,
28 struct nv04_resource
*res
, unsigned flags
)
30 struct nouveau_bufref
*ref
=
31 nouveau_bufctx_refn(bufctx
, bin
, res
->bo
, flags
| res
->domain
);
33 ref
->priv_data
= flags
;
36 #define BCTX_REFN_bo(ctx, bin, fl, bo) \
37 nv50_add_bufctx_resident_bo(ctx, NV50_BIND_##bin, fl, bo);
39 #define BCTX_REFN(bctx, bin, res, acc) \
40 nv50_add_bufctx_resident(bctx, NV50_BIND_##bin, res, NOUVEAU_BO_##acc)
43 PUSH_REFN(struct nouveau_pushbuf
*push
, struct nouveau_bo
*bo
, uint32_t flags
)
45 struct nouveau_pushbuf_refn ref
= { bo
, flags
};
46 nouveau_pushbuf_refn(push
, &ref
, 1);
50 #define SUBC_3D(m) 3, (m)
51 #define NV50_3D(n) SUBC_3D(NV50_3D_##n)
52 #define NVA0_3D(n) SUBC_3D(NVA0_3D_##n)
54 #define SUBC_2D(m) 4, (m)
55 #define NV50_2D(n) SUBC_2D(NV50_2D_##n)
57 #define SUBC_M2MF(m) 5, (m)
58 #define NV50_M2MF(n) SUBC_M2MF(NV50_M2MF_##n)
60 #define SUBC_COMPUTE(m) 6, (m)
61 #define NV50_COMPUTE(n) SUBC_COMPUTE(NV50_COMPUTE_##n)
64 static INLINE
uint32_t
65 NV50_FIFO_PKHDR(int subc
, int mthd
, unsigned size
)
67 return 0x00000000 | (size
<< 18) | (subc
<< 13) | mthd
;
70 static INLINE
uint32_t
71 NV50_FIFO_PKHDR_NI(int subc
, int mthd
, unsigned size
)
73 return 0x40000000 | (size
<< 18) | (subc
<< 13) | mthd
;
76 static INLINE
uint32_t
77 NV50_FIFO_PKHDR_L(int subc
, int mthd
)
79 return 0x00030000 | (subc
<< 13) | mthd
;
83 static INLINE
uint32_t
84 nouveau_bo_memtype(const struct nouveau_bo
*bo
)
86 return bo
->config
.nv50
.memtype
;
91 PUSH_DATAh(struct nouveau_pushbuf
*push
, uint64_t data
)
93 *push
->cur
++ = (uint32_t)(data
>> 32);
97 BEGIN_NV04(struct nouveau_pushbuf
*push
, int subc
, int mthd
, unsigned size
)
99 #ifndef NV50_PUSH_EXPLICIT_SPACE_CHECKING
100 PUSH_SPACE(push
, size
+ 1);
102 PUSH_DATA (push
, NV50_FIFO_PKHDR(subc
, mthd
, size
));
106 BEGIN_NI04(struct nouveau_pushbuf
*push
, int subc
, int mthd
, unsigned size
)
108 #ifndef NV50_PUSH_EXPLICIT_SPACE_CHECKING
109 PUSH_SPACE(push
, size
+ 1);
111 PUSH_DATA (push
, NV50_FIFO_PKHDR_NI(subc
, mthd
, size
));
114 /* long, non-incremental, nv50-only */
116 BEGIN_NL50(struct nouveau_pushbuf
*push
, int subc
, int mthd
, uint32_t size
)
118 #ifndef NV50_PUSH_EXPLICIT_SPACE_CHECKING
121 PUSH_DATA (push
, NV50_FIFO_PKHDR_L(subc
, mthd
));
122 PUSH_DATA (push
, size
);
125 #endif /* __NV50_WINSYS_H__ */