2 #ifndef __NV50_WINSYS_H__
3 #define __NV50_WINSYS_H__
8 #include "pipe/p_defines.h"
10 #include "nouveau/nouveau_winsys.h"
11 #include "nouveau/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)
53 #define SUBC_2D(m) 4, (m)
54 #define NV50_2D(n) SUBC_2D(NV50_2D_##n)
56 #define SUBC_M2MF(m) 5, (m)
57 #define NV50_M2MF(n) SUBC_M2MF(NV50_M2MF_##n)
59 #define SUBC_COMPUTE(m) 6, (m)
60 #define NV50_COMPUTE(n) SUBC_COMPUTE(NV50_COMPUTE_##n)
63 static INLINE
uint32_t
64 NV50_FIFO_PKHDR(int subc
, int mthd
, unsigned size
)
66 return 0x00000000 | (size
<< 18) | (subc
<< 13) | mthd
;
69 static INLINE
uint32_t
70 NV50_FIFO_PKHDR_NI(int subc
, int mthd
, unsigned size
)
72 return 0x40000000 | (size
<< 18) | (subc
<< 13) | mthd
;
75 static INLINE
uint32_t
76 NV50_FIFO_PKHDR_L(int subc
, int mthd
)
78 return 0x00030000 | (subc
<< 13) | mthd
;
82 static INLINE
uint32_t
83 nouveau_bo_memtype(const struct nouveau_bo
*bo
)
85 return bo
->config
.nv50
.memtype
;
90 PUSH_DATAh(struct nouveau_pushbuf
*push
, uint64_t data
)
92 *push
->cur
++ = (uint32_t)(data
>> 32);
96 BEGIN_NV04(struct nouveau_pushbuf
*push
, int subc
, int mthd
, unsigned size
)
98 #ifndef NV50_PUSH_EXPLICIT_SPACE_CHECKING
99 PUSH_SPACE(push
, size
+ 1);
101 PUSH_DATA (push
, NV50_FIFO_PKHDR(subc
, mthd
, size
));
105 BEGIN_NI04(struct nouveau_pushbuf
*push
, int subc
, int mthd
, unsigned size
)
107 #ifndef NV50_PUSH_EXPLICIT_SPACE_CHECKING
108 PUSH_SPACE(push
, size
+ 1);
110 PUSH_DATA (push
, NV50_FIFO_PKHDR_NI(subc
, mthd
, size
));
113 /* long, non-incremental, nv50-only */
115 BEGIN_NL50(struct nouveau_pushbuf
*push
, int subc
, int mthd
, uint32_t size
)
117 #ifndef NV50_PUSH_EXPLICIT_SPACE_CHECKING
120 PUSH_DATA (push
, NV50_FIFO_PKHDR_L(subc
, mthd
));
121 PUSH_DATA (push
, size
);
124 #endif /* __NV50_WINSYS_H__ */