diff options
-rw-r--r-- | include/render/wlr_renderer.h | 4 | ||||
-rw-r--r-- | render/wlr_renderer.c | 20 |
2 files changed, 16 insertions, 8 deletions
diff --git a/include/render/wlr_renderer.h b/include/render/wlr_renderer.h index 9e41f86f..dab9fd12 100644 --- a/include/render/wlr_renderer.h +++ b/include/render/wlr_renderer.h @@ -4,6 +4,10 @@ #include <wlr/render/wlr_renderer.h> /** + * Automatically select and create a renderer suitable for the DRM FD. + */ +struct wlr_renderer *wlr_renderer_autocreate_with_drm_fd(int drm_fd); +/** * Bind a buffer to the renderer. * * All subsequent rendering operations will operate on the supplied buffer. diff --git a/render/wlr_renderer.c b/render/wlr_renderer.c index 3c757430..4a565b1d 100644 --- a/render/wlr_renderer.c +++ b/render/wlr_renderer.c @@ -250,14 +250,8 @@ bool wlr_renderer_init_wl_display(struct wlr_renderer *r, return true; } -struct wlr_renderer *wlr_renderer_autocreate(struct wlr_backend *backend) { - int fd = backend_get_drm_fd(backend); - if (fd < 0) { - wlr_log(WLR_ERROR, "Failed to get DRM FD from backend"); - return NULL; - } - - struct gbm_device *gbm_device = gbm_create_device(fd); +struct wlr_renderer *wlr_renderer_autocreate_with_drm_fd(int drm_fd) { + struct gbm_device *gbm_device = gbm_create_device(drm_fd); if (!gbm_device) { wlr_log(WLR_ERROR, "Failed to create GBM device"); return NULL; @@ -282,6 +276,16 @@ struct wlr_renderer *wlr_renderer_autocreate(struct wlr_backend *backend) { return renderer; } +struct wlr_renderer *wlr_renderer_autocreate(struct wlr_backend *backend) { + int drm_fd = backend_get_drm_fd(backend); + if (drm_fd < 0) { + wlr_log(WLR_ERROR, "Failed to get DRM FD from backend"); + return NULL; + } + + return wlr_renderer_autocreate_with_drm_fd(drm_fd); +} + int wlr_renderer_get_drm_fd(struct wlr_renderer *r) { if (!r->impl->get_drm_fd) { return -1; |