2013-02-28 11:38:30 +00:00
|
|
|
#ifndef SNA_RENDER_INLINE_H
|
|
|
|
#define SNA_RENDER_INLINE_H
|
|
|
|
|
|
|
|
static inline bool need_tiling(struct sna *sna, int16_t width, int16_t height)
|
|
|
|
{
|
|
|
|
/* Is the damage area too large to fit in 3D pipeline,
|
|
|
|
* and so do we need to split the operation up into tiles?
|
|
|
|
*/
|
|
|
|
return (width > sna->render.max_3d_size ||
|
|
|
|
height > sna->render.max_3d_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool need_redirect(struct sna *sna, PixmapPtr dst)
|
|
|
|
{
|
|
|
|
/* Is the pixmap too large to render to? */
|
|
|
|
return (dst->drawable.width > sna->render.max_3d_size ||
|
|
|
|
dst->drawable.height > sna->render.max_3d_size);
|
|
|
|
}
|
|
|
|
|
2013-11-18 11:28:53 +00:00
|
|
|
static force_inline float pack_2s(int16_t x, int16_t y)
|
2013-02-28 11:38:30 +00:00
|
|
|
{
|
|
|
|
union {
|
|
|
|
struct sna_coordinate p;
|
|
|
|
float f;
|
|
|
|
} u;
|
|
|
|
u.p.x = x;
|
|
|
|
u.p.y = y;
|
|
|
|
return u.f;
|
|
|
|
}
|
|
|
|
|
2013-11-18 11:28:53 +00:00
|
|
|
static force_inline int vertex_space(struct sna *sna)
|
2013-02-28 11:38:30 +00:00
|
|
|
{
|
|
|
|
return sna->render.vertex_size - sna->render.vertex_used;
|
|
|
|
}
|
2013-11-18 11:28:53 +00:00
|
|
|
static force_inline void vertex_emit(struct sna *sna, float v)
|
2013-02-28 11:38:30 +00:00
|
|
|
{
|
|
|
|
assert(sna->render.vertex_used < sna->render.vertex_size);
|
|
|
|
sna->render.vertices[sna->render.vertex_used++] = v;
|
|
|
|
}
|
2013-11-18 11:28:53 +00:00
|
|
|
static force_inline void vertex_emit_2s(struct sna *sna, int16_t x, int16_t y)
|
2013-02-28 11:38:30 +00:00
|
|
|
{
|
|
|
|
vertex_emit(sna, pack_2s(x, y));
|
|
|
|
}
|
|
|
|
|
2013-11-18 11:28:53 +00:00
|
|
|
static force_inline int batch_space(struct sna *sna)
|
2013-02-28 11:38:30 +00:00
|
|
|
{
|
|
|
|
assert(sna->kgem.nbatch <= KGEM_BATCH_SIZE(&sna->kgem));
|
|
|
|
assert(sna->kgem.nbatch + KGEM_BATCH_RESERVED <= sna->kgem.surface);
|
|
|
|
return sna->kgem.surface - sna->kgem.nbatch - KGEM_BATCH_RESERVED;
|
|
|
|
}
|
|
|
|
|
2013-11-18 11:28:53 +00:00
|
|
|
static force_inline void batch_emit(struct sna *sna, uint32_t dword)
|
2013-02-28 11:38:30 +00:00
|
|
|
{
|
|
|
|
assert(sna->kgem.mode != KGEM_NONE);
|
|
|
|
assert(sna->kgem.nbatch + KGEM_BATCH_RESERVED < sna->kgem.surface);
|
|
|
|
sna->kgem.batch[sna->kgem.nbatch++] = dword;
|
|
|
|
}
|
|
|
|
|
2013-11-18 11:28:53 +00:00
|
|
|
static force_inline void batch_emit_float(struct sna *sna, float f)
|
2013-02-28 11:38:30 +00:00
|
|
|
{
|
|
|
|
union {
|
|
|
|
uint32_t dw;
|
|
|
|
float f;
|
|
|
|
} u;
|
|
|
|
u.f = f;
|
|
|
|
batch_emit(sna, u.dw);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* SNA_RENDER_INLINE_H */
|