blob: 7d92587ca583d2d8693374e7bc703a5cb848313d (
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
|
#ifndef _YAGL_ONSCREEN_SURFACE_H_
#define _YAGL_ONSCREEN_SURFACE_H_
#include "yagl_export.h"
#include "yagl_types.h"
#include "yagl_surface.h"
#include "yagl_dri2.h"
#include "yagl_onscreen_display.h"
struct yagl_onscreen_surface
{
struct yagl_surface base;
/*
* Backing pixmap for PBuffer surfaces. NULL otherwise.
*/
Pixmap tmp_pixmap;
/*
* For widow surfaces this is DRI2BufferBackLeft.
* For pixmap surfaces this is DRI2BufferFrontLeft.
* For pbuffer surfaces this is DRI2BufferFrontLeft of 'tmp_pixmap'.
*
* TODO: For window surfaces we also need to support
* DRI2BufferFrontLeft.
*/
struct yagl_onscreen_buffer *buffer;
/*
* This gets incremented in DRI2 invalidate handler, compare it to
* 'last_timestamp' in order to find out if an invalidate event
* had occurred.
*/
uint32_t stamp;
/*
* Last value of 'stamp'.
*/
uint32_t last_stamp;
};
struct yagl_onscreen_surface
*yagl_onscreen_surface_create_window(struct yagl_display *dpy,
yagl_host_handle host_config,
Window x_win,
const EGLint* attrib_list);
struct yagl_onscreen_surface
*yagl_onscreen_surface_create_pixmap(struct yagl_display *dpy,
yagl_host_handle host_config,
Pixmap x_pixmap,
const EGLint* attrib_list);
struct yagl_onscreen_surface
*yagl_onscreen_surface_create_pbuffer(struct yagl_display *dpy,
yagl_host_handle host_config,
const EGLint* attrib_list);
#endif
|