2 #include "state_tracker/drm_driver.h"
3 #include "i915_drm_winsys.h"
4 #include "util/u_memory.h"
8 static struct i915_winsys_buffer
*
9 i915_drm_buffer_create(struct i915_winsys
*iws
,
10 unsigned size
, unsigned alignment
,
11 enum i915_winsys_buffer_type type
)
13 struct i915_drm_buffer
*buf
= CALLOC_STRUCT(i915_drm_buffer
);
14 struct i915_drm_winsys
*idws
= i915_drm_winsys(iws
);
15 drm_intel_bufmgr
*pool
;
21 buf
->magic
= 0xDEAD1337;
25 if (type
== I915_NEW_TEXTURE
) {
26 name
= "gallium3d_texture";
27 pool
= idws
->pools
.gem
;
28 } else if (type
== I915_NEW_VERTEX
) {
29 name
= "gallium3d_vertex";
30 pool
= idws
->pools
.gem
;
31 } else if (type
== I915_NEW_SCANOUT
) {
32 name
= "gallium3d_scanout";
33 pool
= idws
->pools
.gem
;
36 name
= "gallium3d_unknown";
37 pool
= idws
->pools
.gem
;
40 buf
->bo
= drm_intel_bo_alloc(pool
, name
, size
, alignment
);
45 return (struct i915_winsys_buffer
*)buf
;
53 static struct i915_winsys_buffer
*
54 i915_drm_buffer_from_handle(struct i915_winsys
*iws
,
55 struct winsys_handle
*whandle
,
58 struct i915_drm_winsys
*idws
= i915_drm_winsys(iws
);
59 struct i915_drm_buffer
*buf
= CALLOC_STRUCT(i915_drm_buffer
);
60 uint32_t tile
= 0, swizzle
= 0;
65 buf
->magic
= 0xDEAD1337;
66 buf
->bo
= drm_intel_bo_gem_create_from_name(idws
->pools
.gem
, "gallium3d_from_handle", whandle
->handle
);
68 buf
->flink
= whandle
->handle
;
73 drm_intel_bo_get_tiling(buf
->bo
, &tile
, &swizzle
);
75 *stride
= whandle
->stride
;
77 return (struct i915_winsys_buffer
*)buf
;
85 i915_drm_buffer_get_handle(struct i915_winsys
*iws
,
86 struct i915_winsys_buffer
*buffer
,
87 struct winsys_handle
*whandle
,
90 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
92 if (whandle
->type
== DRM_API_HANDLE_TYPE_SHARED
) {
94 if (drm_intel_bo_flink(buf
->bo
, &buf
->flink
))
99 whandle
->handle
= buf
->flink
;
100 } else if (whandle
->type
== DRM_API_HANDLE_TYPE_KMS
) {
101 whandle
->handle
= buf
->bo
->handle
;
103 assert(!"unknown usage");
107 whandle
->stride
= stride
;
112 i915_drm_buffer_set_fence_reg(struct i915_winsys
*iws
,
113 struct i915_winsys_buffer
*buffer
,
115 enum i915_winsys_buffer_tile tile
)
117 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
118 assert(I915_TILING_NONE
== I915_TILE_NONE
);
119 assert(I915_TILING_X
== I915_TILE_X
);
120 assert(I915_TILING_Y
== I915_TILE_Y
);
122 if (tile
!= I915_TILE_NONE
) {
123 assert(buf
->map_count
== 0);
126 return drm_intel_bo_set_tiling(buf
->bo
, &tile
, stride
);
130 i915_drm_buffer_map(struct i915_winsys
*iws
,
131 struct i915_winsys_buffer
*buffer
,
134 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
135 drm_intel_bo
*bo
= intel_bo(buffer
);
143 ret
= drm_intel_gem_bo_map_gtt(bo
);
145 buf
->ptr
= bo
->virtual;
157 i915_drm_buffer_unmap(struct i915_winsys
*iws
,
158 struct i915_winsys_buffer
*buffer
)
160 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
162 if (--buf
->map_count
)
165 drm_intel_gem_bo_unmap_gtt(intel_bo(buffer
));
169 i915_drm_buffer_write(struct i915_winsys
*iws
,
170 struct i915_winsys_buffer
*buffer
,
175 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
177 return drm_intel_bo_subdata(buf
->bo
, offset
, size
, (void*)data
);
181 i915_drm_buffer_destroy(struct i915_winsys
*iws
,
182 struct i915_winsys_buffer
*buffer
)
184 drm_intel_bo_unreference(intel_bo(buffer
));
187 i915_drm_buffer(buffer
)->magic
= 0;
188 i915_drm_buffer(buffer
)->bo
= NULL
;
195 i915_drm_winsys_init_buffer_functions(struct i915_drm_winsys
*idws
)
197 idws
->base
.buffer_create
= i915_drm_buffer_create
;
198 idws
->base
.buffer_from_handle
= i915_drm_buffer_from_handle
;
199 idws
->base
.buffer_get_handle
= i915_drm_buffer_get_handle
;
200 idws
->base
.buffer_set_fence_reg
= i915_drm_buffer_set_fence_reg
;
201 idws
->base
.buffer_map
= i915_drm_buffer_map
;
202 idws
->base
.buffer_unmap
= i915_drm_buffer_unmap
;
203 idws
->base
.buffer_write
= i915_drm_buffer_write
;
204 idws
->base
.buffer_destroy
= i915_drm_buffer_destroy
;