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
);
20 buf
->magic
= 0xDEAD1337;
24 if (type
== I915_NEW_TEXTURE
) {
25 name
= "gallium3d_texture";
26 } else if (type
== I915_NEW_VERTEX
) {
27 name
= "gallium3d_vertex";
28 } else if (type
== I915_NEW_SCANOUT
) {
29 name
= "gallium3d_scanout";
32 name
= "gallium3d_unknown";
35 buf
->bo
= drm_intel_bo_alloc(idws
->gem_manager
, name
, size
, alignment
);
40 return (struct i915_winsys_buffer
*)buf
;
48 static struct i915_winsys_buffer
*
49 i915_drm_buffer_from_handle(struct i915_winsys
*iws
,
50 struct winsys_handle
*whandle
,
53 struct i915_drm_winsys
*idws
= i915_drm_winsys(iws
);
54 struct i915_drm_buffer
*buf
= CALLOC_STRUCT(i915_drm_buffer
);
55 uint32_t tile
= 0, swizzle
= 0;
60 buf
->magic
= 0xDEAD1337;
61 buf
->bo
= drm_intel_bo_gem_create_from_name(idws
->gem_manager
, "gallium3d_from_handle", whandle
->handle
);
63 buf
->flink
= whandle
->handle
;
68 drm_intel_bo_get_tiling(buf
->bo
, &tile
, &swizzle
);
70 *stride
= whandle
->stride
;
72 return (struct i915_winsys_buffer
*)buf
;
80 i915_drm_buffer_get_handle(struct i915_winsys
*iws
,
81 struct i915_winsys_buffer
*buffer
,
82 struct winsys_handle
*whandle
,
85 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
87 if (whandle
->type
== DRM_API_HANDLE_TYPE_SHARED
) {
89 if (drm_intel_bo_flink(buf
->bo
, &buf
->flink
))
94 whandle
->handle
= buf
->flink
;
95 } else if (whandle
->type
== DRM_API_HANDLE_TYPE_KMS
) {
96 whandle
->handle
= buf
->bo
->handle
;
98 assert(!"unknown usage");
102 whandle
->stride
= stride
;
107 i915_drm_buffer_set_fence_reg(struct i915_winsys
*iws
,
108 struct i915_winsys_buffer
*buffer
,
110 enum i915_winsys_buffer_tile tile
)
112 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
113 assert(I915_TILING_NONE
== I915_TILE_NONE
);
114 assert(I915_TILING_X
== I915_TILE_X
);
115 assert(I915_TILING_Y
== I915_TILE_Y
);
117 if (tile
!= I915_TILE_NONE
) {
118 assert(buf
->map_count
== 0);
121 return drm_intel_bo_set_tiling(buf
->bo
, &tile
, stride
);
125 i915_drm_buffer_map(struct i915_winsys
*iws
,
126 struct i915_winsys_buffer
*buffer
,
129 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
130 drm_intel_bo
*bo
= intel_bo(buffer
);
138 ret
= drm_intel_gem_bo_map_gtt(bo
);
140 buf
->ptr
= bo
->virtual;
152 i915_drm_buffer_unmap(struct i915_winsys
*iws
,
153 struct i915_winsys_buffer
*buffer
)
155 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
157 if (--buf
->map_count
)
160 drm_intel_gem_bo_unmap_gtt(intel_bo(buffer
));
164 i915_drm_buffer_write(struct i915_winsys
*iws
,
165 struct i915_winsys_buffer
*buffer
,
170 struct i915_drm_buffer
*buf
= i915_drm_buffer(buffer
);
172 return drm_intel_bo_subdata(buf
->bo
, offset
, size
, (void*)data
);
176 i915_drm_buffer_destroy(struct i915_winsys
*iws
,
177 struct i915_winsys_buffer
*buffer
)
179 drm_intel_bo_unreference(intel_bo(buffer
));
182 i915_drm_buffer(buffer
)->magic
= 0;
183 i915_drm_buffer(buffer
)->bo
= NULL
;
190 i915_drm_winsys_init_buffer_functions(struct i915_drm_winsys
*idws
)
192 idws
->base
.buffer_create
= i915_drm_buffer_create
;
193 idws
->base
.buffer_from_handle
= i915_drm_buffer_from_handle
;
194 idws
->base
.buffer_get_handle
= i915_drm_buffer_get_handle
;
195 idws
->base
.buffer_set_fence_reg
= i915_drm_buffer_set_fence_reg
;
196 idws
->base
.buffer_map
= i915_drm_buffer_map
;
197 idws
->base
.buffer_unmap
= i915_drm_buffer_unmap
;
198 idws
->base
.buffer_write
= i915_drm_buffer_write
;
199 idws
->base
.buffer_destroy
= i915_drm_buffer_destroy
;