mirror of
https://github.com/LibreELEC/LibreELEC.tv.git
synced 2025-08-03 16:07:51 +00:00
Merge pull request #4039 from Kwiboo/mpv-update
mpv-drmprime: update to 0.30.0
This commit is contained in:
commit
b83039e250
@ -2,8 +2,8 @@
|
||||
# Copyright (C) 2019-present Team LibreELEC (https://libreelec.tv)
|
||||
|
||||
PKG_NAME="mpv-drmprime"
|
||||
PKG_VERSION="0.29.1"
|
||||
PKG_SHA256="f9f9d461d1990f9728660b4ccb0e8cb5dce29ccaa6af567bec481b79291ca623"
|
||||
PKG_VERSION="0.30.0"
|
||||
PKG_SHA256="33a1bcb7e74ff17f070e754c15c52228cf44f2cefbfd8f34886ae81df214ca35"
|
||||
PKG_LICENSE="GPL"
|
||||
PKG_SITE="https://mpv.io/"
|
||||
PKG_URL="https://github.com/mpv-player/mpv/archive/v$PKG_VERSION.tar.gz"
|
||||
@ -26,8 +26,6 @@ PKG_CONFIGURE_OPTS_TARGET="--prefix=/usr \
|
||||
--disable-x11 \
|
||||
--disable-vulkan \
|
||||
--disable-caca \
|
||||
--disable-crossc \
|
||||
--disable-libv4l2 \
|
||||
--enable-drm \
|
||||
--enable-drmprime \
|
||||
--enable-gbm \
|
||||
|
@ -1,73 +0,0 @@
|
||||
From 9c39a05e87e89534bc0ebf0b1a1bfb918cfb127d Mon Sep 17 00:00:00 2001
|
||||
From: Jonas Karlman <jonas@kwiboo.se>
|
||||
Date: Thu, 24 Jan 2019 22:11:10 +0100
|
||||
Subject: [PATCH] vo_gpu: hwdec_drmprime_drm: add hwdec ctx
|
||||
|
||||
This allows to use drm hwaccels that require a hwdevice.
|
||||
|
||||
Tested with v4l2request hwaccel and cedrus driver on an allwinner device
|
||||
running mpv with --vo=gpu --gpu-context=drm --hwdec=drm.
|
||||
---
|
||||
video/out/opengl/hwdec_drmprime_drm.c | 14 ++++++++++++++
|
||||
wscript | 2 +-
|
||||
2 files changed, 15 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/video/out/opengl/hwdec_drmprime_drm.c b/video/out/opengl/hwdec_drmprime_drm.c
|
||||
index fd3d383c55..13fbe7528f 100644
|
||||
--- a/video/out/opengl/hwdec_drmprime_drm.c
|
||||
+++ b/video/out/opengl/hwdec_drmprime_drm.c
|
||||
@@ -23,6 +23,7 @@
|
||||
#include <math.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
+#include <libavutil/hwcontext.h>
|
||||
#include <libavutil/hwcontext_drm.h>
|
||||
|
||||
#include "common.h"
|
||||
@@ -44,6 +45,7 @@ struct drm_frame {
|
||||
|
||||
struct priv {
|
||||
struct mp_log *log;
|
||||
+ struct mp_hwdec_ctx hwctx;
|
||||
|
||||
struct mp_image_params params;
|
||||
|
||||
@@ -231,6 +233,9 @@ static void uninit(struct ra_hwdec *hw)
|
||||
disable_video_plane(hw);
|
||||
set_current_frame(hw, NULL);
|
||||
|
||||
+ hwdec_devices_remove(hw->devs, &p->hwctx);
|
||||
+ av_buffer_unref(&p->hwctx.av_device_ref);
|
||||
+
|
||||
if (p->ctx) {
|
||||
drm_atomic_destroy_context(p->ctx);
|
||||
p->ctx = NULL;
|
||||
@@ -284,6 +289,15 @@ static int init(struct ra_hwdec *hw)
|
||||
}
|
||||
|
||||
disable_video_plane(hw);
|
||||
+
|
||||
+ p->hwctx = (struct mp_hwdec_ctx) {
|
||||
+ .driver_name = hw->driver->name,
|
||||
+ };
|
||||
+ if (!av_hwdevice_ctx_create(&p->hwctx.av_device_ref, AV_HWDEVICE_TYPE_DRM,
|
||||
+ drmGetDeviceNameFromFd2(p->ctx->fd), NULL, 0)) {
|
||||
+ hwdec_devices_add(hw->devs, &p->hwctx);
|
||||
+ }
|
||||
+
|
||||
return 0;
|
||||
|
||||
err:
|
||||
diff --git a/wscript b/wscript
|
||||
index d3d49090c8..c437d5adc1 100644
|
||||
--- a/wscript
|
||||
+++ b/wscript
|
||||
@@ -554,7 +554,7 @@ video_output_features = [
|
||||
'name': '--drm',
|
||||
'desc': 'DRM',
|
||||
'deps': 'vt.h',
|
||||
- 'func': check_pkg_config('libdrm'),
|
||||
+ 'func': check_pkg_config('libdrm', '>= 2.4.74'),
|
||||
}, {
|
||||
'name': '--drmprime',
|
||||
'desc': 'DRM Prime ffmpeg support',
|
Loading…
x
Reference in New Issue
Block a user