mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2025-12-25 02:10:11 +01:00
gallium: add pipe_screen::resource_changed callback wrappers
Add resource_changed to the ddebug, rbug, and trace wrappers. Since it is optional, there is no need to add it to noop. Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de> Suggested-by: Nicolai Hähnle <nhaehnle@gmail.com> Reviewed-by: Marek Olšák <marek.olsak@amd.com> Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
This commit is contained in:
parent
97de7e6586
commit
a37cf630b4
3 changed files with 47 additions and 0 deletions
|
|
@ -226,6 +226,15 @@ dd_screen_resource_from_user_memory(struct pipe_screen *_screen,
|
|||
return res;
|
||||
}
|
||||
|
||||
static void
|
||||
dd_screen_resource_changed(struct pipe_screen *_screen,
|
||||
struct pipe_resource *res)
|
||||
{
|
||||
struct pipe_screen *screen = dd_screen(_screen)->screen;
|
||||
|
||||
screen->resource_changed(screen, res);
|
||||
}
|
||||
|
||||
static void
|
||||
dd_screen_resource_destroy(struct pipe_screen *_screen,
|
||||
struct pipe_resource *res)
|
||||
|
|
@ -385,6 +394,7 @@ ddebug_screen_create(struct pipe_screen *screen)
|
|||
dscreen->base.resource_from_handle = dd_screen_resource_from_handle;
|
||||
SCR_INIT(resource_from_user_memory);
|
||||
dscreen->base.resource_get_handle = dd_screen_resource_get_handle;
|
||||
SCR_INIT(resource_changed);
|
||||
dscreen->base.resource_destroy = dd_screen_resource_destroy;
|
||||
SCR_INIT(flush_frontbuffer);
|
||||
SCR_INIT(fence_reference);
|
||||
|
|
|
|||
|
|
@ -191,7 +191,17 @@ rbug_screen_resource_get_handle(struct pipe_screen *_screen,
|
|||
resource, handle, usage);
|
||||
}
|
||||
|
||||
static void
|
||||
rbug_screen_resource_changed(struct pipe_screen *_screen,
|
||||
struct pipe_resource *_resource)
|
||||
{
|
||||
struct rbug_screen *rb_screen = rbug_screen(_screen);
|
||||
struct rbug_resource *rb_resource = rbug_resource(_resource);
|
||||
struct pipe_screen *screen = rb_screen->screen;
|
||||
struct pipe_resource *resource = rb_resource->resource;
|
||||
|
||||
screen->resource_changed(screen, resource);
|
||||
}
|
||||
|
||||
static void
|
||||
rbug_screen_resource_destroy(struct pipe_screen *screen,
|
||||
|
|
@ -267,6 +277,9 @@ rbug_screen_create(struct pipe_screen *screen)
|
|||
make_empty_list(&rb_screen->surfaces);
|
||||
make_empty_list(&rb_screen->transfers);
|
||||
|
||||
#define SCR_INIT(_member) \
|
||||
rb_screen->base._member = screen->_member ? rbug_screen_##_member : NULL
|
||||
|
||||
rb_screen->base.destroy = rbug_screen_destroy;
|
||||
rb_screen->base.get_name = rbug_screen_get_name;
|
||||
rb_screen->base.get_vendor = rbug_screen_get_vendor;
|
||||
|
|
@ -279,6 +292,7 @@ rbug_screen_create(struct pipe_screen *screen)
|
|||
rb_screen->base.resource_create = rbug_screen_resource_create;
|
||||
rb_screen->base.resource_from_handle = rbug_screen_resource_from_handle;
|
||||
rb_screen->base.resource_get_handle = rbug_screen_resource_get_handle;
|
||||
SCR_INIT(resource_changed);
|
||||
rb_screen->base.resource_destroy = rbug_screen_resource_destroy;
|
||||
rb_screen->base.flush_frontbuffer = rbug_screen_flush_frontbuffer;
|
||||
rb_screen->base.fence_reference = rbug_screen_fence_reference;
|
||||
|
|
|
|||
|
|
@ -350,7 +350,26 @@ trace_screen_resource_get_handle(struct pipe_screen *_screen,
|
|||
resource, handle, usage);
|
||||
}
|
||||
|
||||
static void
|
||||
trace_screen_resource_changed(struct pipe_screen *_screen,
|
||||
struct pipe_resource *_resource)
|
||||
{
|
||||
struct trace_screen *tr_scr = trace_screen(_screen);
|
||||
struct trace_resource *tr_res = trace_resource(_resource);
|
||||
struct pipe_screen *screen = tr_scr->screen;
|
||||
struct pipe_resource *resource = tr_res->resource;
|
||||
|
||||
assert(resource->screen == screen);
|
||||
|
||||
trace_dump_call_begin("pipe_screen", "resource_changed");
|
||||
|
||||
trace_dump_arg(ptr, screen);
|
||||
trace_dump_arg(ptr, resource);
|
||||
|
||||
screen->resource_changed(screen, resource);
|
||||
|
||||
trace_dump_call_end();
|
||||
}
|
||||
|
||||
static void
|
||||
trace_screen_resource_destroy(struct pipe_screen *_screen,
|
||||
|
|
@ -499,6 +518,9 @@ trace_screen_create(struct pipe_screen *screen)
|
|||
if (!tr_scr)
|
||||
goto error2;
|
||||
|
||||
#define SCR_INIT(_member) \
|
||||
tr_scr->base._member = screen->_member ? trace_screen_##_member : NULL
|
||||
|
||||
tr_scr->base.destroy = trace_screen_destroy;
|
||||
tr_scr->base.get_name = trace_screen_get_name;
|
||||
tr_scr->base.get_vendor = trace_screen_get_vendor;
|
||||
|
|
@ -513,6 +535,7 @@ trace_screen_create(struct pipe_screen *screen)
|
|||
tr_scr->base.resource_create = trace_screen_resource_create;
|
||||
tr_scr->base.resource_from_handle = trace_screen_resource_from_handle;
|
||||
tr_scr->base.resource_get_handle = trace_screen_resource_get_handle;
|
||||
SCR_INIT(resource_changed);
|
||||
tr_scr->base.resource_destroy = trace_screen_resource_destroy;
|
||||
tr_scr->base.fence_reference = trace_screen_fence_reference;
|
||||
tr_scr->base.fence_finish = trace_screen_fence_finish;
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue