mirror of
https://github.com/mpv-player/mpv
synced 2025-01-04 05:52:09 +00:00
vo_gpu: vdpau actually works under EGL
The use of glXGetCurrentDisplay() restricted this to the GLX backend. But actually it works under EGL as well. Removing the GLX-specific call and using the general mpv-internal method to get the X "Display" makes it work in mpv. I didn't know this. Nvidia didn't list this as extension in the EGL context when I still used their GPUs. Note that this might in theory break use of vdpau in some libmpv clients using the render API. But only if MPV_RENDER_PARAM_X11_DISPLAY is not used, and they relied on mpv using glXGetCurrentDisplay(). EGL does not provide such an API, and hwdec_vaapi.c also uses what hwdec_vdpau.c uses now. Considering that vaapi is preferable these days, it's not bad at all if these clients get "broken". They can be easily fixed by passing the display to mpv correctly.
This commit is contained in:
parent
17a89e5778
commit
1c8d2246bf
@ -987,8 +987,7 @@ Video
|
|||||||
:auto: enable best hw decoder (see below)
|
:auto: enable best hw decoder (see below)
|
||||||
:yes: exactly the same as ``auto``
|
:yes: exactly the same as ``auto``
|
||||||
:auto-copy: enable best hw decoder with copy-back (see below)
|
:auto-copy: enable best hw decoder with copy-back (see below)
|
||||||
:vdpau: requires ``--vo=gpu`` with ``--gpu-context=x11``,
|
:vdpau: requires ``--vo=gpu`` with X11, or ``--vo=vdpau`` (Linux only)
|
||||||
or ``--vo=vdpau`` (Linux only)
|
|
||||||
:vdpau-copy: copies video back into system RAM (Linux with some GPUs only)
|
:vdpau-copy: copies video back into system RAM (Linux with some GPUs only)
|
||||||
:vaapi: requires ``--vo=gpu`` or ``--vo=vaapi`` (Linux only)
|
:vaapi: requires ``--vo=gpu`` or ``--vo=vaapi`` (Linux only)
|
||||||
:vaapi-copy: copies video back into system RAM (Linux with some GPUs only)
|
:vaapi-copy: copies video back into system RAM (Linux with some GPUs only)
|
||||||
|
@ -18,8 +18,6 @@
|
|||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
#include <GL/glx.h>
|
|
||||||
|
|
||||||
#include "video/out/gpu/hwdec.h"
|
#include "video/out/gpu/hwdec.h"
|
||||||
#include "ra_gl.h"
|
#include "ra_gl.h"
|
||||||
#include "video/vdpau.h"
|
#include "video/vdpau.h"
|
||||||
@ -49,7 +47,7 @@ struct priv {
|
|||||||
|
|
||||||
static int init(struct ra_hwdec *hw)
|
static int init(struct ra_hwdec *hw)
|
||||||
{
|
{
|
||||||
Display *x11disp = glXGetCurrentDisplay();
|
Display *x11disp = ra_get_native_resource(hw->ra, "x11");
|
||||||
if (!x11disp || !ra_is_gl(hw->ra))
|
if (!x11disp || !ra_is_gl(hw->ra))
|
||||||
return -1;
|
return -1;
|
||||||
GL *gl = ra_gl_get(hw->ra);
|
GL *gl = ra_gl_get(hw->ra);
|
||||||
@ -313,7 +311,7 @@ static int mapper_map(struct ra_hwdec_mapper *mapper)
|
|||||||
}
|
}
|
||||||
|
|
||||||
const struct ra_hwdec_driver ra_hwdec_vdpau = {
|
const struct ra_hwdec_driver ra_hwdec_vdpau = {
|
||||||
.name = "vdpau-glx",
|
.name = "vdpau-gl",
|
||||||
.priv_size = sizeof(struct priv_owner),
|
.priv_size = sizeof(struct priv_owner),
|
||||||
.imgfmts = {IMGFMT_VDPAU, 0},
|
.imgfmts = {IMGFMT_VDPAU, 0},
|
||||||
.init = init,
|
.init = init,
|
||||||
|
Loading…
Reference in New Issue
Block a user