blob: a35e9a5c9012d6d27fdbb7e4d0fe2abfeea90501 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
#ifndef XORG_EXA_H
#define XORG_EXA_H
#include "xorg_tracker.h"
#include <pipe/p_state.h>
struct cso_context;
struct xorg_shaders;
/* src + mask + dst */
#define MAX_EXA_SAMPLERS 3
struct exa_context
{
ExaDriverPtr pExa;
struct pipe_context *pipe;
struct pipe_screen *scrn;
struct xorg_renderer *renderer;
struct pipe_sampler_view *bound_sampler_views[MAX_EXA_SAMPLERS];
int num_bound_samplers;
float solid_color[4];
boolean has_solid_color;
boolean accel;
/* float[9] projective matrix bound to pictures */
struct {
float src[9];
float mask[9];
boolean has_src;
boolean has_mask;
} transform;
struct {
boolean use_surface_copy;
struct exa_pixmap_priv *src;
struct exa_pixmap_priv *dst;
struct pipe_surface *src_surface;
struct pipe_surface *dst_surface;
struct pipe_resource *src_texture;
} copy;
};
struct exa_pixmap_priv
{
int width, height;
int flags;
int tex_flags;
int picture_format;
struct pipe_resource *tex;
struct pipe_resource *depth_stencil_tex;
struct pipe_transfer *map_transfer;
unsigned map_count;
};
#define XORG_FALLBACK(s, arg...) \
do { \
if (ms->debug_fallback) { \
xf86DrvMsg(pScrn->scrnIndex, X_INFO, \
"%s fallback " s "\n", __FUNCTION__, ##arg); \
} \
return FALSE; \
} while(0)
struct pipe_surface *
xorg_gpu_surface(struct pipe_screen *scrn, struct exa_pixmap_priv *priv);
void xorg_exa_flush(struct exa_context *exa, uint pipeFlushFlags,
struct pipe_fence_handle **fence);
void xorg_exa_finish(struct exa_context *exa);
#endif
|