blob: 96e94c47e712e4bfa875a121c03e1544bd7a6f75 (
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
|
#ifndef INTEL_DRM_DEVICE_H
#define INTEL_DRM_DEVICE_H
#include "pipe/p_winsys.h"
#include "pipe/p_context.h"
#include "drm.h"
#include "intel_bufmgr.h"
/*
* Device
*/
struct intel_be_device
{
struct pipe_winsys base;
int fd; /**< Drm file discriptor */
size_t max_batch_size;
size_t max_vertex_size;
struct {
drm_intel_bufmgr *gem;
} pools;
};
boolean
intel_be_init_device(struct intel_be_device *device, int fd, unsigned id);
void
intel_be_destroy_device(struct intel_be_device *dev);
/*
* Buffer
*/
struct intel_be_buffer {
struct pipe_buffer base;
drm_intel_bo *bo;
};
/**
* Create a be buffer from a drm bo handle.
*
* Takes a reference.
*/
struct pipe_buffer *
intel_be_buffer_from_handle(struct pipe_winsys *winsys,
const char* name, unsigned handle);
/**
* Gets a handle from a buffer.
*
* If buffer is destroyed handle may become invalid.
*/
unsigned
intel_be_handle_from_buffer(struct pipe_winsys *winsys,
struct pipe_buffer *buffer);
static INLINE struct intel_be_buffer *
intel_be_buffer(struct pipe_buffer *buf)
{
return (struct intel_be_buffer *)buf;
}
static INLINE drm_intel_bo *
intel_bo(struct pipe_buffer *buf)
{
return intel_be_buffer(buf)->bo;
}
#endif
|