renderonly: remove layering violations

The renderonly object is something the winsys creates, so the pipe
driver has no business in memcpying or freeing it. Move those bits
to the winsys.

Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
Reviewed-by: Guido Günther <agx@sigxcpu.org>
Reviewed-by: Eric Anholt <eric@anholt.net>
Reviewed-by: Christian Gmeiner <christian.gmeiner@gmail.com>
Reviewed-by: Alyssa Rosenzweig <alyssa@collabora.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/6983>
This commit is contained in:
Lucas Stach 2019-01-28 20:22:57 +01:00 committed by Marge Bot
parent 5487847d8c
commit 187218395d
10 changed files with 91 additions and 108 deletions

View file

@ -37,20 +37,6 @@
#include "util/u_inlines.h"
#include "util/u_memory.h"
struct renderonly *
renderonly_dup(const struct renderonly *ro)
{
struct renderonly *copy;
copy = CALLOC_STRUCT(renderonly);
if (!copy)
return NULL;
memcpy(copy, ro, sizeof(*ro));
return copy;
}
void
renderonly_scanout_destroy(struct renderonly_scanout *scanout,
struct renderonly *ro)

View file

@ -59,13 +59,11 @@ struct renderonly {
struct renderonly_scanout *(*create_for_resource)(struct pipe_resource *rsc,
struct renderonly *ro,
struct winsys_handle *out_handle);
void (*destroy)(struct renderonly *ro);
int kms_fd;
int gpu_fd;
};
struct renderonly *
renderonly_dup(const struct renderonly *ro);
static inline struct renderonly_scanout *
renderonly_scanout_for_resource(struct pipe_resource *rsc,
struct renderonly *ro,

View file

@ -99,7 +99,7 @@ etna_screen_destroy(struct pipe_screen *pscreen)
etna_gpu_del(screen->gpu);
if (screen->ro)
FREE(screen->ro);
screen->ro->destroy(screen->ro);
if (screen->dev)
etna_device_del(screen->dev);
@ -939,7 +939,7 @@ etna_screen_create(struct etna_device *dev, struct etna_gpu *gpu,
pscreen = &screen->base;
screen->dev = dev;
screen->gpu = gpu;
screen->ro = renderonly_dup(ro);
screen->ro = ro;
screen->refcnt = 1;
if (!screen->ro) {

View file

@ -153,7 +153,7 @@ fd_screen_destroy(struct pipe_screen *pscreen)
fd_device_del(screen->dev);
if (screen->ro)
FREE(screen->ro);
screen->ro->destroy(screen->ro);
fd_bc_fini(&screen->batch_cache);
fd_gmem_screen_fini(pscreen);
@ -903,16 +903,9 @@ fd_screen_create(struct fd_device *dev, struct renderonly *ro)
pscreen = &screen->base;
screen->dev = dev;
screen->ro = ro;
screen->refcnt = 1;
if (ro) {
screen->ro = renderonly_dup(ro);
if (!screen->ro) {
DBG("could not create renderonly object");
goto fail;
}
}
// maybe this should be in context?
screen->pipe = fd_pipe_new(screen->dev, FD_PIPE_3D);
if (!screen->pipe) {

View file

@ -54,7 +54,7 @@ lima_screen_destroy(struct pipe_screen *pscreen)
slab_destroy_parent(&screen->transfer_pool);
if (screen->ro)
free(screen->ro);
screen->ro->destroy(screen->ro);
if (screen->pp_buffer)
lima_bo_unreference(screen->pp_buffer);
@ -621,6 +621,7 @@ lima_screen_create(int fd, struct renderonly *ro)
return NULL;
screen->fd = fd;
screen->ro = ro;
lima_screen_parse_env();
@ -692,14 +693,6 @@ lima_screen_create(int fd, struct renderonly *ro)
pp_frame_rsw[9] = screen->pp_buffer->va + pp_clear_program_offset;
pp_frame_rsw[13] = 0x00000100;
if (ro) {
screen->ro = renderonly_dup(ro);
if (!screen->ro) {
fprintf(stderr, "Failed to dup renderonly object\n");
goto err_out3;
}
}
screen->base.destroy = lima_screen_destroy;
screen->base.get_name = lima_screen_get_name;
screen->base.get_vendor = lima_screen_get_vendor;
@ -722,8 +715,6 @@ lima_screen_create(int fd, struct renderonly *ro)
return &screen->base;
err_out3:
lima_bo_unreference(screen->pp_buffer);
err_out2:
lima_bo_table_fini(screen);
err_out1:

View file

@ -683,7 +683,11 @@ panfrost_get_compute_param(struct pipe_screen *pscreen, enum pipe_shader_ir ir_t
static void
panfrost_destroy_screen(struct pipe_screen *pscreen)
{
panfrost_close_device(pan_device(pscreen));
struct panfrost_device *dev = pan_device(pscreen);
if (dev->ro)
dev->ro->destroy(dev->ro);
panfrost_close_device(dev);
ralloc_free(pscreen);
}
@ -810,16 +814,7 @@ panfrost_create_screen(int fd, struct renderonly *ro)
if (dev->debug & PAN_DBG_NO_AFBC)
dev->quirks |= MIDGARD_NO_AFBC;
if (ro) {
dev->ro = renderonly_dup(ro);
if (!dev->ro) {
if (dev->debug & PAN_DBG_MSGS)
fprintf(stderr, "Failed to dup renderonly object\n");
free(screen);
return NULL;
}
}
dev->ro = ro;
/* Check if we're loading against a supported GPU model. */

View file

@ -76,7 +76,8 @@ v3d_screen_destroy(struct pipe_screen *pscreen)
_mesa_hash_table_destroy(screen->bo_handles, NULL);
v3d_bufmgr_destroy(pscreen);
slab_destroy_parent(&screen->transfer_pool);
free(screen->ro);
if (screen->ro)
screen->ro->destroy(screen->ro);
if (using_v3d_simulator)
v3d_simulator_destroy(screen->sim_file);
@ -699,14 +700,8 @@ v3d_screen_create(int fd, const struct pipe_screen_config *config,
pscreen->is_format_supported = v3d_screen_is_format_supported;
screen->fd = fd;
if (ro) {
screen->ro = renderonly_dup(ro);
if (!screen->ro) {
fprintf(stderr, "Failed to dup renderonly object\n");
ralloc_free(screen);
return NULL;
}
}
screen->ro = ro;
list_inithead(&screen->bo_cache.time_list);
(void)mtx_init(&screen->bo_handles_mutex, mtx_plain);
screen->bo_handles = util_hash_table_create_ptr_keys();

View file

@ -105,7 +105,7 @@ vc4_screen_destroy(struct pipe_screen *pscreen)
_mesa_hash_table_destroy(screen->bo_handles, NULL);
vc4_bufmgr_destroy(pscreen);
slab_destroy_parent(&screen->transfer_pool);
free(screen->ro);
screen->ro->destroy(screen->ro);
#ifdef USE_VC4_SIMULATOR
vc4_simulator_destroy(screen);
@ -552,14 +552,7 @@ vc4_screen_create(int fd, struct renderonly *ro)
pscreen->is_format_supported = vc4_screen_is_format_supported;
screen->fd = fd;
if (ro) {
screen->ro = renderonly_dup(ro);
if (!screen->ro) {
fprintf(stderr, "Failed to dup renderonly object\n");
ralloc_free(screen);
return NULL;
}
}
screen->ro = ro;
list_inithead(&screen->bo_cache.time_list);
(void) mtx_init(&screen->bo_handles_mutex, mtx_plain);

View file

@ -185,14 +185,29 @@ unlock:
return pscreen;
}
static void etnaviv_ro_destroy(struct renderonly *ro)
{
FREE(ro);
}
struct pipe_screen *
etna_drm_screen_create(int fd)
{
struct renderonly ro = {
.create_for_resource = renderonly_create_gpu_import_for_resource,
.kms_fd = -1,
.gpu_fd = fd
};
return etna_drm_screen_create_renderonly(&ro);
struct renderonly *ro = CALLOC_STRUCT(renderonly);
struct pipe_screen *screen;
if (!ro)
return NULL;
ro->create_for_resource = renderonly_create_gpu_import_for_resource;
ro->destroy = etnaviv_ro_destroy;
ro->kms_fd = -1;
ro->gpu_fd = fd;
screen = etna_drm_screen_create_renderonly(ro);
if (!screen)
FREE(ro);
return screen;
}

View file

@ -36,92 +36,109 @@
#include "pipe/p_screen.h"
#include "renderonly/renderonly.h"
#include "util/u_memory.h"
static void kmsro_ro_destroy(struct renderonly *ro)
{
FREE(ro);
}
struct pipe_screen *kmsro_drm_screen_create(int fd,
const struct pipe_screen_config *config)
{
struct pipe_screen *screen = NULL;
struct renderonly ro = {
.kms_fd = fd,
.gpu_fd = -1,
};
struct renderonly *ro = CALLOC_STRUCT(renderonly);
if (!ro)
return NULL;
ro->kms_fd = fd;
ro->gpu_fd = -1;
ro->destroy = kmsro_ro_destroy;
#if defined(GALLIUM_VC4)
ro.gpu_fd = drmOpenWithType("vc4", NULL, DRM_NODE_RENDER);
if (ro.gpu_fd >= 0) {
ro->gpu_fd = drmOpenWithType("vc4", NULL, DRM_NODE_RENDER);
if (ro->gpu_fd >= 0) {
/* Passes the vc4-allocated BO through to the KMS-only DRM device using
* PRIME buffer sharing. The VC4 BO must be linear, which the SCANOUT
* flag on allocation will have ensured.
*/
ro.create_for_resource = renderonly_create_gpu_import_for_resource,
screen = vc4_drm_screen_create_renderonly(&ro, config);
ro->create_for_resource = renderonly_create_gpu_import_for_resource;
screen = vc4_drm_screen_create_renderonly(ro, config);
if (!screen)
close(ro.gpu_fd);
goto out_free;
return screen;
}
#endif
#if defined(GALLIUM_ETNAVIV)
ro.gpu_fd = drmOpenWithType("etnaviv", NULL, DRM_NODE_RENDER);
if (ro.gpu_fd >= 0) {
ro.create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = etna_drm_screen_create_renderonly(&ro);
ro->gpu_fd = drmOpenWithType("etnaviv", NULL, DRM_NODE_RENDER);
if (ro->gpu_fd >= 0) {
ro->create_for_resource = renderonly_create_kms_dumb_buffer_for_resource;
screen = etna_drm_screen_create_renderonly(ro);
if (!screen)
close(ro.gpu_fd);
goto out_free;
return screen;
}
#endif
#if defined(GALLIUM_FREEDRENO)
ro.gpu_fd = drmOpenWithType("msm", NULL, DRM_NODE_RENDER);
if (ro.gpu_fd >= 0) {
ro.create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = fd_drm_screen_create(ro.gpu_fd, &ro);
ro->gpu_fd = drmOpenWithType("msm", NULL, DRM_NODE_RENDER);
if (ro->gpu_fd >= 0) {
ro->create_for_resource = renderonly_create_kms_dumb_buffer_for_resource;
screen = fd_drm_screen_create(ro->gpu_fd, ro);
if (!screen)
close(ro.gpu_fd);
goto out_free;
return screen;
}
#endif
#if defined(GALLIUM_PANFROST)
ro.gpu_fd = drmOpenWithType("panfrost", NULL, DRM_NODE_RENDER);
ro->gpu_fd = drmOpenWithType("panfrost", NULL, DRM_NODE_RENDER);
if (ro.gpu_fd >= 0) {
ro.create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = panfrost_drm_screen_create_renderonly(&ro);
if (ro->gpu_fd >= 0) {
ro->create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = panfrost_drm_screen_create_renderonly(ro);
if (!screen)
close(ro.gpu_fd);
goto out_free;
return screen;
}
#endif
#if defined(GALLIUM_LIMA)
ro.gpu_fd = drmOpenWithType("lima", NULL, DRM_NODE_RENDER);
if (ro.gpu_fd >= 0) {
ro.create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = lima_drm_screen_create_renderonly(&ro);
ro->gpu_fd = drmOpenWithType("lima", NULL, DRM_NODE_RENDER);
if (ro->gpu_fd >= 0) {
ro->create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = lima_drm_screen_create_renderonly(ro);
if (!screen)
close(ro.gpu_fd);
goto out_free;
return screen;
}
#endif
#if defined(GALLIUM_V3D)
ro.gpu_fd = drmOpenWithType("v3d", NULL, DRM_NODE_RENDER);
if (ro.gpu_fd >= 0) {
ro.create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = v3d_drm_screen_create_renderonly(&ro, config);
ro->gpu_fd = drmOpenWithType("v3d", NULL, DRM_NODE_RENDER);
if (ro->gpu_fd >= 0) {
ro->create_for_resource = renderonly_create_kms_dumb_buffer_for_resource,
screen = v3d_drm_screen_create_renderonly(ro, config);
if (!screen)
close(ro.gpu_fd);
goto out_free;
return screen;
}
#endif
return screen;
out_free:
if (ro->gpu_fd >= 0)
close(ro->gpu_fd);
FREE(ro);
return NULL;
}