mirror of
				https://github.com/jojo61/vdr-plugin-softhdcuvid.git
				synced 2025-03-01 10:39:28 +00:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 230bb5ca11 | ||
|  | f026e8e86d | ||
|  | 9dd936df86 | ||
|  | 4e5529efcf | 
							
								
								
									
										110
									
								
								codec.c
									
									
									
									
									
								
							
							
						
						
									
										110
									
								
								codec.c
									
									
									
									
									
								
							| @@ -125,7 +125,7 @@ struct _video_decoder_ | ||||
| */ | ||||
| static enum AVPixelFormat Codec_get_format(AVCodecContext *video_ctx, const enum AVPixelFormat *fmt) { | ||||
|     VideoDecoder *decoder; | ||||
|     enum AVPixelFormat fmt1; | ||||
|  | ||||
|  | ||||
|     decoder = video_ctx->opaque; | ||||
|     // bug in ffmpeg 1.1.1, called with zero width or height | ||||
| @@ -389,15 +389,19 @@ void CodecVideoClose(VideoDecoder *video_decoder) { | ||||
|     Debug(3, "CodecVideoClose\n"); | ||||
|     if (video_decoder->VideoCtx) { | ||||
|         pthread_mutex_lock(&CodecLockMutex); | ||||
| #if 1 | ||||
|  | ||||
|         frame = av_frame_alloc(); | ||||
|         avcodec_send_packet(video_decoder->VideoCtx, NULL); | ||||
|         while (avcodec_receive_frame(video_decoder->VideoCtx, frame) >= 0) | ||||
|             ; | ||||
|         av_frame_free(&frame); | ||||
|  | ||||
| #if LIBAVUTIL_VERSION_INT < AV_VERSION_INT(55,63,100) | ||||
| 	    avcodec_close(video_decoder->VideoCtx); | ||||
| 	    av_freep(&video_decoder->VideoCtx); | ||||
| #else | ||||
| 	    avcodec_free_context(&video_decoder->VideoCtx); | ||||
| #endif | ||||
|         avcodec_close(video_decoder->VideoCtx); | ||||
|         av_freep(&video_decoder->VideoCtx); | ||||
|         pthread_mutex_unlock(&CodecLockMutex); | ||||
|     } | ||||
| } | ||||
| @@ -513,7 +517,7 @@ void CodecVideoDecode(VideoDecoder *decoder, const AVPacket *avpkt) { | ||||
|     int ret, ret1; | ||||
|     int got_frame; | ||||
|     int consumed = 0; | ||||
|     static uint64_t first_time = 0; | ||||
|     //static uint64_t first_time = 0; | ||||
|     const AVPacket *pkt; | ||||
|  | ||||
| next_part: | ||||
| @@ -541,7 +545,7 @@ next_part: | ||||
|             frame = av_frame_alloc(); | ||||
|             ret = avcodec_receive_frame(video_ctx, frame); // get new frame | ||||
|             if (ret >= 0) {                                // one is avail. | ||||
|             first_time = frame->pts; | ||||
|                 //first_time = frame->pts; | ||||
|                 got_frame = 1; | ||||
|             } else { | ||||
|                 got_frame = 0; | ||||
| @@ -755,8 +759,12 @@ void CodecAudioClose(AudioDecoder *audio_decoder) { | ||||
|     } | ||||
|     if (audio_decoder->AudioCtx) { | ||||
|         pthread_mutex_lock(&CodecLockMutex); | ||||
|         avcodec_close(audio_decoder->AudioCtx); | ||||
|         av_freep(&audio_decoder->AudioCtx); | ||||
| #if LIBAVUTIL_VERSION_INT < AV_VERSION_INT(55,63,100) | ||||
| 	    avcodec_close(audio_decoder->AudioCtx); | ||||
| 	    av_freep(&audio_decoder->AudioCtx); | ||||
| #else | ||||
| 	    avcodec_free_context(&audio_decoder->AudioCtx); | ||||
| #endif | ||||
|         pthread_mutex_unlock(&CodecLockMutex); | ||||
|     } | ||||
| } | ||||
| @@ -868,19 +876,35 @@ static int CodecAudioUpdateHelper(AudioDecoder *audio_decoder, int *passthrough) | ||||
|     int err; | ||||
|  | ||||
|     audio_ctx = audio_decoder->AudioCtx; | ||||
|     Debug(3, "codec/audio: Chanlayout %lx format change %s %dHz *%d channels%s%s%s%s%s\n",audio_ctx->channel_layout, | ||||
|           av_get_sample_fmt_name(audio_ctx->sample_fmt), audio_ctx->sample_rate, audio_ctx->channels, | ||||
|           CodecPassthrough & CodecPCM ? " PCM" : "", CodecPassthrough & CodecMPA ? " MPA" : "", | ||||
|           CodecPassthrough & CodecAC3 ? " AC-3" : "", CodecPassthrough & CodecEAC3 ? " E-AC-3" : "", | ||||
|           CodecPassthrough ? " pass-through" : ""); | ||||
|      | ||||
|   | ||||
|     Debug(3, "codec/audio: format change %s %dHz *%d channels%s%s%s%s%s%s\n", | ||||
| 	av_get_sample_fmt_name(audio_ctx->sample_fmt), audio_ctx->sample_rate, | ||||
| #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,24,100) | ||||
| 	audio_ctx->channels, CodecPassthrough & CodecPCM ? " PCM" : "", | ||||
| #else | ||||
| 	audio_ctx->ch_layout.nb_channels, CodecPassthrough & CodecPCM ? " PCM" : "", | ||||
| #endif | ||||
| 	CodecPassthrough & CodecMPA ? " MPA" : "", | ||||
| 	CodecPassthrough & CodecAC3 ? " AC-3" : "", | ||||
| 	CodecPassthrough & CodecEAC3 ? " E-AC-3" : "", | ||||
| 	CodecPassthrough & CodecDTS ? " DTS" : "", | ||||
| 	CodecPassthrough ? " pass-through" : ""); | ||||
|  | ||||
|  | ||||
|     *passthrough = 0; | ||||
|     audio_decoder->SampleRate = audio_ctx->sample_rate; | ||||
|     audio_decoder->HwSampleRate = audio_ctx->sample_rate; | ||||
| #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,24,100) | ||||
|     audio_decoder->Channels = audio_ctx->channels; | ||||
|     audio_decoder->HwChannels = CodecDownmix ? 2 : audio_ctx->channels; | ||||
|     audio_decoder->Passthrough = CodecPassthrough; | ||||
|     audio_decoder->HwChannels = audio_ctx->channels; | ||||
| #else | ||||
|     audio_decoder->Channels = audio_ctx->ch_layout.nb_channels; | ||||
|     audio_decoder->HwChannels = audio_ctx->ch_layout.nb_channels; | ||||
| #endif | ||||
|     if (CodecDownmix && !CodecPassthrough) audio_decoder->HwChannels = 2; | ||||
|  | ||||
|     audio_decoder->Passthrough = CodecPassthrough; | ||||
|     // SPDIF/HDMI pass-through | ||||
|     if ((CodecPassthrough & CodecAC3 && audio_ctx->codec_id == AV_CODEC_ID_AC3) || | ||||
|         (CodecPassthrough & CodecEAC3 && audio_ctx->codec_id == AV_CODEC_ID_EAC3)) { | ||||
| @@ -909,9 +933,15 @@ static int CodecAudioUpdateHelper(AudioDecoder *audio_decoder, int *passthrough) | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     Debug(3, "codec/audio: resample %s %dHz *%d -> %s %dHz *%d\n", av_get_sample_fmt_name(audio_ctx->sample_fmt), | ||||
|           audio_ctx->sample_rate, audio_ctx->channels, av_get_sample_fmt_name(AV_SAMPLE_FMT_S16), | ||||
|           audio_decoder->HwSampleRate, audio_decoder->HwChannels); | ||||
|     Debug(3, "codec/audio: resample %s %dHz *%d -> %s %dHz *%d\n", | ||||
| 	    av_get_sample_fmt_name(audio_ctx->sample_fmt), audio_ctx->sample_rate, | ||||
| #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,24,100) | ||||
| 	    audio_ctx->channels, av_get_sample_fmt_name(AV_SAMPLE_FMT_S16), | ||||
| #else | ||||
| 	    audio_ctx->ch_layout.nb_channels, av_get_sample_fmt_name(AV_SAMPLE_FMT_S16), | ||||
| #endif | ||||
| 	    audio_decoder->HwSampleRate, audio_decoder->HwChannels); | ||||
|  | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
| @@ -1140,6 +1170,12 @@ static void CodecAudioUpdateFormat(AudioDecoder *audio_decoder) { | ||||
|     int passthrough; | ||||
|     const AVCodecContext *audio_ctx; | ||||
|  | ||||
| #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,24,100) | ||||
|     int64_t dmlayout = AV_CH_LAYOUT_STEREO; | ||||
| #else | ||||
|     AVChannelLayout dmlayout = AV_CHANNEL_LAYOUT_STEREO; | ||||
| #endif | ||||
|  | ||||
|     if (CodecAudioUpdateHelper(audio_decoder, &passthrough)) { | ||||
|         // FIXME: handle swresample format conversions. | ||||
|         return; | ||||
| @@ -1150,6 +1186,12 @@ static void CodecAudioUpdateFormat(AudioDecoder *audio_decoder) { | ||||
|  | ||||
|     audio_ctx = audio_decoder->AudioCtx; | ||||
|  | ||||
| #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,24,100) | ||||
|     if (!CodecDownmix || CodecPassthrough) dmlayout = audio_ctx->channel_layout; | ||||
| #else | ||||
|     if (!CodecDownmix || CodecPassthrough) dmlayout = audio_ctx->ch_layout; | ||||
| #endif | ||||
|  | ||||
| #ifdef DEBUG | ||||
|     if (audio_ctx->sample_fmt == AV_SAMPLE_FMT_S16 && audio_ctx->sample_rate == audio_decoder->HwSampleRate && | ||||
|         !CodecAudioDrift) { | ||||
| @@ -1157,27 +1199,23 @@ static void CodecAudioUpdateFormat(AudioDecoder *audio_decoder) { | ||||
|         fprintf(stderr, "no resample needed\n"); | ||||
|     } | ||||
| #endif | ||||
|  | ||||
|      | ||||
| #if LIBSWRESAMPLE_VERSION_INT < AV_VERSION_INT(4,5,100) | ||||
|         audio_decoder->Resample = swr_alloc_set_opts(audio_decoder->Resample,  | ||||
|                                     CodecDownmix ? AV_CH_LAYOUT_STEREO : audio_ctx->channel_layout, | ||||
|                                     AV_SAMPLE_FMT_S16, audio_decoder->HwSampleRate, | ||||
| 	                                audio_ctx->channel_layout, audio_ctx->sample_fmt,audio_ctx->sample_rate, | ||||
|                                     0, NULL); | ||||
|     audio_decoder->Resample = | ||||
|         swr_alloc_set_opts(audio_decoder->Resample, dmlayout, | ||||
|         AV_SAMPLE_FMT_S16, audio_decoder->HwSampleRate, | ||||
|         audio_ctx->channel_layout, audio_ctx->sample_fmt, | ||||
| #else | ||||
|     //printf("last ressort downmix Layout in %lx Lyout out: %llx \n",audio_ctx->channel_layout,AV_CH_LAYOUT_STEREO); | ||||
|         audio_decoder->Resample = swr_alloc(); | ||||
|         av_opt_set_channel_layout(audio_decoder->Resample, "in_channel_layout",audio_ctx->channel_layout, 0); | ||||
|         av_opt_set_channel_layout(audio_decoder->Resample, "out_channel_layout", CodecDownmix ? AV_CH_LAYOUT_STEREO : audio_ctx->channel_layout ,  0); | ||||
|         av_opt_set_int(audio_decoder->Resample, "in_sample_rate",     audio_ctx->sample_rate,                0); | ||||
|         av_opt_set_int(audio_decoder->Resample, "out_sample_rate",    audio_ctx->sample_rate,                0); | ||||
|         av_opt_set_sample_fmt(audio_decoder->Resample, "in_sample_fmt",  audio_ctx->sample_fmt, 0); | ||||
|         av_opt_set_sample_fmt(audio_decoder->Resample, "out_sample_fmt", AV_SAMPLE_FMT_S16,  0); | ||||
|         swr_alloc_set_opts2(&audio_decoder->Resample, &dmlayout, | ||||
|         AV_SAMPLE_FMT_S16, audio_decoder->HwSampleRate, | ||||
|         &audio_ctx->ch_layout, audio_ctx->sample_fmt, | ||||
| #endif | ||||
| 	   audio_ctx->sample_rate, 0, NULL);  | ||||
|  | ||||
|     if (audio_decoder->Resample) { | ||||
| 	    swr_init(audio_decoder->Resample); | ||||
| 	swr_init(audio_decoder->Resample); | ||||
|     } else { | ||||
| 	    Error(_("codec/audio: can't setup resample\n")); | ||||
| 	Error(_("codec/audio: can't setup resample\n")); | ||||
|     } | ||||
|  | ||||
|  | ||||
| @@ -1223,7 +1261,11 @@ void CodecAudioDecode(AudioDecoder *audio_decoder, const AVPacket *avpkt) { | ||||
|             // format change | ||||
|             if (audio_decoder->Passthrough != CodecPassthrough || | ||||
|                 audio_decoder->SampleRate != audio_ctx->sample_rate || | ||||
| #if LIBAVCODEC_VERSION_INT < AV_VERSION_INT(59,24,100) | ||||
|                 audio_decoder->Channels != audio_ctx->channels) { | ||||
| #else | ||||
|                 audio_decoder->Channels != audio_ctx->ch_layout.nb_channels) { | ||||
| #endif | ||||
|                 CodecAudioUpdateFormat(audio_decoder); | ||||
|             } | ||||
|             if (!audio_decoder->HwSampleRate || !audio_decoder->HwChannels) { | ||||
|   | ||||
| @@ -61,7 +61,7 @@ extern void ToggleLUT(); | ||||
| /// vdr-plugin version number. | ||||
| /// Makefile extracts the version number for generating the file name | ||||
| /// for the distribution archive. | ||||
| static const char *const VERSION = "3.22" | ||||
| static const char *const VERSION = "3.24" | ||||
| #ifdef GIT_REV | ||||
|                                    "-GIT" GIT_REV | ||||
| #endif | ||||
|   | ||||
							
								
								
									
										16
									
								
								video.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								video.c
									
									
									
									
									
								
							| @@ -1258,19 +1258,17 @@ static void EglExit(void) { | ||||
|         EglCheck(); | ||||
|         eglSurface = NULL; | ||||
|     } | ||||
|      | ||||
|     if (eglContext) { | ||||
|         eglDestroyContext(eglDisplay, eglContext); | ||||
|         EglCheck(); | ||||
|         eglContext = NULL; | ||||
|     } | ||||
|     if (eglSharedContext) { | ||||
|         eglDestroyContext(eglDisplay, eglSharedContext); | ||||
|         EglCheck(); | ||||
|         eglSharedContext = NULL; | ||||
|     } | ||||
|  | ||||
|      | ||||
|     if (eglContext) { | ||||
|         eglDestroyContext(eglDisplay, eglContext); | ||||
|         EglCheck(); | ||||
|         eglContext = NULL; | ||||
|     } | ||||
|     eglTerminate(eglDisplay); | ||||
|     eglDisplay = NULL; | ||||
|  | ||||
| @@ -2287,7 +2285,7 @@ void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsig | ||||
|                                &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( | ||||
|                     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, | ||||
| @@ -2299,7 +2297,7 @@ void createTextureDst(CuvidDecoder *decoder, int anz, unsigned int size_x, unsig | ||||
|                         .export_handle = PL_HANDLE_FD, | ||||
| #endif | ||||
|                     }); | ||||
|             } | ||||
|             //} | ||||
|  | ||||
|             // make planes for image | ||||
|             pl = &decoder->pl_frames[i].planes[n]; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user