diff options
author | Niklas Haas <git@haasn.xyz> | 2017-09-14 08:04:55 +0200 |
---|---|---|
committer | Niklas Haas <git@haasn.xyz> | 2017-09-21 15:00:55 +0200 |
commit | 65979986a923a8f08019b257c3fe72cd5e8ecf68 (patch) | |
tree | b8f4b8c17d583594aef0ca509064f8b2ff7128d4 /video/out/opengl/context_wayland.c | |
parent | 20f958c9775652c3213588c2a0824f5353276adc (diff) | |
download | mpv-65979986a923a8f08019b257c3fe72cd5e8ecf68.tar.bz2 mpv-65979986a923a8f08019b257c3fe72cd5e8ecf68.tar.xz |
vo_opengl: refactor into vo_gpu
This is done in several steps:
1. refactor MPGLContext -> struct ra_ctx
2. move GL-specific stuff in vo_opengl into opengl/context.c
3. generalize context creation to support other APIs, and add --gpu-api
4. rename all of the --opengl- options that are no longer opengl-specific
5. move all of the stuff from opengl/* that isn't GL-specific into gpu/
(note: opengl/gl_utils.h became opengl/utils.h)
6. rename vo_opengl to vo_gpu
7. to handle window screenshots, the short-term approach was to just add
it to ra_swchain_fns. Long term (and for vulkan) this has to be moved to
ra itself (and vo_gpu altered to compensate), but this was a stop-gap
measure to prevent this commit from getting too big
8. move ra->fns->flush to ra_gl_ctx instead
9. some other minor changes that I've probably already forgotten
Note: This is one half of a major refactor, the other half of which is
provided by rossy's following commit. This commit enables support for
all linux platforms, while his version enables support for all non-linux
platforms.
Note 2: vo_opengl_cb.c also re-uses ra_gl_ctx so it benefits from the
--opengl- options like --opengl-early-flush, --opengl-finish etc. Should
be a strict superset of the old functionality.
Disclaimer: Since I have no way of compiling mpv on all platforms, some
of these ports were done blindly. Specifically, the blind ports included
context_mali_fbdev.c and context_rpi.c. Since they're both based on
egl_helpers, the port should have gone smoothly without any major
changes required. But if somebody complains about a compile error on
those platforms (assuming anybody actually uses them), you know where to
complain.
Diffstat (limited to 'video/out/opengl/context_wayland.c')
-rw-r--r-- | video/out/opengl/context_wayland.c | 74 |
1 files changed, 41 insertions, 33 deletions
diff --git a/video/out/opengl/context_wayland.c b/video/out/opengl/context_wayland.c index 87e98cd64f..6ddc550306 100644 --- a/video/out/opengl/context_wayland.c +++ b/video/out/opengl/context_wayland.c @@ -19,6 +19,7 @@ #include "video/out/wayland_common.h" #include "context.h" #include "egl_helpers.h" +#include "utils.h" static void egl_resize(struct vo_wayland_state *wl) { @@ -63,30 +64,42 @@ static void egl_resize(struct vo_wayland_state *wl) wl->vo->want_redraw = true; } -static int egl_create_context(struct vo_wayland_state *wl, MPGLContext *ctx, - int flags) +static void waylandgl_swap_buffers(struct ra_ctx *ctx) { - GL *gl = ctx->gl; + struct vo_wayland_state *wl = ctx->vo->wayland; + vo_wayland_wait_events(ctx->vo, 0); + eglSwapBuffers(wl->egl_context.egl.dpy, wl->egl_context.egl_surface); +} + +static bool egl_create_context(struct ra_ctx *ctx, struct vo_wayland_state *wl) +{ + GL *gl = ctx->priv = talloc_zero(ctx, GL); if (!(wl->egl_context.egl.dpy = eglGetDisplay(wl->display.display))) - return -1; + return false; if (eglInitialize(wl->egl_context.egl.dpy, NULL, NULL) != EGL_TRUE) - return -1; + return false; - if (!mpegl_create_context(wl->egl_context.egl.dpy, wl->log, flags, + if (!mpegl_create_context(ctx, wl->egl_context.egl.dpy, &wl->egl_context.egl.ctx, &wl->egl_context.egl.conf)) - return -1; + return false; eglMakeCurrent(wl->egl_context.egl.dpy, NULL, NULL, wl->egl_context.egl.ctx); mpegl_load_functions(gl, wl->log); - ctx->native_display_type = "wl"; - ctx->native_display = wl->display.display; + struct ra_gl_ctx_params params = { + .swap_buffers = waylandgl_swap_buffers, + .native_display_type = "wl", + .native_display = wl->display.display, + }; + + if (!ra_gl_ctx_init(ctx, gl, params)) + return false; - return 0; + return true; } static void egl_create_window(struct vo_wayland_state *wl) @@ -122,23 +135,25 @@ static void egl_create_window(struct vo_wayland_state *wl) eglSwapInterval(wl->egl_context.egl.dpy, 0); } -static int waylandgl_reconfig(struct MPGLContext *ctx) +static bool waylandgl_reconfig(struct ra_ctx *ctx) { struct vo_wayland_state * wl = ctx->vo->wayland; if (!vo_wayland_config(ctx->vo)) - return -1; + return false; if (!wl->egl_context.egl_window) egl_create_window(wl); - return 0; + return true; } -static void waylandgl_uninit(MPGLContext *ctx) +static void waylandgl_uninit(struct ra_ctx *ctx) { struct vo_wayland_state *wl = ctx->vo->wayland; + ra_gl_ctx_uninit(ctx); + if (wl->egl_context.egl.ctx) { eglReleaseThread(); if (wl->egl_context.egl_window) @@ -153,52 +168,45 @@ static void waylandgl_uninit(MPGLContext *ctx) vo_wayland_uninit(ctx->vo); } -static void waylandgl_swap_buffers(MPGLContext *ctx) -{ - struct vo_wayland_state *wl = ctx->vo->wayland; - - vo_wayland_wait_events(ctx->vo, 0); - - eglSwapBuffers(wl->egl_context.egl.dpy, wl->egl_context.egl_surface); -} - -static int waylandgl_control(MPGLContext *ctx, int *events, int request, +static int waylandgl_control(struct ra_ctx *ctx, int *events, int request, void *data) { struct vo_wayland_state *wl = ctx->vo->wayland; int r = vo_wayland_control(ctx->vo, events, request, data); - if (*events & VO_EVENT_RESIZE) + if (*events & VO_EVENT_RESIZE) { egl_resize(wl); + ra_gl_ctx_resize(ctx->swapchain, wl->vo->dwidth, wl->vo->dheight, 0); + } return r; } -static void wayland_wakeup(struct MPGLContext *ctx) +static void wayland_wakeup(struct ra_ctx *ctx) { vo_wayland_wakeup(ctx->vo); } -static void wayland_wait_events(struct MPGLContext *ctx, int64_t until_time_us) +static void wayland_wait_events(struct ra_ctx *ctx, int64_t until_time_us) { vo_wayland_wait_events(ctx->vo, until_time_us); } -static int waylandgl_init(struct MPGLContext *ctx, int flags) +static bool waylandgl_init(struct ra_ctx *ctx) { if (!vo_wayland_init(ctx->vo)) - return -1; + return false; - return egl_create_context(ctx->vo->wayland, ctx, flags); + return egl_create_context(ctx, ctx->vo->wayland); } -const struct mpgl_driver mpgl_driver_wayland = { +const struct ra_ctx_fns ra_ctx_wayland_egl = { + .type = "opengl", .name = "wayland", - .init = waylandgl_init, .reconfig = waylandgl_reconfig, - .swap_buffers = waylandgl_swap_buffers, .control = waylandgl_control, .wakeup = wayland_wakeup, .wait_events = wayland_wait_events, + .init = waylandgl_init, .uninit = waylandgl_uninit, }; |