1 /**************************************************************************
3 * Copyright 2010 VMware, Inc.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 **************************************************************************/
29 #include "pipe/p_screen.h"
30 #include "pipe/p_state.h"
31 #include "util/u_memory.h"
32 #include "util/u_debug.h"
33 #include "util/simple_list.h"
35 #include "rbug_public.h"
36 #include "rbug_screen.h"
37 #include "rbug_context.h"
38 #include "rbug_objects.h"
40 DEBUG_GET_ONCE_BOOL_OPTION(rbug
, "GALLIUM_RBUG", false)
43 rbug_screen_destroy(struct pipe_screen
*_screen
)
45 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
46 struct pipe_screen
*screen
= rb_screen
->screen
;
48 screen
->destroy(screen
);
54 rbug_screen_get_name(struct pipe_screen
*_screen
)
56 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
57 struct pipe_screen
*screen
= rb_screen
->screen
;
59 return screen
->get_name(screen
);
63 rbug_screen_get_vendor(struct pipe_screen
*_screen
)
65 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
66 struct pipe_screen
*screen
= rb_screen
->screen
;
68 return screen
->get_vendor(screen
);
72 rbug_screen_get_device_vendor(struct pipe_screen
*_screen
)
74 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
75 struct pipe_screen
*screen
= rb_screen
->screen
;
77 return screen
->get_device_vendor(screen
);
80 static struct disk_cache
*
81 rbug_screen_get_disk_shader_cache(struct pipe_screen
*_screen
)
83 struct pipe_screen
*screen
= rbug_screen(_screen
)->screen
;
85 return screen
->get_disk_shader_cache(screen
);
89 rbug_screen_get_param(struct pipe_screen
*_screen
,
92 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
93 struct pipe_screen
*screen
= rb_screen
->screen
;
95 return screen
->get_param(screen
,
100 rbug_screen_get_shader_param(struct pipe_screen
*_screen
,
101 enum pipe_shader_type shader
,
102 enum pipe_shader_cap param
)
104 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
105 struct pipe_screen
*screen
= rb_screen
->screen
;
107 return screen
->get_shader_param(screen
, shader
,
112 rbug_screen_get_paramf(struct pipe_screen
*_screen
,
113 enum pipe_capf param
)
115 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
116 struct pipe_screen
*screen
= rb_screen
->screen
;
118 return screen
->get_paramf(screen
,
123 rbug_screen_is_format_supported(struct pipe_screen
*_screen
,
124 enum pipe_format format
,
125 enum pipe_texture_target target
,
126 unsigned sample_count
,
127 unsigned storage_sample_count
,
130 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
131 struct pipe_screen
*screen
= rb_screen
->screen
;
133 return screen
->is_format_supported(screen
,
137 storage_sample_count
,
142 rbug_screen_query_dmabuf_modifiers(struct pipe_screen
*_screen
,
143 enum pipe_format format
, int max
,
145 unsigned int *external_only
, int *count
)
147 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
148 struct pipe_screen
*screen
= rb_screen
->screen
;
150 screen
->query_dmabuf_modifiers(screen
,
158 static struct pipe_context
*
159 rbug_screen_context_create(struct pipe_screen
*_screen
,
160 void *priv
, unsigned flags
)
162 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
163 struct pipe_screen
*screen
= rb_screen
->screen
;
164 struct pipe_context
*result
;
166 result
= screen
->context_create(screen
, priv
, flags
);
168 return rbug_context_create(_screen
, result
);
173 rbug_screen_can_create_resource(struct pipe_screen
*_screen
,
174 const struct pipe_resource
*templat
)
176 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
177 struct pipe_screen
*screen
= rb_screen
->screen
;
179 return screen
->can_create_resource(screen
,
183 static struct pipe_resource
*
184 rbug_screen_resource_create(struct pipe_screen
*_screen
,
185 const struct pipe_resource
*templat
)
187 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
188 struct pipe_screen
*screen
= rb_screen
->screen
;
189 struct pipe_resource
*result
;
191 result
= screen
->resource_create(screen
,
195 return rbug_resource_create(rb_screen
, result
);
199 static struct pipe_resource
*
200 rbug_screen_resource_create_with_modifiers(struct pipe_screen
*_screen
,
201 const struct pipe_resource
*templat
,
202 const uint64_t *modifiers
, int count
)
204 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
205 struct pipe_screen
*screen
= rb_screen
->screen
;
206 struct pipe_resource
*result
;
208 result
= screen
->resource_create_with_modifiers(screen
,
214 return rbug_resource_create(rb_screen
, result
);
218 static struct pipe_resource
*
219 rbug_screen_resource_from_handle(struct pipe_screen
*_screen
,
220 const struct pipe_resource
*templ
,
221 struct winsys_handle
*handle
,
224 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
225 struct pipe_screen
*screen
= rb_screen
->screen
;
226 struct pipe_resource
*result
;
228 result
= screen
->resource_from_handle(screen
, templ
, handle
, usage
);
230 result
= rbug_resource_create(rbug_screen(_screen
), result
);
236 rbug_screen_check_resource_capability(struct pipe_screen
*_screen
,
237 struct pipe_resource
*_resource
,
240 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
241 struct rbug_resource
*rb_resource
= rbug_resource(_resource
);
242 struct pipe_screen
*screen
= rb_screen
->screen
;
243 struct pipe_resource
*resource
= rb_resource
->resource
;
245 return screen
->check_resource_capability(screen
, resource
, bind
);
249 rbug_screen_resource_get_handle(struct pipe_screen
*_screen
,
250 struct pipe_context
*_pipe
,
251 struct pipe_resource
*_resource
,
252 struct winsys_handle
*handle
,
255 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
256 struct rbug_context
*rb_pipe
= rbug_context(_pipe
);
257 struct rbug_resource
*rb_resource
= rbug_resource(_resource
);
258 struct pipe_screen
*screen
= rb_screen
->screen
;
259 struct pipe_resource
*resource
= rb_resource
->resource
;
261 return screen
->resource_get_handle(screen
, rb_pipe
? rb_pipe
->pipe
: NULL
,
262 resource
, handle
, usage
);
266 rbug_screen_resource_get_param(struct pipe_screen
*_screen
,
267 struct pipe_context
*_pipe
,
268 struct pipe_resource
*_resource
,
271 enum pipe_resource_param param
,
272 unsigned handle_usage
,
275 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
276 struct rbug_context
*rb_pipe
= rbug_context(_pipe
);
277 struct rbug_resource
*rb_resource
= rbug_resource(_resource
);
278 struct pipe_screen
*screen
= rb_screen
->screen
;
279 struct pipe_resource
*resource
= rb_resource
->resource
;
281 return screen
->resource_get_param(screen
, rb_pipe
? rb_pipe
->pipe
: NULL
,
282 resource
, plane
, layer
, param
,
283 handle_usage
, value
);
288 rbug_screen_resource_get_info(struct pipe_screen
*_screen
,
289 struct pipe_resource
*_resource
,
293 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
294 struct rbug_resource
*rb_resource
= rbug_resource(_resource
);
295 struct pipe_screen
*screen
= rb_screen
->screen
;
296 struct pipe_resource
*resource
= rb_resource
->resource
;
298 screen
->resource_get_info(screen
, resource
, stride
, offset
);
302 rbug_screen_resource_changed(struct pipe_screen
*_screen
,
303 struct pipe_resource
*_resource
)
305 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
306 struct rbug_resource
*rb_resource
= rbug_resource(_resource
);
307 struct pipe_screen
*screen
= rb_screen
->screen
;
308 struct pipe_resource
*resource
= rb_resource
->resource
;
310 screen
->resource_changed(screen
, resource
);
314 rbug_screen_resource_destroy(struct pipe_screen
*screen
,
315 struct pipe_resource
*_resource
)
317 rbug_resource_destroy(rbug_resource(_resource
));
321 rbug_screen_flush_frontbuffer(struct pipe_screen
*_screen
,
322 struct pipe_resource
*_resource
,
323 unsigned level
, unsigned layer
,
324 void *context_private
, struct pipe_box
*sub_box
)
326 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
327 struct rbug_resource
*rb_resource
= rbug_resource(_resource
);
328 struct pipe_screen
*screen
= rb_screen
->screen
;
329 struct pipe_resource
*resource
= rb_resource
->resource
;
331 screen
->flush_frontbuffer(screen
,
334 context_private
, sub_box
);
338 rbug_screen_fence_reference(struct pipe_screen
*_screen
,
339 struct pipe_fence_handle
**ptr
,
340 struct pipe_fence_handle
*fence
)
342 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
343 struct pipe_screen
*screen
= rb_screen
->screen
;
345 screen
->fence_reference(screen
,
351 rbug_screen_fence_finish(struct pipe_screen
*_screen
,
352 struct pipe_context
*_ctx
,
353 struct pipe_fence_handle
*fence
,
356 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
357 struct pipe_screen
*screen
= rb_screen
->screen
;
358 struct pipe_context
*ctx
= _ctx
? rbug_context(_ctx
)->pipe
: NULL
;
360 return screen
->fence_finish(screen
, ctx
, fence
, timeout
);
364 rbug_screen_fence_get_fd(struct pipe_screen
*_screen
,
365 struct pipe_fence_handle
*fence
)
367 struct rbug_screen
*rb_screen
= rbug_screen(_screen
);
368 struct pipe_screen
*screen
= rb_screen
->screen
;
370 return screen
->fence_get_fd(screen
, fence
);
374 rbug_screen_finalize_nir(struct pipe_screen
*_screen
, void *nir
, bool optimize
)
376 struct pipe_screen
*screen
= rbug_screen(_screen
)->screen
;
378 screen
->finalize_nir(screen
, nir
, optimize
);
384 return debug_get_option_rbug();
388 rbug_screen_create(struct pipe_screen
*screen
)
390 struct rbug_screen
*rb_screen
;
392 if (!debug_get_option_rbug())
395 rb_screen
= CALLOC_STRUCT(rbug_screen
);
399 (void) mtx_init(&rb_screen
->list_mutex
, mtx_plain
);
400 make_empty_list(&rb_screen
->contexts
);
401 make_empty_list(&rb_screen
->resources
);
402 make_empty_list(&rb_screen
->surfaces
);
403 make_empty_list(&rb_screen
->transfers
);
405 #define SCR_INIT(_member) \
406 rb_screen->base._member = screen->_member ? rbug_screen_##_member : NULL
408 rb_screen
->base
.destroy
= rbug_screen_destroy
;
409 rb_screen
->base
.get_name
= rbug_screen_get_name
;
410 rb_screen
->base
.get_vendor
= rbug_screen_get_vendor
;
411 SCR_INIT(get_disk_shader_cache
);
412 rb_screen
->base
.get_device_vendor
= rbug_screen_get_device_vendor
;
413 rb_screen
->base
.get_param
= rbug_screen_get_param
;
414 rb_screen
->base
.get_shader_param
= rbug_screen_get_shader_param
;
415 rb_screen
->base
.get_paramf
= rbug_screen_get_paramf
;
416 rb_screen
->base
.is_format_supported
= rbug_screen_is_format_supported
;
417 SCR_INIT(query_dmabuf_modifiers
);
418 rb_screen
->base
.context_create
= rbug_screen_context_create
;
419 SCR_INIT(can_create_resource
);
420 rb_screen
->base
.resource_create
= rbug_screen_resource_create
;
421 SCR_INIT(resource_create_with_modifiers
);
422 rb_screen
->base
.resource_from_handle
= rbug_screen_resource_from_handle
;
423 SCR_INIT(check_resource_capability
);
424 rb_screen
->base
.resource_get_handle
= rbug_screen_resource_get_handle
;
425 SCR_INIT(resource_get_param
);
426 SCR_INIT(resource_get_info
);
427 SCR_INIT(resource_changed
);
428 rb_screen
->base
.resource_destroy
= rbug_screen_resource_destroy
;
429 rb_screen
->base
.flush_frontbuffer
= rbug_screen_flush_frontbuffer
;
430 rb_screen
->base
.fence_reference
= rbug_screen_fence_reference
;
431 rb_screen
->base
.fence_finish
= rbug_screen_fence_finish
;
432 rb_screen
->base
.fence_get_fd
= rbug_screen_fence_get_fd
;
433 SCR_INIT(finalize_nir
);
435 rb_screen
->screen
= screen
;
437 rb_screen
->private_context
= screen
->context_create(screen
, NULL
, 0);
438 if (!rb_screen
->private_context
)
441 rb_screen
->rbug
= rbug_start(rb_screen
);
443 if (!rb_screen
->rbug
)
446 return &rb_screen
->base
;
449 rb_screen
->private_context
->destroy(rb_screen
->private_context
);