diff options
author | Simon Ser <contact@emersion.fr> | 2021-06-24 13:11:21 +0200 |
---|---|---|
committer | Simon Zeni <simon@bl4ckb0ne.ca> | 2021-06-30 14:02:26 -0400 |
commit | 1db976cecb6968b2d989840c6f16aa00bb83d026 (patch) | |
tree | 79f47a4e2d0e11a648dc4f9b10b25a18762e3796 /render/gles2 | |
parent | 1c4b5bcab3aa1ca7b2c40fd64f77f90b8dde11d7 (diff) |
render/egl: replace wlr_egl_create with wlr_egl_create_with_drm_fd
We never create an EGL context with the platform set to something
other than EGL_PLATFORM_GBM_KHR. Let's simplify wlr_egl_create by
taking a DRM FD instead of a (platform, remote_display) tuple.
This hides the internal details of creating an EGL context for a
specific device. This will allow us to transparently use the device
platform [1] when the time comes.
[1]: https://github.com/swaywm/wlroots/pull/2671
Diffstat (limited to 'render/gles2')
-rw-r--r-- | render/gles2/renderer.c | 11 |
1 files changed, 1 insertions, 10 deletions
diff --git a/render/gles2/renderer.c b/render/gles2/renderer.c index e0534749..9bfaebd7 100644 --- a/render/gles2/renderer.c +++ b/render/gles2/renderer.c @@ -733,21 +733,12 @@ extern const GLchar tex_fragment_src_rgbx[]; extern const GLchar tex_fragment_src_external[]; struct wlr_renderer *wlr_gles2_renderer_create_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; - } - - struct wlr_egl *egl = wlr_egl_create(EGL_PLATFORM_GBM_KHR, gbm_device); + struct wlr_egl *egl = wlr_egl_create_with_drm_fd(drm_fd); if (egl == NULL) { wlr_log(WLR_ERROR, "Could not initialize EGL"); - gbm_device_destroy(gbm_device); return NULL; } - egl->gbm_device = gbm_device; - struct wlr_renderer *renderer = wlr_gles2_renderer_create(egl); if (!renderer) { wlr_log(WLR_ERROR, "Failed to create GLES2 renderer"); |