6 Commits
V3.24 ... V3.27

Author SHA1 Message Date
jojo61
2c8e75e3ff Clarify RGB Level Setting 2024-10-17 13:12:22 +02:00
jojo61
e3fe68d7e6 Update Readme 2024-10-17 12:50:08 +02:00
jojo61
41da5ca526 Cleanup some Compiler Warnings 2024-10-15 09:59:20 +02:00
jojo61
68fc7e4511 No deinterlacing for HVEC 2024-09-26 16:27:17 +02:00
jojo61
46df18afe0 Fix Makefile for VDR*Elec thanks to rell 2024-09-24 17:23:30 +02:00
jojo61
0ff83f0e31 No DMA handling for CUVID with placebo 2024-09-04 07:57:46 +02:00
9 changed files with 232 additions and 169 deletions

View File

@@ -113,8 +113,8 @@ TMPDIR ?= /tmp
### The compiler options: ### The compiler options:
export CFLAGS = $(call PKGCFG,cflags) export CFLAGS = $(call PKGCFG,cflags) -fpermissive
export CXXFLAGS = $(call PKGCFG,cxxflags) export CXXFLAGS = $(call PKGCFG,cxxflags) -fpermissive
ifeq ($(CFLAGS),) ifeq ($(CFLAGS),)
$(warning CFLAGS not set) $(warning CFLAGS not set)

View File

@@ -251,8 +251,8 @@ Setup: /etc/vdr/setup.conf
(Red * 65536 + Green * 256 + Blue) (Red * 65536 + Green * 256 + Blue)
softhddevice.StudioLevels = 0 softhddevice.StudioLevels = 0
0 use PC levels (0-255) with vdpau. 0 use limited RGB (16-235) with vdpau.
1 use studio levels (16-235) with vdpau. 1 use full RGB (0-255) with vdpau.
softhddevice.Suspend.Close = 0 softhddevice.Suspend.Close = 0
1 suspend closes x11 window, connection and audio device. 1 suspend closes x11 window, connection and audio device.

View File

@@ -2283,26 +2283,31 @@ found:
AudioChannelMatrix[u][chan] = 4; AudioChannelMatrix[u][chan] = 4;
break; break;
} }
__attribute__ ((fallthrough));
case 4: case 4:
if (AudioChannelsInHw[5]) { if (AudioChannelsInHw[5]) {
AudioChannelMatrix[u][chan] = 5; AudioChannelMatrix[u][chan] = 5;
break; break;
} }
__attribute__ ((fallthrough));
case 5: case 5:
if (AudioChannelsInHw[6]) { if (AudioChannelsInHw[6]) {
AudioChannelMatrix[u][chan] = 6; AudioChannelMatrix[u][chan] = 6;
break; break;
} }
__attribute__ ((fallthrough));
case 6: case 6:
if (AudioChannelsInHw[7]) { if (AudioChannelsInHw[7]) {
AudioChannelMatrix[u][chan] = 7; AudioChannelMatrix[u][chan] = 7;
break; break;
} }
__attribute__ ((fallthrough));
case 7: case 7:
if (AudioChannelsInHw[8]) { if (AudioChannelsInHw[8]) {
AudioChannelMatrix[u][chan] = 8; AudioChannelMatrix[u][chan] = 8;
break; break;
} }
__attribute__ ((fallthrough));
case 8: case 8:
if (AudioChannelsInHw[6]) { if (AudioChannelsInHw[6]) {
AudioChannelMatrix[u][chan] = 6; AudioChannelMatrix[u][chan] = 6;

22
codec.c
View File

@@ -208,9 +208,13 @@ void CodecVideoDelDecoder(VideoDecoder *decoder) { free(decoder); }
** @param codec_id video codec id ** @param codec_id video codec id
*/ */
void CodecVideoOpen(VideoDecoder *decoder, int codec_id) { void CodecVideoOpen(VideoDecoder *decoder, int codec_id) {
#if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,0,100)
AVCodec *video_codec; AVCodec *video_codec;
#else
const AVCodec *video_codec;
#endif
const char *name; const char *name;
int ret, deint = 2; int ret;
Debug(3, "***************codec: Video Open using video codec ID %#06x (%s)\n", codec_id, Debug(3, "***************codec: Video Open using video codec ID %#06x (%s)\n", codec_id,
avcodec_get_name(codec_id)); avcodec_get_name(codec_id));
@@ -265,9 +269,7 @@ void CodecVideoOpen(VideoDecoder *decoder, int codec_id) {
pthread_mutex_lock(&CodecLockMutex); pthread_mutex_lock(&CodecLockMutex);
// open codec // open codec
#ifdef YADIF
deint = 2;
#endif
#if defined VAAPI #if defined VAAPI
#if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,8,100) #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,8,100)
@@ -305,6 +307,7 @@ void CodecVideoOpen(VideoDecoder *decoder, int codec_id) {
#endif #endif
#ifdef CUVID #ifdef CUVID
int deint = 2;
if (strcmp(decoder->VideoCodec->long_name, if (strcmp(decoder->VideoCodec->long_name,
"Nvidia CUVID MPEG2VIDEO decoder") == 0) { // deinterlace for mpeg2 is somehow broken "Nvidia CUVID MPEG2VIDEO decoder") == 0) { // deinterlace for mpeg2 is somehow broken
if (av_opt_set_int(decoder->VideoCtx->priv_data, "deint", deint, 0) < 0) { // adaptive if (av_opt_set_int(decoder->VideoCtx->priv_data, "deint", deint, 0) < 0) { // adaptive
@@ -619,7 +622,11 @@ typedef struct _audio_decoder_ AudioDecoder;
/// Audio decoder structure. /// Audio decoder structure.
/// ///
struct _audio_decoder_ { struct _audio_decoder_ {
AVCodec *AudioCodec; ///< audio codec #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,0,100)
AVCodec *AudioCodec; ///< audio codec
#else
const AVCodec *AudioCodec; ///< audio codec
#endif
AVCodecContext *AudioCtx; ///< audio codec context AVCodecContext *AudioCtx; ///< audio codec context
char Passthrough; ///< current pass-through flags char Passthrough; ///< current pass-through flags
@@ -706,8 +713,11 @@ void CodecAudioDelDecoder(AudioDecoder *decoder) {
** @param codec_id audio codec id ** @param codec_id audio codec id
*/ */
void CodecAudioOpen(AudioDecoder *audio_decoder, int codec_id) { void CodecAudioOpen(AudioDecoder *audio_decoder, int codec_id) {
#if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,0,100)
AVCodec *audio_codec; AVCodec *audio_codec;
#else
const AVCodec *audio_codec;
#endif
Debug(3, "codec: using audio codec ID %#06x (%s)\n", codec_id, avcodec_get_name(codec_id)); Debug(3, "codec: using audio codec ID %#06x (%s)\n", codec_id, avcodec_get_name(codec_id));
if (!(audio_codec = avcodec_find_decoder(codec_id))) { if (!(audio_codec = avcodec_find_decoder(codec_id))) {
// if (!(audio_codec = avcodec_find_decoder(codec_id))) { // if (!(audio_codec = avcodec_find_decoder(codec_id))) {

View File

@@ -56,7 +56,11 @@ struct _video_decoder_ {
VideoHwDecoder *HwDecoder; ///< video hardware decoder VideoHwDecoder *HwDecoder; ///< video hardware decoder
int GetFormatDone; ///< flag get format called! int GetFormatDone; ///< flag get format called!
AVCodec *VideoCodec; ///< video codec #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,0,100)
AVCodec *VideoCodec; ///< video codec
#else
const AVCodec *VideoCodec; ///< video codec
#endif
AVCodecContext *VideoCtx; ///< video codec context AVCodecContext *VideoCtx; ///< video codec context
// #ifdef FFMPEG_WORKAROUND_ARTIFACTS // #ifdef FFMPEG_WORKAROUND_ARTIFACTS
int FirstKeyFrame; ///< flag first frame int FirstKeyFrame; ///< flag first frame

View File

@@ -126,7 +126,7 @@ void pl_shader_append_v(const char *fmt, ...) {
Fatal(_("Shaderlenght fault\n")); Fatal(_("Shaderlenght fault\n"));
strcat(shv, temp); strcat(shv, temp);
} }
#ifndef PLACEBO
static void compile_attach_shader(GLuint program, GLenum type, const char *source) { static void compile_attach_shader(GLuint program, GLenum type, const char *source) {
GLuint shader; GLuint shader;
GLint status = 1234, log_length; GLint status = 1234, log_length;
@@ -159,6 +159,7 @@ static void link_shader(GLuint program) {
Debug(3, "Link Status %d loglen %d\n", status, log_length); Debug(3, "Link Status %d loglen %d\n", status, log_length);
} }
static GLuint sc_generate_osd(GLuint gl_prog) { static GLuint sc_generate_osd(GLuint gl_prog) {
Debug(3, "vor create osd\n"); Debug(3, "vor create osd\n");
@@ -209,7 +210,7 @@ static GLuint sc_generate(GLuint gl_prog, enum AVColorSpace colorspace) {
int n; int n;
GLint cmsLoc; GLint cmsLoc;
float *m, *c, *cms; float *m, *c, *cms;
char *frag; //char *frag;
GL_init(); GL_init();
GLSL("%s\n", gl_version); GLSL("%s\n", gl_version);
@@ -446,3 +447,4 @@ static void render_pass_quad(int flip, float xcrop, float ycrop) {
for (n = 0; vertex_vao[n].name; n++) for (n = 0; vertex_vao[n].name; n++)
glDisableVertexAttribArray(n); glDisableVertexAttribArray(n);
} }
#endif

View File

@@ -61,7 +61,7 @@ extern void ToggleLUT();
/// vdr-plugin version number. /// vdr-plugin version number.
/// Makefile extracts the version number for generating the file name /// Makefile extracts the version number for generating the file name
/// for the distribution archive. /// for the distribution archive.
static const char *const VERSION = "3.24" static const char *const VERSION = "3.27"
#ifdef GIT_REV #ifdef GIT_REV
"-GIT" GIT_REV "-GIT" GIT_REV
#endif #endif
@@ -1226,7 +1226,7 @@ void cMenuSetupSoft::Create(void) {
Add(new cMenuEditIntItem(tr("Video background color (Alpha)"), (int *)&BackgroundAlpha, 0, 0xFF)); Add(new cMenuEditIntItem(tr("Video background color (Alpha)"), (int *)&BackgroundAlpha, 0, 0xFF));
#endif #endif
#ifdef PLACEBO #ifdef PLACEBO
Add(new cMenuEditBoolItem(tr("Use studio levels"), &StudioLevels, trVDR("no"), trVDR("yes"))); Add(new cMenuEditBoolItem(tr("RGB Level"), &StudioLevels, trVDR("limited RGB"), trVDR("Full RGB")));
#endif #endif
Add(new cMenuEditBoolItem(tr("60hz display mode"), &_60HzMode, trVDR("no"), trVDR("yes"))); Add(new cMenuEditBoolItem(tr("60hz display mode"), &_60HzMode, trVDR("no"), trVDR("yes")));
Add(new cMenuEditBoolItem(tr("Soft start a/v sync"), &SoftStartSync, trVDR("no"), trVDR("yes"))); Add(new cMenuEditBoolItem(tr("Soft start a/v sync"), &SoftStartSync, trVDR("no"), trVDR("yes")));

View File

@@ -60,7 +60,7 @@
#include "codec.h" #include "codec.h"
// clang-format on // clang-format on
#ifdef DEBUG #if 0
static int DumpH264(const uint8_t *data, int size); static int DumpH264(const uint8_t *data, int size);
static void DumpMpeg(const uint8_t *data, int size); static void DumpMpeg(const uint8_t *data, int size);
#endif #endif
@@ -662,7 +662,13 @@ static void PesParse(PesDemux *pesdx, const uint8_t *data, int size, int is_star
break; break;
} }
if (r > 0) { if (r > 0) {
AVPacket avpkt[1]; #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(58,33,100)
AVPacket avpkt[1];
av_init_packet(avpkt);
#else
AVPacket * avpkt;
avpkt = av_packet_alloc();
#endif
// new codec id, close and open new // new codec id, close and open new
if (AudioCodecID != codec_id) { if (AudioCodecID != codec_id) {
@@ -671,13 +677,15 @@ static void PesParse(PesDemux *pesdx, const uint8_t *data, int size, int is_star
CodecAudioOpen(MyAudioDecoder, codec_id); CodecAudioOpen(MyAudioDecoder, codec_id);
AudioCodecID = codec_id; AudioCodecID = codec_id;
} }
av_init_packet(avpkt);
avpkt->data = (void *)q; avpkt->data = (void *)q;
avpkt->size = r; avpkt->size = r;
avpkt->pts = pesdx->PTS; avpkt->pts = pesdx->PTS;
avpkt->dts = pesdx->DTS; avpkt->dts = pesdx->DTS;
// FIXME: not aligned for ffmpeg // FIXME: not aligned for ffmpeg
CodecAudioDecode(MyAudioDecoder, avpkt); CodecAudioDecode(MyAudioDecoder, avpkt);
#if LIBAVCODEC_VERSION_INT >= AV_VERSION_INT(58,33,100)
av_packet_free(&avpkt);
#endif
pesdx->PTS = AV_NOPTS_VALUE; pesdx->PTS = AV_NOPTS_VALUE;
pesdx->DTS = AV_NOPTS_VALUE; pesdx->DTS = AV_NOPTS_VALUE;
pesdx->Skip += r; pesdx->Skip += r;
@@ -1147,21 +1155,28 @@ int PlayAudio(const uint8_t *data, int size, uint8_t id) {
break; break;
} }
if (r > 0) { if (r > 0) {
AVPacket avpkt[1]; #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(58,33,100)
AVPacket avpkt[1];
av_init_packet(avpkt);
#else
AVPacket * avpkt;
avpkt = av_packet_alloc();
#endif
// new codec id, close and open new // new codec id, close and open new
if (AudioCodecID != codec_id) { if (AudioCodecID != codec_id) {
CodecAudioClose(MyAudioDecoder); CodecAudioClose(MyAudioDecoder);
CodecAudioOpen(MyAudioDecoder, codec_id); CodecAudioOpen(MyAudioDecoder, codec_id);
AudioCodecID = codec_id; AudioCodecID = codec_id;
} }
av_init_packet(avpkt);
avpkt->data = (void *)p; avpkt->data = (void *)p;
avpkt->size = r; avpkt->size = r;
avpkt->pts = AudioAvPkt->pts; avpkt->pts = AudioAvPkt->pts;
avpkt->dts = AudioAvPkt->dts; avpkt->dts = AudioAvPkt->dts;
// FIXME: not aligned for ffmpeg // FIXME: not aligned for ffmpeg
CodecAudioDecode(MyAudioDecoder, avpkt); CodecAudioDecode(MyAudioDecoder, avpkt);
#if LIBAVCODEC_VERSION_INT >= AV_VERSION_INT(58,33,100)
av_packet_free(&avpkt);
#endif
AudioAvPkt->pts = AV_NOPTS_VALUE; AudioAvPkt->pts = AV_NOPTS_VALUE;
AudioAvPkt->dts = AV_NOPTS_VALUE; AudioAvPkt->dts = AV_NOPTS_VALUE;
p += r; p += r;
@@ -1625,7 +1640,7 @@ static void VideoMpegEnqueue(VideoStream *stream, int64_t pts, int64_t dts, cons
** @param avpkt ffmpeg a/v packet ** @param avpkt ffmpeg a/v packet
*/ */
#ifndef USE_PIP #if !defined USE_PIP && !defined VAAPI
static void FixPacketForFFMpeg(VideoDecoder *vdecoder, AVPacket *avpkt) { static void FixPacketForFFMpeg(VideoDecoder *vdecoder, AVPacket *avpkt) {
uint8_t *p; uint8_t *p;
int n; int n;
@@ -1993,7 +2008,7 @@ static void StopVideo(void) {
#endif #endif
} }
#ifdef DEBUG #if 0
/** /**
** Dump mpeg video packet. ** Dump mpeg video packet.

319
video.c
View File

@@ -172,6 +172,7 @@ typedef enum {
#if !defined PLACEBO_GL #if !defined PLACEBO_GL
#include <EGL/egl.h> #include <EGL/egl.h>
#include <EGL/eglext.h> #include <EGL/eglext.h>
#endif #endif
#ifndef GL_OES_EGL_image #ifndef GL_OES_EGL_image
@@ -183,6 +184,7 @@ typedef void *EGLImageKHR;
#ifdef PLACEBO #ifdef PLACEBO
#ifdef PLACEBO_GL #ifdef PLACEBO_GL
GLenum glewInit(void);
#include <libplacebo/opengl.h> #include <libplacebo/opengl.h>
#else #else
#define VK_USE_PLATFORM_XCB_KHR #define VK_USE_PLATFORM_XCB_KHR
@@ -380,18 +382,12 @@ signed char VideoHardwareDecoder = -1; ///< flag use hardware decoder
static char VideoSurfaceModesChanged; ///< flag surface modes changed static char VideoSurfaceModesChanged; ///< flag surface modes changed
/// flag use transparent OSD.
static const char VideoTransparentOsd = 1;
static uint32_t VideoBackground; ///< video background color static uint32_t VideoBackground; ///< video background color
char VideoStudioLevels; ///< flag use studio levels char VideoStudioLevels; ///< flag use studio levels
/// Default deinterlace mode. /// Default deinterlace mode.
static VideoDeinterlaceModes VideoDeinterlace[VideoResolutionMax]; static VideoDeinterlaceModes VideoDeinterlace[VideoResolutionMax];
/// Default number of deinterlace surfaces
static const int VideoDeinterlaceSurfaces = 4;
/// Default skip chroma deinterlace flag (CUVID only). /// Default skip chroma deinterlace flag (CUVID only).
static char VideoSkipChromaDeinterlace[VideoResolutionMax]; static char VideoSkipChromaDeinterlace[VideoResolutionMax];
@@ -430,7 +426,7 @@ static int DRMRefresh = 50;
static char Video60HzMode; ///< handle 60hz displays static char Video60HzMode; ///< handle 60hz displays
static char VideoSoftStartSync; ///< soft start sync audio/video static char VideoSoftStartSync; ///< soft start sync audio/video
static const int VideoSoftStartFrames = 100; ///< soft start frames //static const int VideoSoftStartFrames = 100; ///< soft start frames
static char VideoShowBlackPicture; ///< flag show black picture static char VideoShowBlackPicture; ///< flag show black picture
static float VideoBrightness = 0.0f; static float VideoBrightness = 0.0f;
@@ -442,11 +438,14 @@ static float VideoTemperature = 0.0f;
static int VulkanTargetColorSpace = 0; static int VulkanTargetColorSpace = 0;
static int VideoScalerTest = 0; static int VideoScalerTest = 0;
static int VideoColorBlindness = 0; static int VideoColorBlindness = 0;
static float VideoColorBlindnessFaktor = 1.0f; static float VideoColorBlindnessFaktor = 1.0;
#ifdef PLACEBO
static char *shadersp[NUM_SHADERS]; static char *shadersp[NUM_SHADERS];
char MyConfigDir[200]; char MyConfigDir[200];
static int num_shaders = 0; static int num_shaders = 0;
#endif
static int LUTon = -1; static int LUTon = -1;
static xcb_atom_t WmDeleteWindowAtom; ///< WM delete message atom static xcb_atom_t WmDeleteWindowAtom; ///< WM delete message atom
@@ -494,11 +493,11 @@ static char DPMSDisabled; ///< flag we have disabled dpms
static char EnableDPMSatBlackScreen; ///< flag we should enable dpms at black screen static char EnableDPMSatBlackScreen; ///< flag we should enable dpms at black screen
#endif #endif
static unsigned int Count;
static int EglEnabled; ///< use EGL static int EglEnabled; ///< use EGL
static int GlxVSyncEnabled = 1; ///< enable/disable v-sync
#ifdef CUVID #ifdef CUVID
static int GlxVSyncEnabled = 1; ///< enable/disable v-sync
static unsigned int Count;
static GLXContext glxSharedContext; ///< shared gl context static GLXContext glxSharedContext; ///< shared gl context
static GLXContext glxContext; ///< our gl context static GLXContext glxContext; ///< our gl context
@@ -509,11 +508,13 @@ static void GlxSetupWindow(xcb_window_t window, int width, int height, GLXContex
GLXContext OSDcontext; GLXContext OSDcontext;
#else #else
static EGLContext eglSharedContext; ///< shared gl context static EGLContext eglSharedContext; ///< shared gl context
#ifdef USE_DRM
static EGLContext eglOSDContext = NULL; ///< our gl context for the thread static EGLContext eglOSDContext = NULL; ///< our gl context for the thread
#endif
static EGLContext eglContext; ///< our gl context static EGLContext eglContext; ///< our gl context
static EGLConfig eglConfig; static EGLConfig eglConfig;
static EGLDisplay eglDisplay; static EGLDisplay eglDisplay;
static EGLSurface eglSurface, eglOSDSurface; static EGLSurface eglSurface;
static EGLint eglAttrs[10]; static EGLint eglAttrs[10];
static int eglVersion = 2; static int eglVersion = 2;
static EGLImageKHR(EGLAPIENTRY *CreateImageKHR)(EGLDisplay, EGLContext, EGLenum, EGLClientBuffer, const EGLint *); static EGLImageKHR(EGLAPIENTRY *CreateImageKHR)(EGLDisplay, EGLContext, EGLenum, EGLClientBuffer, const EGLint *);
@@ -531,9 +532,6 @@ static void GlxSetupWindow(xcb_window_t window, int width, int height, EGLContex
EGLContext OSDcontext; EGLContext OSDcontext;
#endif #endif
static GLuint OsdGlTextures[2]; ///< gl texture for OSD
static int OsdIndex = 0; ///< index into OsdGlTextures
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
// Common Functions // Common Functions
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@@ -630,8 +628,8 @@ static void VideoSetPts(int64_t *pts_p, int interlaced, const AVCodecContext *vi
// } else { // } else {
duration = interlaced ? 40 : 20; // 50Hz -> 20ms default duration = interlaced ? 40 : 20; // 50Hz -> 20ms default
// } // }
// Debug(4, "video: %d/%d %" PRIx64 " -> %d\n", video_ctx->framerate.den, Debug(4, "video: Framerate %d/%d \n", video_ctx->framerate.den,
// video_ctx->framerate.num, av_frame_get_pkt_duration(frame), duration); video_ctx->framerate.num);
// update video clock // update video clock
if (*pts_p != (int64_t)AV_NOPTS_VALUE) { if (*pts_p != (int64_t)AV_NOPTS_VALUE) {
@@ -793,7 +791,7 @@ video_none:
return; return;
} }
static uint64_t test_time = 0; //static uint64_t test_time = 0;
/// ///
/// Lock video thread. /// Lock video thread.
@@ -871,18 +869,7 @@ static uint64_t test_time = 0;
#ifdef USE_GLX #ifdef USE_GLX
///
/// GLX extension functions
///@{
#ifdef GLX_MESA_swap_control
static PFNGLXSWAPINTERVALMESAPROC GlxSwapIntervalMESA;
#endif
#ifdef GLX_SGI_video_sync
static PFNGLXGETVIDEOSYNCSGIPROC GlxGetVideoSyncSGI;
#endif
#ifdef GLX_SGI_swap_control
static PFNGLXSWAPINTERVALSGIPROC GlxSwapIntervalSGI;
#endif
/// ///
/// GLX check error. /// GLX check error.
@@ -896,6 +883,21 @@ static PFNGLXSWAPINTERVALSGIPROC GlxSwapIntervalSGI;
} \ } \
} }
#ifdef CUVID
///
/// GLX extension functions
///@{
#ifdef GLX_MESA_swap_control
static PFNGLXSWAPINTERVALMESAPROC GlxSwapIntervalMESA;
#endif
#ifdef GLX_SGI_video_sync
static PFNGLXGETVIDEOSYNCSGIPROC GlxGetVideoSyncSGI;
#endif
#ifdef GLX_SGI_swap_control
static PFNGLXSWAPINTERVALSGIPROC GlxSwapIntervalSGI;
#endif
/// ///
/// GLX check if a GLX extension is supported. /// GLX check if a GLX extension is supported.
/// ///
@@ -915,6 +917,7 @@ static int GlxIsExtensionSupported(const char *ext) {
} }
return 0; return 0;
} }
#endif
/// ///
/// Setup GLX window. /// Setup GLX window.
@@ -930,11 +933,12 @@ static void GlxSetupWindow(xcb_window_t window, int width, int height, GLXContex
static void GlxSetupWindow(xcb_window_t window, int width, int height, EGLContext context) static void GlxSetupWindow(xcb_window_t window, int width, int height, EGLContext context)
#endif #endif
{ {
#ifdef CUVID
uint32_t start; uint32_t start;
uint32_t end; uint32_t end;
int i; int i;
unsigned count; unsigned count;
#endif
#ifdef PLACEBO_ #ifdef PLACEBO_
return; return;
@@ -1170,6 +1174,7 @@ static void EglInit(void) {
} }
#else // VAAPI #else // VAAPI
extern void make_egl(void);
static void EglInit(void) { static void EglInit(void) {
int redSize, greenSize, blueSize, alphaSize; int redSize, greenSize, blueSize, alphaSize;
static int glewdone = 0; static int glewdone = 0;
@@ -1185,7 +1190,8 @@ static void EglInit(void) {
make_egl(); make_egl();
if (!glewdone) { if (!glewdone) {
GLenum err = glewInit(); //GLenum err = glewInit();
glewInit();
glewdone = 1; glewdone = 1;
// if (err != GLEW_OK) { // if (err != GLEW_OK) {
@@ -1456,11 +1462,11 @@ typedef struct priv {
const struct pl_vulkan *vk; const struct pl_vulkan *vk;
const struct pl_vk_inst *vk_inst; const struct pl_vk_inst *vk_inst;
#endif #endif
struct pl_context *ctx; const struct pl_log_t *ctx;
struct pl_custom_lut *lut; struct pl_custom_lut *lut;
struct pl_renderer *renderer; struct pl_renderer_t *renderer;
struct pl_renderer *renderertest; struct pl_renderer_t *renderertest;
const struct pl_swapchain *swapchain; const struct pl_swapchain_t *swapchain;
struct pl_log_params context; struct pl_log_params context;
#ifndef PLACEBO_GL #ifndef PLACEBO_GL
VkSurfaceKHR pSurface; VkSurfaceKHR pSurface;
@@ -1468,7 +1474,7 @@ typedef struct priv {
int has_dma_buf; int has_dma_buf;
#ifdef PLACEBO_GL #ifdef PLACEBO_GL
#if PL_API_VER >= 229 #if PL_API_VER >= 229
struct pl_opengl_t *gl; const struct pl_opengl_t *gl;
#else #else
struct pl_opengl *gl; struct pl_opengl *gl;
#endif #endif
@@ -1484,7 +1490,6 @@ static struct pl_overlay osdoverlay;
static struct pl_overlay_part part; static struct pl_overlay_part part;
#endif #endif
static int semid;
struct itimerval itimer; struct itimerval itimer;
#endif #endif
@@ -1816,11 +1821,6 @@ struct mp_egl_config_attr {
#define MP_EGL_ATTRIB(id) \ #define MP_EGL_ATTRIB(id) \
{ id, #id } { id, #id }
static const struct mp_egl_config_attr mp_egl_attribs[] = {
MP_EGL_ATTRIB(EGL_CONFIG_ID), MP_EGL_ATTRIB(EGL_RED_SIZE), MP_EGL_ATTRIB(EGL_GREEN_SIZE),
MP_EGL_ATTRIB(EGL_BLUE_SIZE), MP_EGL_ATTRIB(EGL_ALPHA_SIZE), MP_EGL_ATTRIB(EGL_COLOR_BUFFER_TYPE),
MP_EGL_ATTRIB(EGL_CONFIG_CAVEAT), MP_EGL_ATTRIB(EGL_CONFORMANT),
};
const int mpgl_preferred_gl_versions[] = {460, 440, 430, 400, 330, 320, 310, 300, 210, 0}; const int mpgl_preferred_gl_versions[] = {460, 440, 430, 400, 330, 320, 310, 300, 210, 0};
@@ -1952,7 +1952,7 @@ static bool create_context_cb(EGLDisplay display, int es_version, EGLContext *ou
return true; return true;
} }
make_egl() { void make_egl(void) {
int bpp; int bpp;
CreateImageKHR = (void *)eglGetProcAddress("eglCreateImageKHR"); CreateImageKHR = (void *)eglGetProcAddress("eglCreateImageKHR");
@@ -1976,7 +1976,7 @@ make_egl() {
if (!create_context_cb(eglDisplay, 0, &eglContext, &eglConfig, &bpp)) { if (!create_context_cb(eglDisplay, 0, &eglContext, &eglConfig, &bpp)) {
Fatal(_("Could not create EGL Context\n")); Fatal(_("Could not create EGL Context\n"));
} }
int vID, n; int vID;
eglGetConfigAttrib(eglDisplay, eglConfig, EGL_NATIVE_VISUAL_ID, &vID); eglGetConfigAttrib(eglDisplay, eglConfig, EGL_NATIVE_VISUAL_ID, &vID);
Debug(3, "chose visual 0x%x bpp %d\n", vID, bpp); Debug(3, "chose visual 0x%x bpp %d\n", vID, bpp);
@@ -2249,9 +2249,9 @@ void generateCUDAImage(CuvidDecoder *decoder, int index, const AVFrame *frame, i
#ifdef PLACEBO #ifdef PLACEBO
void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsigned int size_y, void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsigned int size_y,
enum AVPixelFormat PixFmt) { enum AVPixelFormat PixFmt) {
int n, i, size = 1, fd; int n, i;
const struct pl_fmt *fmt; const struct pl_fmt_t *fmt;
struct pl_tex *tex; //struct pl_tex *tex;
struct pl_frame *img; struct pl_frame *img;
struct pl_plane *pl; struct pl_plane *pl;
@@ -2270,10 +2270,8 @@ void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsig
if (PixFmt == AV_PIX_FMT_NV12) { if (PixFmt == AV_PIX_FMT_NV12) {
fmt = pl_find_named_fmt(p->gpu, n == 0 ? "r8" : "rg8"); // 8 Bit YUV fmt = pl_find_named_fmt(p->gpu, n == 0 ? "r8" : "rg8"); // 8 Bit YUV
size = 1;
} else { } else {
fmt = pl_find_named_fmt(p->gpu, n == 0 ? "r16" : "rg16"); // 10 Bit YUV fmt = pl_find_named_fmt(p->gpu, n == 0 ? "r16" : "rg16"); // 10 Bit YUV
size = 2;
} }
if (decoder->pl_frames[i].planes[n].texture) { if (decoder->pl_frames[i].planes[n].texture) {
// #ifdef VAAPI // #ifdef VAAPI
@@ -2285,7 +2283,7 @@ void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsig
&decoder->pl_frames[i].planes[n].texture); // delete old texture &decoder->pl_frames[i].planes[n].texture); // delete old texture
} }
//if (p->has_dma_buf == 0) { if (p->has_dma_buf == 0) {
decoder->pl_frames[i].planes[n].texture = pl_tex_create( decoder->pl_frames[i].planes[n].texture = pl_tex_create(
p->gpu, &(struct pl_tex_params) { p->gpu, &(struct pl_tex_params) {
.w = n == 0 ? size_x : size_x / 2, .h = n == 0 ? size_y : size_y / 2, .d = 0, .format = fmt, .w = n == 0 ? size_x : size_x / 2, .h = n == 0 ? size_y : size_y / 2, .d = 0, .format = fmt,
@@ -2297,7 +2295,7 @@ void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsig
.export_handle = PL_HANDLE_FD, .export_handle = PL_HANDLE_FD,
#endif #endif
}); });
//} }
// make planes for image // make planes for image
pl = &decoder->pl_frames[i].planes[n]; pl = &decoder->pl_frames[i].planes[n];
@@ -2320,7 +2318,7 @@ void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsig
Fatal(_("Unable to create placebo textures")); Fatal(_("Unable to create placebo textures"));
} }
#ifdef CUVID #ifdef CUVID
fd = dup(decoder->pl_frames[i].planes[n].texture->shared_mem.handle.fd); int fd = dup(decoder->pl_frames[i].planes[n].texture->shared_mem.handle.fd);
CUDA_EXTERNAL_MEMORY_HANDLE_DESC ext_desc = { CUDA_EXTERNAL_MEMORY_HANDLE_DESC ext_desc = {
.type = CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD, .type = CU_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD,
.handle.fd = fd, .handle.fd = fd,
@@ -2372,10 +2370,8 @@ void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsig
void generateVAAPIImage(CuvidDecoder *decoder, int index, const AVFrame *frame, int image_width, int image_height) { void generateVAAPIImage(CuvidDecoder *decoder, int index, const AVFrame *frame, int image_width, int image_height) {
int n; int n;
VAStatus status; VAStatus status;
int toggle = 0;
uint64_t first_time;
VADRMPRIMESurfaceDescriptor desc; VADRMPRIMESurfaceDescriptor desc;
vaSyncSurface(decoder->VaDisplay, (unsigned int)frame->data[3]); vaSyncSurface(decoder->VaDisplay, (unsigned int)frame->data[3]);
status = status =
vaExportSurfaceHandle(decoder->VaDisplay, (unsigned int)frame->data[3], VA_SURFACE_ATTRIB_MEM_TYPE_DRM_PRIME_2, vaExportSurfaceHandle(decoder->VaDisplay, (unsigned int)frame->data[3], VA_SURFACE_ATTRIB_MEM_TYPE_DRM_PRIME_2,
@@ -2394,11 +2390,8 @@ void generateVAAPIImage(CuvidDecoder *decoder, int index, const AVFrame *frame,
int fd = desc.objects[id].fd; int fd = desc.objects[id].fd;
uint32_t size = desc.objects[id].size; uint32_t size = desc.objects[id].size;
uint32_t offset = desc.layers[n].offset[0]; uint32_t offset = desc.layers[n].offset[0];
#if PL_API_VER < 229
struct pl_fmt *fmt;
#else
struct pl_fmt_t *fmt; struct pl_fmt_t *fmt;
#endif
if (fd == -1) { if (fd == -1) {
printf("Fehler beim Import von Surface %d\n", index); printf("Fehler beim Import von Surface %d\n", index);
@@ -2409,15 +2402,14 @@ void generateVAAPIImage(CuvidDecoder *decoder, int index, const AVFrame *frame,
size = n == 0 ? desc.width * desc.height : desc.width * desc.height / 2; size = n == 0 ? desc.width * desc.height : desc.width * desc.height / 2;
} }
// fmt = pl_find_fourcc(p->gpu,desc.layers[n].drm_format); // fmt = pl_find_fourcc(p->gpu,desc.lsayers[n].drm_format);
#if 1
if (decoder->PixFmt == AV_PIX_FMT_NV12) { if (decoder->PixFmt == AV_PIX_FMT_NV12) {
fmt = pl_find_named_fmt(p->gpu, n == 0 ? "r8" : "rg8"); // 8 Bit YUV fmt = pl_find_named_fmt(p->gpu, n == 0 ? "r8" : "rg8"); // 8 Bit YUV
} else { } else {
fmt = pl_find_fourcc(p->gpu, fmt = pl_find_fourcc(p->gpu,
n == 0 ? 0x20363152 : 0x32335247); // 10 Bit YUV n == 0 ? 0x20363152 : 0x32335247); // 10 Bit YUV
} }
#endif
assert(fmt != NULL); assert(fmt != NULL);
#ifdef PLACEBO_GL #ifdef PLACEBO_GL
@@ -2570,8 +2562,6 @@ void generateVAAPIImage(CuvidDecoder *decoder, VASurfaceID index, const AVFrame
int image_height) { int image_height) {
VAStatus status; VAStatus status;
uint64_t first_time;
#if defined(VAAPI) #if defined(VAAPI)
VADRMPRIMESurfaceDescriptor desc; VADRMPRIMESurfaceDescriptor desc;
@@ -2840,7 +2830,7 @@ static int init_generic_hwaccel(CuvidDecoder *decoder, enum AVPixelFormat hw_fmt
if (decoder->cached_hw_frames_ctx) { if (decoder->cached_hw_frames_ctx) {
AVHWFramesContext *old_fctx = (void *)decoder->cached_hw_frames_ctx->data; AVHWFramesContext *old_fctx = (void *)decoder->cached_hw_frames_ctx->data;
Debug(3, "CMP %d:%d %d:%d %d:%d %d:%d %d:%d\,", new_fctx->format, old_fctx->format, new_fctx->sw_format, Debug(3, "CMP %d:%d %d:%d %d:%d %d:%d %d:%d\n,", new_fctx->format, old_fctx->format, new_fctx->sw_format,
old_fctx->sw_format, new_fctx->width, old_fctx->width, new_fctx->height, old_fctx->height, old_fctx->sw_format, new_fctx->width, old_fctx->width, new_fctx->height, old_fctx->height,
new_fctx->initial_pool_size, old_fctx->initial_pool_size); new_fctx->initial_pool_size, old_fctx->initial_pool_size);
if (new_fctx->format != old_fctx->format || new_fctx->sw_format != old_fctx->sw_format || if (new_fctx->format != old_fctx->format || new_fctx->sw_format != old_fctx->sw_format ||
@@ -2889,7 +2879,7 @@ error:
static enum AVPixelFormat Cuvid_get_format(CuvidDecoder *decoder, AVCodecContext *video_ctx, static enum AVPixelFormat Cuvid_get_format(CuvidDecoder *decoder, AVCodecContext *video_ctx,
const enum AVPixelFormat *fmt) { const enum AVPixelFormat *fmt) {
const enum AVPixelFormat *fmt_idx; const enum AVPixelFormat *fmt_idx;
int bitformat16 = 0, deint = 0; int bitformat16 = 0;
VideoDecoder *ist = video_ctx->opaque; VideoDecoder *ist = video_ctx->opaque;
@@ -2986,6 +2976,7 @@ static enum AVPixelFormat Cuvid_get_format(CuvidDecoder *decoder, AVCodecContext
} }
#if defined YADIF && defined CUVID #if defined YADIF && defined CUVID
int deint;
if (VideoDeinterlace[decoder->Resolution] == VideoDeinterlaceYadif) { if (VideoDeinterlace[decoder->Resolution] == VideoDeinterlaceYadif) {
deint = 0; deint = 0;
ist->filter = 1; // init yadif_cuda ist->filter = 1; // init yadif_cuda
@@ -3004,7 +2995,10 @@ static enum AVPixelFormat Cuvid_get_format(CuvidDecoder *decoder, AVCodecContext
#ifdef CUVID #ifdef CUVID
ist->active_hwaccel_id = HWACCEL_CUVID; ist->active_hwaccel_id = HWACCEL_CUVID;
#else #else
if (VideoDeinterlace[decoder->Resolution]) {// need deinterlace if (video_ctx->codec_id == AV_CODEC_ID_HEVC) {
ist->filter = 0;
}
else if (VideoDeinterlace[decoder->Resolution]) {// need deinterlace
ist->filter = 1; // init deint vaapi ist->filter = 1; // init deint vaapi
} }
else { else {
@@ -3037,18 +3031,18 @@ int get_RGB(CuvidDecoder *decoder) {
#ifdef PLACEBO #ifdef PLACEBO
struct pl_render_params render_params = pl_render_default_params; struct pl_render_params render_params = pl_render_default_params;
struct pl_frame target = {0}; struct pl_frame target = {0};
const struct pl_fmt *fmt; const struct pl_fmt_t *fmt;
int offset, x1, y1, x0, y0; int x1=0, y1=0, x0=0, y0=0;
float faktorx, faktory; float faktorx, faktory;
#endif #endif
uint8_t *base; uint8_t *base;
int width; int width;
int height; int height;
GLuint fb, texture;
int current; int current;
GLint texLoc;
base = decoder->grabbase; base = decoder->grabbase;
width = decoder->grabwidth; width = decoder->grabwidth;
@@ -3057,7 +3051,8 @@ int get_RGB(CuvidDecoder *decoder) {
current = decoder->SurfacesRb[decoder->SurfaceRead]; current = decoder->SurfacesRb[decoder->SurfaceRead];
#ifndef PLACEBO #ifndef PLACEBO
GLint texLoc;
GLuint fb, texture;
glGenTextures(1, &texture); glGenTextures(1, &texture);
GlxCheck(); GlxCheck();
glBindTexture(GL_TEXTURE_2D, texture); glBindTexture(GL_TEXTURE_2D, texture);
@@ -3496,7 +3491,6 @@ extern void cudaLaunchNV12toARGBDrv(uint32_t * d_srcNV12, size_t nSourcePitch, u
/// @param frame frame to display /// @param frame frame to display
/// ///
static void CuvidRenderFrame(CuvidDecoder *decoder, const AVCodecContext *video_ctx, AVFrame *frame) { static void CuvidRenderFrame(CuvidDecoder *decoder, const AVCodecContext *video_ctx, AVFrame *frame) {
uint64_t first_time;
int surface; int surface;
enum AVColorSpace color; enum AVColorSpace color;
@@ -3524,33 +3518,40 @@ static void CuvidRenderFrame(CuvidDecoder *decoder, const AVCodecContext *video_
// Fix libav colorspace failure // Fix libav colorspace failure
color = frame->colorspace; color = frame->colorspace;
if (color == AVCOL_SPC_UNSPECIFIED) // failure with RTL HD and all SD channels if (color == AVCOL_SPC_UNSPECIFIED) { // failure with RTL HD and all SD channels
// with vaapi // with vaapi
if (frame->width > 720) if (frame->width > 720) {
color = AVCOL_SPC_BT709; color = AVCOL_SPC_BT709;
else } else {
color = AVCOL_SPC_BT470BG; color = AVCOL_SPC_BT470BG;
if (color == AVCOL_SPC_RGB) // Cuvid decoder failure with SD channels }
}
if (color == AVCOL_SPC_RGB) { // Cuvid decoder failure with SD channels
color = AVCOL_SPC_BT470BG; color = AVCOL_SPC_BT470BG;
}
frame->colorspace = color; frame->colorspace = color;
// Fix libav Color primaries failures // Fix libav Color primaries failures
if (frame->color_primaries == AVCOL_PRI_UNSPECIFIED) // failure with RTL HD and all SD channels with if (frame->color_primaries == AVCOL_PRI_UNSPECIFIED) { // failure with RTL HD and all SD channels with
// vaapi // vaapi
if (frame->width > 720) if (frame->width > 720) {
frame->color_primaries = AVCOL_PRI_BT709; frame->color_primaries = AVCOL_PRI_BT709;
else } else {
frame->color_primaries = AVCOL_PRI_BT470BG; frame->color_primaries = AVCOL_PRI_BT470BG;
}
}
if (frame->color_primaries == AVCOL_PRI_RESERVED0) // cuvid decoder failure with SD channels if (frame->color_primaries == AVCOL_PRI_RESERVED0) // cuvid decoder failure with SD channels
frame->color_primaries = AVCOL_PRI_BT470BG; frame->color_primaries = AVCOL_PRI_BT470BG;
// Fix libav Color TRC failures // Fix libav Color TRC failures
if (frame->color_trc == AVCOL_TRC_UNSPECIFIED) // failure with RTL HD and all if (frame->color_trc == AVCOL_TRC_UNSPECIFIED) { // failure with RTL HD and all
// SD channels with vaapi // SD channels with vaapi
if (frame->width > 720) if (frame->width > 720) {
frame->color_trc = AVCOL_TRC_BT709; frame->color_trc = AVCOL_TRC_BT709;
else } else {
frame->color_trc = AVCOL_TRC_SMPTE170M; frame->color_trc = AVCOL_TRC_SMPTE170M;
}
}
if (frame->color_trc == AVCOL_TRC_RESERVED0) // cuvid decoder failure with SD channels if (frame->color_trc == AVCOL_TRC_RESERVED0) // cuvid decoder failure with SD channels
frame->color_trc = AVCOL_TRC_SMPTE170M; frame->color_trc = AVCOL_TRC_SMPTE170M;
@@ -3645,10 +3646,10 @@ static void CuvidRenderFrame(CuvidDecoder *decoder, const AVCodecContext *video_
/// @param decoder CUVID hw decoder /// @param decoder CUVID hw decoder
/// ///
static void *CuvidGetHwAccelContext(CuvidDecoder *decoder) { static void *CuvidGetHwAccelContext(CuvidDecoder *decoder) {
unsigned int version, ret;
(void)decoder;
Debug(3, "Initializing cuvid hwaccel thread ID:%ld\n", (long int)syscall(186)); Debug(3, "Initializing cuvid hwaccel thread ID:%ld\n", (long int)syscall(186));
// turn NULL;
#ifdef CUVID #ifdef CUVID
if (decoder->cuda_ctx) { if (decoder->cuda_ctx) {
Debug(3, "schon passiert\n"); Debug(3, "schon passiert\n");
@@ -3656,7 +3657,7 @@ static void *CuvidGetHwAccelContext(CuvidDecoder *decoder) {
} }
if (!cu) { if (!cu) {
ret = cuda_load_functions(&cu, NULL); int ret = cuda_load_functions(&cu, NULL);
if (ret < 0) { if (ret < 0) {
Error(_("Could not dynamically load CUDA\n")); Error(_("Could not dynamically load CUDA\n"));
return 0; return 0;
@@ -3668,7 +3669,7 @@ static void *CuvidGetHwAccelContext(CuvidDecoder *decoder) {
if (decoder->cuda_ctx == NULL) if (decoder->cuda_ctx == NULL)
Fatal(_("Kein Cuda device gefunden")); Fatal(_("Kein Cuda device gefunden"));
// unsigned int version;
// cu->cuCtxGetApiVersion(decoder->cuda_ctx, &version); // cu->cuCtxGetApiVersion(decoder->cuda_ctx, &version);
// Debug(3, "***********CUDA API Version %d\n", version); // Debug(3, "***********CUDA API Version %d\n", version);
#endif #endif
@@ -3727,7 +3728,7 @@ static void CuvidAdvanceDecoderFrame(CuvidDecoder *decoder) {
#if defined PLACEBO && PL_API_VER >= 58 #if defined PLACEBO && PL_API_VER >= 58
static const struct pl_hook *parse_user_shader(char *shader) { static const struct pl_hook *parse_user_shader(char *shader) {
char tmp[200]; char tmp[400];
if (!shader) if (!shader)
return NULL; return NULL;
@@ -3790,26 +3791,23 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
struct pl_deband_params deband; struct pl_deband_params deband;
struct pl_color_adjustment colors; struct pl_color_adjustment colors;
struct pl_cone_params cone; struct pl_cone_params cone;
struct pl_tex_vk *vkp; //struct pl_tex_vk *vkp;
struct pl_plane *pl; struct pl_plane *pl;
struct pl_tex *tex0, *tex1; //struct pl_tex *tex0, *tex1;
struct pl_frame *img; struct pl_frame *img;
bool ok; //bool ok;
VdpRect video_src_rect; VdpRect video_src_rect;
VdpRect dst_rect; //VdpRect dst_rect;
VdpRect dst_video_rect; VdpRect dst_video_rect;
#endif #endif
int current; int current;
int y;
float xcropf, ycropf;
GLint texLoc;
AVFrame *frame;
AVFrameSideData *sd, *sd1 = NULL, *sd2 = NULL;
#ifdef PLACEBO #ifdef PLACEBO
#if 0
if (level) { if (level) {
dst_rect.x0 = decoder->VideoX; // video window output (clip) dst_rect.x0 = decoder->VideoX; // video window output (clip)
dst_rect.y0 = decoder->VideoY; dst_rect.y0 = decoder->VideoY;
@@ -3821,7 +3819,7 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
dst_rect.x1 = VideoWindowWidth; dst_rect.x1 = VideoWindowWidth;
dst_rect.y1 = VideoWindowHeight; dst_rect.y1 = VideoWindowHeight;
} }
#endif
video_src_rect.x0 = decoder->CropX; // video source (crop) video_src_rect.x0 = decoder->CropX; // video source (crop)
video_src_rect.y0 = decoder->CropY; video_src_rect.y0 = decoder->CropY;
video_src_rect.x1 = decoder->CropX + decoder->CropWidth; video_src_rect.x1 = decoder->CropX + decoder->CropWidth;
@@ -3833,12 +3831,13 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
dst_video_rect.y1 = decoder->OutputY + decoder->OutputHeight; dst_video_rect.y1 = decoder->OutputY + decoder->OutputHeight;
#endif #endif
xcropf = (float)decoder->CropX / (float)decoder->InputWidth;
ycropf = (float)decoder->CropY / (float)decoder->InputHeight;
current = decoder->SurfacesRb[decoder->SurfaceRead]; current = decoder->SurfacesRb[decoder->SurfaceRead];
#ifdef USE_DRM #ifdef USE_DRM
AVFrameSideData *sd, *sd1 = NULL, *sd2 = NULL;
if (!decoder->Closing) { if (!decoder->Closing) {
frame = decoder->frames[current]; frame = decoder->frames[current];
sd1 = av_frame_get_side_data(frame, AV_FRAME_DATA_MASTERING_DISPLAY_METADATA); sd1 = av_frame_get_side_data(frame, AV_FRAME_DATA_MASTERING_DISPLAY_METADATA);
@@ -3850,6 +3849,14 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
// Render Progressive frame // Render Progressive frame
#ifndef PLACEBO #ifndef PLACEBO
GLint texLoc;
int y;
float xcropf, ycropf;
xcropf = (float)decoder->CropX / (float)decoder->InputWidth;
ycropf = (float)decoder->CropY / (float)decoder->InputHeight;
y = VideoWindowHeight - decoder->OutputY - decoder->OutputHeight; y = VideoWindowHeight - decoder->OutputY - decoder->OutputHeight;
if (y < 0) if (y < 0)
y = 0; y = 0;
@@ -3888,8 +3895,7 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
else else
render_params.lut = NULL; render_params.lut = NULL;
frame = decoder->frames[current];
// Fix Color Parameters // Fix Color Parameters
switch (decoder->ColorSpace) { switch (decoder->ColorSpace) {
@@ -3972,6 +3978,9 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
// target.repr.bits.bit_shift =0; // target.repr.bits.bit_shift =0;
#if USE_DRM #if USE_DRM
AVFrame *frame;
frame = decoder->frames[current];
switch (VulkanTargetColorSpace) { switch (VulkanTargetColorSpace) {
case 0: // Monitor case 0: // Monitor
memcpy(&target->color, &pl_color_space_monitor, sizeof(struct pl_color_space)); memcpy(&target->color, &pl_color_space_monitor, sizeof(struct pl_color_space));
@@ -4100,7 +4109,11 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
render_params.downscaler = pl_filter_presets[VideoScaling[decoder->Resolution]].filter; render_params.downscaler = pl_filter_presets[VideoScaling[decoder->Resolution]].filter;
if (level) if (level)
#if PL_API_VER < 346
render_params.skip_target_clearing = 1; render_params.skip_target_clearing = 1;
#else
render_params.border = PL_CLEAR_SKIP;
#endif
render_params.color_adjustment = &colors; render_params.color_adjustment = &colors;
@@ -4196,7 +4209,11 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
// render_params.lut = NULL; // render_params.lut = NULL;
render_params.num_hooks = 0; render_params.num_hooks = 0;
#if PL_API_VER < 346
render_params.skip_target_clearing = 1; render_params.skip_target_clearing = 1;
#else
render_params.border = PL_CLEAR_SKIP;
#endif
if (!p->renderertest) if (!p->renderertest)
p->renderertest = pl_renderer_create(p->ctx, p->gpu); p->renderertest = pl_renderer_create(p->ctx, p->gpu);
@@ -4209,7 +4226,7 @@ static void CuvidMixVideo(CuvidDecoder *decoder, __attribute__((unused)) int lev
p->renderertest = NULL; p->renderertest = NULL;
} }
#endif #endif
Debug(4, "video/cuvid: yy video surface %p displayed\n", current, decoder->SurfaceRead);
} }
#ifdef PLACEBO #ifdef PLACEBO
@@ -4217,7 +4234,7 @@ void make_osd_overlay(int x, int y, int width, int height) {
const struct pl_fmt *fmt; const struct pl_fmt *fmt;
struct pl_overlay *pl; struct pl_overlay *pl;
int offset = VideoWindowHeight - (VideoWindowHeight - height - y) - (VideoWindowHeight - y);
fmt = pl_find_named_fmt(p->gpu, "rgba8"); // 8 Bit RGB fmt = pl_find_named_fmt(p->gpu, "rgba8"); // 8 Bit RGB
@@ -4282,7 +4299,7 @@ void make_osd_overlay(int x, int y, int width, int height) {
pl->rect.x1 = x + width; pl->rect.x1 = x + width;
pl->rect.y0 = VideoWindowHeight - height - y; pl->rect.y0 = VideoWindowHeight - height - y;
#else #else
int offset = VideoWindowHeight - (VideoWindowHeight - height - y) - (VideoWindowHeight - y);
pl->rect.x0 = x; pl->rect.x0 = x;
pl->rect.y0 = VideoWindowHeight - y + offset; // Boden von oben pl->rect.y0 = VideoWindowHeight - y + offset; // Boden von oben
pl->rect.x1 = x + width; pl->rect.x1 = x + width;
@@ -4297,6 +4314,7 @@ void make_osd_overlay(int x, int y, int width, int height) {
part.dst.x1 = x + width; part.dst.x1 = x + width;
part.dst.y0 = VideoWindowHeight - height - y; part.dst.y0 = VideoWindowHeight - height - y;
#else #else
int offset = VideoWindowHeight - (VideoWindowHeight - height - y) - (VideoWindowHeight - y);
part.dst.x0 = x; part.dst.x0 = x;
part.dst.y0 = VideoWindowHeight - y + offset; // Boden von oben part.dst.y0 = VideoWindowHeight - y + offset; // Boden von oben
part.dst.x1 = x + width; part.dst.x1 = x + width;
@@ -4311,30 +4329,33 @@ void make_osd_overlay(int x, int y, int width, int height) {
static void CuvidDisplayFrame(void) { static void CuvidDisplayFrame(void) {
static uint64_t first_time = 0, round_time = 0;
static uint64_t last_time = 0;
int i; int i;
#if defined PLACEBO_GL || defined CUVID
static uint64_t round_time = 0;
//static uint64_t first_time = 0;
#endif
int filled; int filled;
CuvidDecoder *decoder; CuvidDecoder *decoder;
int RTS_flag;
int valid_frame = 0;
float ldiff;
float turnaround;
#ifdef PLACEBO #ifdef PLACEBO
uint64_t diff; //uint64_t diff;
static float fdiff = 23000.0; //static float fdiff = 23000.0;
struct pl_swapchain_frame frame; struct pl_swapchain_frame frame;
struct pl_frame target; struct pl_frame target;
bool ok; //bool ok;
const struct pl_fmt *fmt; //const struct pl_fmt *fmt;
const float black[4] = {0.0f, 0.0f, 0.0f, 1.0f}; //const float black[4] = {0.0f, 0.0f, 0.0f, 1.0f};
#else
int valid_frame = 0;
#endif #endif
#ifndef PLACEBO #ifndef PLACEBO
static uint64_t last_time = 0;
if (CuvidDecoderN) if (CuvidDecoderN)
CuvidDecoders[0]->Frameproc = (float)(GetusTicks() - last_time) / 1000000.0; CuvidDecoders[0]->Frameproc = (float)(GetusTicks() - last_time) / 1000000.0;
@@ -4370,7 +4391,7 @@ static void CuvidDisplayFrame(void) {
#endif #endif
if (CuvidDecoderN) { if (CuvidDecoderN) {
ldiff = (float)(GetusTicks() - round_time) / 1000000.0; float ldiff = (float)(GetusTicks() - round_time) / 1000000.0;
if (ldiff < 100.0 && ldiff > 0.0) if (ldiff < 100.0 && ldiff > 0.0)
CuvidDecoders[0]->Frameproc = (CuvidDecoders[0]->Frameproc + ldiff + ldiff) / 3.0; CuvidDecoders[0]->Frameproc = (CuvidDecoders[0]->Frameproc + ldiff + ldiff) / 3.0;
} }
@@ -4384,7 +4405,7 @@ static void CuvidDisplayFrame(void) {
VideoThreadLock(); VideoThreadLock();
#endif #endif
last_time = GetusTicks(); //last_time = GetusTicks();
while (!pl_swapchain_start_frame(p->swapchain, &frame)) { // get new frame wait for previous to swap while (!pl_swapchain_start_frame(p->swapchain, &frame)) { // get new frame wait for previous to swap
usleep(5); usleep(5);
@@ -4439,7 +4460,7 @@ static void CuvidDisplayFrame(void) {
} }
continue; continue;
} }
valid_frame = 1;
#ifdef PLACEBO #ifdef PLACEBO
//pthread_mutex_lock(&OSDMutex); //pthread_mutex_lock(&OSDMutex);
if (OsdShown == 1) { // New OSD opened if (OsdShown == 1) { // New OSD opened
@@ -4467,6 +4488,7 @@ static void CuvidDisplayFrame(void) {
} }
//pthread_mutex_unlock(&OSDMutex); //pthread_mutex_unlock(&OSDMutex);
#else #else
valid_frame = 1;
CuvidMixVideo(decoder, i); CuvidMixVideo(decoder, i);
#endif #endif
if (i == 0 && decoder->grab) { // Grab frame if (i == 0 && decoder->grab) { // Grab frame
@@ -4583,7 +4605,7 @@ static void CuvidDisplayFrame(void) {
} }
#ifdef PLACEBO_GL #ifdef PLACEBO_GL
CuvidSwapBuffer() { void CuvidSwapBuffer() {
#ifndef USE_DRM #ifndef USE_DRM
eglSwapBuffers(eglDisplay, eglSurface); eglSwapBuffers(eglDisplay, eglSurface);
// eglMakeCurrent(eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, // eglMakeCurrent(eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE,
@@ -4699,7 +4721,6 @@ static void CuvidSyncDecoder(CuvidDecoder *decoder) {
int filled; int filled;
int64_t audio_clock; int64_t audio_clock;
int64_t video_clock; int64_t video_clock;
int err = 0;
static int speedup = 3; static int speedup = 3;
#ifdef GAMMA #ifdef GAMMA
@@ -4767,14 +4788,14 @@ static void CuvidSyncDecoder(CuvidDecoder *decoder) {
} }
#endif #endif
if (abs(diff) > 5000 * 90) { // more than 5s if (abs(diff) > 5000 * 90) { // more than 5s
err = CuvidMessage(2, "video: audio/video difference too big %d\n", diff / 90); CuvidMessage(2, "video: audio/video difference too big %d\n", diff / 90);
// decoder->SyncCounter = 1; // decoder->SyncCounter = 1;
// usleep(10); // usleep(10);
goto skip_sync; goto skip_sync;
} else if (diff > 100 * 90) { } else if (diff > 100 * 90) {
err = CuvidMessage(4, "video: slow down video, duping frame %d\n", diff / 90); CuvidMessage(4, "video: slow down video, duping frame %d\n", diff / 90);
++decoder->FramesDuped; ++decoder->FramesDuped;
if ((speedup && --speedup) || VideoSoftStartSync) if ((speedup && --speedup) || VideoSoftStartSync)
decoder->SyncCounter = 1; decoder->SyncCounter = 1;
@@ -4783,13 +4804,13 @@ static void CuvidSyncDecoder(CuvidDecoder *decoder) {
goto out; goto out;
} else if (diff > 25 * 90) { } else if (diff > 25 * 90) {
err = CuvidMessage(3, "video: slow down video, duping frame %d \n", diff / 90); CuvidMessage(3, "video: slow down video, duping frame %d \n", diff / 90);
++decoder->FramesDuped; ++decoder->FramesDuped;
decoder->SyncCounter = 1; decoder->SyncCounter = 1;
goto out; goto out;
} else if ((diff < -100 * 90)) { } else if ((diff < -100 * 90)) {
if (filled > 2) { if (filled > 2) {
err = CuvidMessage(3, "video: speed up video, droping frame %d\n", diff / 90); CuvidMessage(3, "video: speed up video, droping frame %d\n", diff / 90);
++decoder->FramesDropped; ++decoder->FramesDropped;
CuvidAdvanceDecoderFrame(decoder); CuvidAdvanceDecoderFrame(decoder);
} else if ((diff < -100 * 90)) { // give it some time to get frames to drop } else if ((diff < -100 * 90)) { // give it some time to get frames to drop
@@ -5279,7 +5300,7 @@ void VideoOsdDrawARGB(int xi, int yi, int width, int height, int pitch, const ui
} }
Debug(3, "video: osd dirty %dx%d%+d%+d -> %dx%d%+d%+d\n", width, height, x, y, OsdDirtyWidth, OsdDirtyHeight, Debug(3, "video: osd dirty %dx%d%+d%+d -> %dx%d%+d%+d\n", width, height, x, y, OsdDirtyWidth, OsdDirtyHeight,
OsdDirtyX, OsdDirtyY); OsdDirtyX, OsdDirtyY);
Debug(4," dummy print %d %d %d %s",xi,yi,pitch,argb);
VideoThreadUnlock(); VideoThreadUnlock();
} }
@@ -5583,7 +5604,7 @@ void pl_log_intern(void *stream, enum pl_log_level level, const char *msg) {
[PL_LOG_FATAL] = "fatal", [PL_LOG_ERR] = "error", [PL_LOG_WARN] = "warn", [PL_LOG_FATAL] = "fatal", [PL_LOG_ERR] = "error", [PL_LOG_WARN] = "warn",
[PL_LOG_INFO] = "info", [PL_LOG_DEBUG] = "debug", [PL_LOG_TRACE] = "trace", [PL_LOG_INFO] = "info", [PL_LOG_DEBUG] = "debug", [PL_LOG_TRACE] = "trace",
}; };
(void)stream;
printf("%5s: %s\n", prefix[level], msg); printf("%5s: %s\n", prefix[level], msg);
} }
@@ -5693,7 +5714,8 @@ void InitPlacebo() {
if (!p->swapchain) { if (!p->swapchain) {
Fatal(_("Failed creating vulkan swapchain!")); Fatal(_("Failed creating vulkan swapchain!"));
} }
#ifdef VAAPI
if (!(p->gpu->import_caps.tex & PL_HANDLE_DMA_BUF)) { if (!(p->gpu->import_caps.tex & PL_HANDLE_DMA_BUF)) {
p->has_dma_buf = 0; p->has_dma_buf = 0;
Debug(3, "No support for dma_buf import \n"); Debug(3, "No support for dma_buf import \n");
@@ -5701,16 +5723,20 @@ void InitPlacebo() {
p->has_dma_buf = 1; p->has_dma_buf = 1;
Debug(3, "dma_buf support available\n"); Debug(3, "dma_buf support available\n");
} }
#else
p->has_dma_buf = 0;
Debug(3, "No support for dma_buf import \n");
#endif
#ifdef PLACEBO_GL #ifdef PLACEBO_GL
if (!pl_swapchain_resize(p->swapchain, &VideoWindowWidth, &VideoWindowHeight)) { if (!pl_swapchain_resize(p->swapchain, (int *)&VideoWindowWidth, (int *)&VideoWindowHeight)) {
Fatal(_("libplacebo: failed initializing swapchain\n")); Fatal(_("libplacebo: failed initializing swapchain\n"));
} }
#endif #endif
#if PL_API_VER >= 113 #if PL_API_VER >= 113
// load LUT File // load LUT File
struct file lutf; struct file lutf;
char tmp[200]; char tmp[400];
sprintf(tmp, "%s/%s", MyConfigDir, lut_file); sprintf(tmp, "%s/%s", MyConfigDir, lut_file);
if (open_file(tmp, &lutf) && lutf.size) { if (open_file(tmp, &lutf) && lutf.size) {
@@ -5816,10 +5842,9 @@ void exit_display() {
} }
static void *VideoHandlerThread(void *dummy) { static void *VideoHandlerThread(void *dummy) {
#ifdef VAAPI #if defined VAAPI && !defined PLACEBO_GL
EGLint contextAttrs[] = {EGL_CONTEXT_CLIENT_VERSION, 3, EGL_NONE}; EGLint contextAttrs[] = {EGL_CONTEXT_CLIENT_VERSION, 3, EGL_NONE};
#endif #endif
int redSize, greenSize, blueSize, alphaSize;
prctl(PR_SET_NAME, "video display", 0, 0, 0); prctl(PR_SET_NAME, "video display", 0, 0, 0);
@@ -6583,13 +6608,13 @@ int VideoSetShader(char *s) {
#if defined PLACEBO && PL_API_VER >= 58 #if defined PLACEBO && PL_API_VER >= 58
if (num_shaders == NUM_SHADERS) if (num_shaders == NUM_SHADERS)
return -1; return -1;
p = malloc(strlen(s) + 1); char *p = malloc(strlen(s) + 1);
memcpy(p, s, strlen(s) + 1); memcpy(p, s, strlen(s) + 1);
shadersp[num_shaders++] = p; shadersp[num_shaders++] = p;
CuvidMessage(2, "Use Shader %s\n", s); CuvidMessage(2, "Use Shader %s\n", s);
return 0; return 0;
#else #else
printf("Shaders are only support with placebo\n"); printf("Shaders are only support with placebo (%s)\n",s);
return -1; return -1;
#endif #endif
} }
@@ -6905,7 +6930,8 @@ void VideoSetAbove() {
/// ///
/// Set deinterlace mode. /// Set deinterlace mode.
/// ///
void VideoSetDeinterlace(int mode[VideoResolutionMax]) { void VideoSetDeinterlace(int mode[]) {
#ifdef CUVID #ifdef CUVID
VideoDeinterlace[0] = mode[0]; // 576i VideoDeinterlace[0] = mode[0]; // 576i
VideoDeinterlace[1] = 0; // mode[1]; // 720p VideoDeinterlace[1] = 0; // mode[1]; // 720p
@@ -6913,6 +6939,7 @@ void VideoSetDeinterlace(int mode[VideoResolutionMax]) {
VideoDeinterlace[3] = mode[3]; // 1080 VideoDeinterlace[3] = mode[3]; // 1080
VideoDeinterlace[4] = 0; // mode[4]; 2160p VideoDeinterlace[4] = 0; // mode[4]; 2160p
#else #else
(void)mode;
VideoDeinterlace[0] = 1; // 576i VideoDeinterlace[0] = 1; // 576i
VideoDeinterlace[1] = 0; // mode[1]; // 720p VideoDeinterlace[1] = 0; // mode[1]; // 720p
VideoDeinterlace[2] = 1; // fake 1080 VideoDeinterlace[2] = 1; // fake 1080
@@ -6925,7 +6952,7 @@ void VideoSetDeinterlace(int mode[VideoResolutionMax]) {
/// ///
/// Set skip chroma deinterlace on/off. /// Set skip chroma deinterlace on/off.
/// ///
void VideoSetSkipChromaDeinterlace(int onoff[VideoResolutionMax]) { void VideoSetSkipChromaDeinterlace(int onoff[]) {
VideoSkipChromaDeinterlace[0] = onoff[0]; VideoSkipChromaDeinterlace[0] = onoff[0];
VideoSkipChromaDeinterlace[1] = onoff[1]; VideoSkipChromaDeinterlace[1] = onoff[1];
VideoSkipChromaDeinterlace[2] = onoff[2]; VideoSkipChromaDeinterlace[2] = onoff[2];
@@ -6937,7 +6964,7 @@ void VideoSetSkipChromaDeinterlace(int onoff[VideoResolutionMax]) {
/// ///
/// Set inverse telecine on/off. /// Set inverse telecine on/off.
/// ///
void VideoSetInverseTelecine(int onoff[VideoResolutionMax]) { void VideoSetInverseTelecine(int onoff[]) {
VideoInverseTelecine[0] = onoff[0]; VideoInverseTelecine[0] = onoff[0];
VideoInverseTelecine[1] = onoff[1]; VideoInverseTelecine[1] = onoff[1];
VideoInverseTelecine[2] = onoff[2]; VideoInverseTelecine[2] = onoff[2];
@@ -6949,7 +6976,7 @@ void VideoSetInverseTelecine(int onoff[VideoResolutionMax]) {
/// ///
/// Set denoise level (0 .. 1000). /// Set denoise level (0 .. 1000).
/// ///
void VideoSetDenoise(int level[VideoResolutionMax]) { void VideoSetDenoise(int level[]) {
VideoDenoise[0] = level[0]; VideoDenoise[0] = level[0];
VideoDenoise[1] = level[1]; VideoDenoise[1] = level[1];
VideoDenoise[2] = level[2]; VideoDenoise[2] = level[2];
@@ -6961,7 +6988,7 @@ void VideoSetDenoise(int level[VideoResolutionMax]) {
/// ///
/// Set sharpness level (-1000 .. 1000). /// Set sharpness level (-1000 .. 1000).
/// ///
void VideoSetSharpen(int level[VideoResolutionMax]) { void VideoSetSharpen(int level[]) {
VideoSharpen[0] = level[0]; VideoSharpen[0] = level[0];
VideoSharpen[1] = level[1]; VideoSharpen[1] = level[1];
VideoSharpen[2] = level[2]; VideoSharpen[2] = level[2];
@@ -6975,7 +7002,7 @@ void VideoSetSharpen(int level[VideoResolutionMax]) {
/// ///
/// @param mode table with VideoResolutionMax values /// @param mode table with VideoResolutionMax values
/// ///
void VideoSetScaling(int mode[VideoResolutionMax]) { void VideoSetScaling(int mode[]) {
VideoScaling[0] = mode[0]; VideoScaling[0] = mode[0];
VideoScaling[1] = mode[1]; VideoScaling[1] = mode[1];
VideoScaling[2] = mode[2]; VideoScaling[2] = mode[2];
@@ -6989,7 +7016,7 @@ void VideoSetScaling(int mode[VideoResolutionMax]) {
/// ///
/// @param pixels table with VideoResolutionMax values /// @param pixels table with VideoResolutionMax values
/// ///
void VideoSetCutTopBottom(int pixels[VideoResolutionMax]) { void VideoSetCutTopBottom(int pixels[]) {
VideoCutTopBottom[0] = pixels[0]; VideoCutTopBottom[0] = pixels[0];
VideoCutTopBottom[1] = pixels[1]; VideoCutTopBottom[1] = pixels[1];
VideoCutTopBottom[2] = pixels[2]; VideoCutTopBottom[2] = pixels[2];
@@ -7003,7 +7030,7 @@ void VideoSetCutTopBottom(int pixels[VideoResolutionMax]) {
/// ///
/// @param pixels table with VideoResolutionMax values /// @param pixels table with VideoResolutionMax values
/// ///
void VideoSetCutLeftRight(int pixels[VideoResolutionMax]) { void VideoSetCutLeftRight(int pixels[]) {
VideoCutLeftRight[0] = pixels[0]; VideoCutLeftRight[0] = pixels[0];
VideoCutLeftRight[1] = pixels[1]; VideoCutLeftRight[1] = pixels[1];
VideoCutLeftRight[2] = pixels[2]; VideoCutLeftRight[2] = pixels[2];