aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Zeni <simon@bl4ckb0ne.ca>2021-04-15 14:32:13 -0400
committerSimon Ser <contact@emersion.fr>2021-04-28 20:55:57 +0200
commitc75aa71816826907805606a108626b4671120a7e (patch)
tree471aa3d45646e571555829a88bd506d0cfc09e2a
parent3a04fb4560cf60c34bd968fe711a45d42993e5a4 (diff)
render/gbm_allocator: make wlr_gbm_allocator_create return a wlr_allocator
-rw-r--r--backend/drm/renderer.c6
-rw-r--r--backend/headless/backend.c16
-rw-r--r--backend/wayland/backend.c6
-rw-r--r--backend/x11/backend.c6
-rw-r--r--include/backend/drm/renderer.h2
-rw-r--r--include/render/gbm_allocator.h2
-rw-r--r--render/gbm_allocator.c7
7 files changed, 24 insertions, 21 deletions
diff --git a/backend/drm/renderer.c b/backend/drm/renderer.c
index e1a0e427..00dfcbb0 100644
--- a/backend/drm/renderer.c
+++ b/backend/drm/renderer.c
@@ -62,7 +62,7 @@ void finish_drm_renderer(struct wlr_drm_renderer *renderer) {
return;
}
- wlr_allocator_destroy(&renderer->allocator->base);
+ wlr_allocator_destroy(renderer->allocator);
wlr_renderer_destroy(renderer->wlr_rend);
gbm_device_destroy(renderer->gbm);
}
@@ -83,8 +83,8 @@ static bool init_drm_surface(struct wlr_drm_surface *surf,
wlr_swapchain_destroy(surf->swapchain);
surf->swapchain = NULL;
- surf->swapchain = wlr_swapchain_create(&renderer->allocator->base,
- width, height, drm_format);
+ surf->swapchain = wlr_swapchain_create(renderer->allocator, width, height,
+ drm_format);
if (surf->swapchain == NULL) {
wlr_log(WLR_ERROR, "Failed to create swapchain");
memset(surf, 0, sizeof(*surf));
diff --git a/backend/headless/backend.c b/backend/headless/backend.c
index 822024b3..1ca1c183 100644
--- a/backend/headless/backend.c
+++ b/backend/headless/backend.c
@@ -220,21 +220,21 @@ struct wlr_backend *wlr_headless_backend_create(struct wl_display *display) {
goto error_dup;
}
- struct wlr_gbm_allocator *gbm_alloc = wlr_gbm_allocator_create(drm_fd);
- if (gbm_alloc == NULL) {
+ struct wlr_allocator *alloc = wlr_gbm_allocator_create(drm_fd);
+ if (alloc == NULL) {
wlr_log(WLR_ERROR, "Failed to create GBM allocator");
close(drm_fd);
goto error_dup;
}
- if (!backend_init(backend, display, &gbm_alloc->base, NULL)) {
+ if (!backend_init(backend, display, alloc, NULL)) {
goto error_init;
}
return &backend->backend;
error_init:
- wlr_allocator_destroy(&gbm_alloc->base);
+ wlr_allocator_destroy(alloc);
error_dup:
close(backend->drm_fd);
error_drm_fd:
@@ -266,14 +266,14 @@ struct wlr_backend *wlr_headless_backend_create_with_renderer(
goto error_dup;
}
- struct wlr_gbm_allocator *gbm_alloc = wlr_gbm_allocator_create(drm_fd);
- if (gbm_alloc == NULL) {
+ struct wlr_allocator *alloc = wlr_gbm_allocator_create(drm_fd);
+ if (alloc == NULL) {
wlr_log(WLR_ERROR, "Failed to create GBM allocator");
close(drm_fd);
goto error_dup;
}
- if (!backend_init(backend, display, &gbm_alloc->base, renderer)) {
+ if (!backend_init(backend, display, alloc, renderer)) {
goto error_init;
}
@@ -283,7 +283,7 @@ struct wlr_backend *wlr_headless_backend_create_with_renderer(
return &backend->backend;
error_init:
- wlr_allocator_destroy(&gbm_alloc->base);
+ wlr_allocator_destroy(alloc);
error_dup:
close(backend->drm_fd);
error_drm_fd:
diff --git a/backend/wayland/backend.c b/backend/wayland/backend.c
index 1606f0a5..42f4d6e2 100644
--- a/backend/wayland/backend.c
+++ b/backend/wayland/backend.c
@@ -452,13 +452,13 @@ struct wlr_backend *wlr_wl_backend_create(struct wl_display *display,
goto error_drm_fd;
}
- struct wlr_gbm_allocator *gbm_alloc = wlr_gbm_allocator_create(drm_fd);
- if (gbm_alloc == NULL) {
+ struct wlr_allocator *alloc = wlr_gbm_allocator_create(drm_fd);
+ if (alloc == NULL) {
wlr_log(WLR_ERROR, "Failed to create GBM allocator");
close(drm_fd);
goto error_drm_fd;
}
- wl->allocator = &gbm_alloc->base;
+ wl->allocator = alloc;
} else {
wlr_log(WLR_DEBUG, "No render node found, falling back to shared memory");
struct wlr_shm_allocator *shm_alloc = wlr_shm_allocator_create();
diff --git a/backend/x11/backend.c b/backend/x11/backend.c
index fbcee33d..06bbfc6c 100644
--- a/backend/x11/backend.c
+++ b/backend/x11/backend.c
@@ -622,13 +622,13 @@ struct wlr_backend *wlr_x11_backend_create(struct wl_display *display,
goto error_event;
}
- struct wlr_gbm_allocator *gbm_alloc = wlr_gbm_allocator_create(drm_fd);
- if (gbm_alloc == NULL) {
+ struct wlr_allocator *alloc = wlr_gbm_allocator_create(drm_fd);
+ if (alloc == NULL) {
wlr_log(WLR_ERROR, "Failed to create GBM allocator");
close(drm_fd);
goto error_event;
}
- x11->allocator = &gbm_alloc->base;
+ x11->allocator = alloc;
pixmap_formats = &x11->dri3_formats;
} else if (x11->have_shm) {
x11->drm_fd = -1;
diff --git a/include/backend/drm/renderer.h b/include/backend/drm/renderer.h
index 2abd9dca..089c7923 100644
--- a/include/backend/drm/renderer.h
+++ b/include/backend/drm/renderer.h
@@ -16,7 +16,7 @@ struct wlr_drm_renderer {
struct gbm_device *gbm;
struct wlr_renderer *wlr_rend;
- struct wlr_gbm_allocator *allocator;
+ struct wlr_allocator *allocator;
};
struct wlr_drm_surface {
diff --git a/include/render/gbm_allocator.h b/include/render/gbm_allocator.h
index d8121328..b4f40039 100644
--- a/include/render/gbm_allocator.h
+++ b/include/render/gbm_allocator.h
@@ -28,6 +28,6 @@ struct wlr_gbm_allocator {
*
* Takes ownership over the FD.
*/
-struct wlr_gbm_allocator *wlr_gbm_allocator_create(int drm_fd);
+struct wlr_allocator *wlr_gbm_allocator_create(int drm_fd);
#endif
diff --git a/render/gbm_allocator.c b/render/gbm_allocator.c
index da71cbaf..33fbf954 100644
--- a/render/gbm_allocator.c
+++ b/render/gbm_allocator.c
@@ -159,7 +159,7 @@ static struct wlr_gbm_allocator *get_gbm_alloc_from_alloc(
return (struct wlr_gbm_allocator *)alloc;
}
-struct wlr_gbm_allocator *wlr_gbm_allocator_create(int fd) {
+struct wlr_allocator *wlr_gbm_allocator_create(int fd) {
uint64_t cap;
if (drmGetCap(fd, DRM_CAP_PRIME, &cap) ||
!(cap & DRM_PRIME_CAP_EXPORT)) {
@@ -185,8 +185,11 @@ struct wlr_gbm_allocator *wlr_gbm_allocator_create(int fd) {
wlr_log(WLR_DEBUG, "Created GBM allocator with backend %s",
gbm_device_get_backend_name(alloc->gbm_device));
+ char *drm_name = drmGetDeviceNameFromFd2(fd);
+ wlr_log(WLR_DEBUG, "Using DRM node %s", drm_name);
+ free(drm_name);
- return alloc;
+ return &alloc->base;
}
static void allocator_destroy(struct wlr_allocator *wlr_alloc) {