diff options
-rw-r--r-- | libhb/common.c | 12 | ||||
-rw-r--r-- | libhb/common.h | 9 | ||||
-rw-r--r-- | libhb/cropscale.c | 2 | ||||
-rw-r--r-- | libhb/decavcodec.c | 18 | ||||
-rw-r--r-- | libhb/scan.c | 8 | ||||
-rw-r--r-- | libhb/stream.c | 34 | ||||
-rw-r--r-- | libhb/work.c | 27 | ||||
-rw-r--r-- | test/test.c | 5 |
8 files changed, 54 insertions, 61 deletions
diff --git a/libhb/common.c b/libhb/common.c index 8cc1dc65d..526ee7874 100644 --- a/libhb/common.c +++ b/libhb/common.c @@ -4532,15 +4532,3 @@ void hb_hexdump( hb_debug_level_t level, const char * label, const uint8_t * dat hb_deep_log( level, " %-50s%20s", line, ascii ); } } - -int hb_use_dxva( hb_title_t * title ) -{ - return ( (title->video_codec_param == AV_CODEC_ID_MPEG2VIDEO - || title->video_codec_param == AV_CODEC_ID_H264 - || title->video_codec_param == AV_CODEC_ID_VC1 - || title->video_codec_param == AV_CODEC_ID_WMV3 - || title->video_codec_param == AV_CODEC_ID_MPEG4 - || title->video_codec_param == AV_CODEC_ID_HEVC ) - && title->opaque_priv ); -} - diff --git a/libhb/common.h b/libhb/common.h index 14faa31fd..a96a3e4e7 100644 --- a/libhb/common.h +++ b/libhb/common.h @@ -962,8 +962,9 @@ struct hb_title_s // additional supported video decoders (e.g. HW-accelerated implementations) int video_decode_support; -#define HB_DECODE_SUPPORT_SW 0x01 // software (libavcodec or mpeg2dec) -#define HB_DECODE_SUPPORT_QSV 0x02 // Intel Quick Sync Video +#define HB_DECODE_SUPPORT_SW 0x01 // software (libavcodec or mpeg2dec) +#define HB_DECODE_SUPPORT_QSV 0x02 // Intel Quick Sync Video +#define HB_DECODE_SUPPORT_DXVA2 0x04 // Microsoft DXVA2 hb_metadata_t * metadata; @@ -979,7 +980,6 @@ struct hb_title_s // whether OpenCL scaling is supported for this source int opencl_support; - int hwd_support; // TODO: merge to video_decode_support }; // Update win/CS/HandBrake.Interop/HandBrakeInterop/HbLib/hb_state_s.cs when changing this struct @@ -1153,8 +1153,6 @@ extern hb_work_object_t hb_reader; #define HB_FILTER_DROP 3 #define HB_FILTER_DONE 4 -int hb_use_dxva(hb_title_t *title); - typedef struct hb_filter_init_s { hb_job_t * job; @@ -1163,7 +1161,6 @@ typedef struct hb_filter_init_s int crop[4]; hb_rational_t vrate; int cfr; - int use_dxva; } hb_filter_init_t; typedef struct hb_filter_info_s diff --git a/libhb/cropscale.c b/libhb/cropscale.c index fc88e32a4..548bdcc2e 100644 --- a/libhb/cropscale.c +++ b/libhb/cropscale.c @@ -71,7 +71,7 @@ static int hb_crop_scale_init( hb_filter_object_t * filter, pv->height_out = init->geometry.height - (init->crop[0] + init->crop[1]); /* OpenCL/DXVA2 */ - pv->use_dxva = init->use_dxva; + pv->use_dxva = hb_hwd_enabled(init->job->h); pv->use_decomb = init->job->use_decomb; pv->use_detelecine = init->job->use_detelecine; diff --git a/libhb/decavcodec.c b/libhb/decavcodec.c index bdca1e180..f81205ada 100644 --- a/libhb/decavcodec.c +++ b/libhb/decavcodec.c @@ -1669,8 +1669,7 @@ static int decavcodecvInit( hb_work_object_t * w, hb_job_t * job ) pv->context->error_concealment = FF_EC_GUESS_MVS|FF_EC_DEBLOCK; #ifdef USE_HWD // QSV decoding is faster, so prefer it to DXVA2 - if (pv->job != NULL && !pv->qsv.decode && pv->job->use_hwd && - hb_use_dxva(pv->title)) + if (pv->job != NULL && !pv->qsv.decode && hb_hwd_enabled(pv->job->h)) { pv->dxva2 = hb_va_create_dxva2( pv->dxva2, w->codec_param ); if( pv->dxva2 && pv->dxva2->do_job == HB_WORK_OK ) @@ -1685,6 +1684,10 @@ static int decavcodecvInit( hb_work_object_t * w, hb_job_t * job ) memset( pv->opencl_scale, 0, sizeof( hb_oclscale_t ) ); pv->threads = 1; } + else + { + hb_log("decavcodecvInit: hb_va_create_dxva2 failed, using software decoder"); + } } #endif @@ -2123,6 +2126,17 @@ static int decavcodecvInfo( hb_work_object_t *w, hb_work_info_t *info ) default: break; } +#ifdef USE_HWD + hb_va_dxva2_t *dxva2 = hb_va_create_dxva2(NULL, pv->context->codec_id); + if (dxva2 != NULL) + { + if (hb_check_hwd_fmt(pv->context->pix_fmt)) + { + info->video_decode_support |= HB_DECODE_SUPPORT_DXVA2; + } + hb_va_close(dxva2); + } +#endif return 1; } diff --git a/libhb/scan.c b/libhb/scan.c index 3a19d9e19..a446344cd 100644 --- a/libhb/scan.c +++ b/libhb/scan.c @@ -1039,6 +1039,14 @@ skip_preview: aspect_to_string(&title->dar), title->geometry.par.num, title->geometry.par.den); + if (title->video_decode_support != HB_DECODE_SUPPORT_SW) + { + hb_log("scan: supported video decoders:%s%s%s", + !(title->video_decode_support & HB_DECODE_SUPPORT_SW) ? "" : " avcodec", + !(title->video_decode_support & HB_DECODE_SUPPORT_QSV) ? "" : " qsv", + !(title->video_decode_support & HB_DECODE_SUPPORT_DXVA2) ? "" : " dxva2"); + } + if( interlaced_preview_count >= ( npreviews / 2 ) ) { hb_log("Title is likely interlaced or telecined (%i out of %i previews). You should do something about that.", diff --git a/libhb/stream.c b/libhb/stream.c index be214c4bc..cb669e52f 100644 --- a/libhb/stream.c +++ b/libhb/stream.c @@ -842,6 +842,8 @@ hb_stream_open(hb_handle_t *h, char *path, hb_title_t *title, int scan) d->path = strdup( path ); if (d->path != NULL ) { + // XXX: DXVA2 integration code requires an AVFormatContext + // use lavf instead of our MPEG demuxer when it's enabled if (!hb_hwd_enabled(d->h) && hb_stream_get_type( d ) != 0 ) { if( !scan ) @@ -1104,20 +1106,6 @@ hb_title_t * hb_stream_title_scan(hb_stream_t *stream, hb_title_t * title) { hb_log( "transport stream missing PCRs - using video DTS instead" ); } -#ifdef USE_HWD - hb_va_dxva2_t * dxva2 = NULL; - dxva2 = hb_va_create_dxva2( dxva2, title->video_codec_param ); - if ( dxva2 ) - { - title->hwd_support = 1; - hb_va_close(dxva2); - dxva2 = NULL; - } - else - title->hwd_support = 0; -#else - title->hwd_support = 0; -#endif // Height, width, rate and aspect ratio information is filled in // when the previews are built @@ -5594,24 +5582,6 @@ static hb_title_t *ffmpeg_title_scan( hb_stream_t *stream, hb_title_t *title ) chapter->seconds = title->seconds; hb_list_add( title->list_chapter, chapter ); } -#ifdef USE_HWD - hb_va_dxva2_t * dxva2 = NULL; - dxva2 = hb_va_create_dxva2( dxva2, title->video_codec_param ); - if (dxva2) - { - title->hwd_support = 1; - hb_va_close(dxva2); - dxva2 = NULL; - } - else - title->hwd_support = 0; - if ( hb_check_hwd_fmt(pix_fmt) == 0) - title->hwd_support = 0; -#else - // Eliminate compiler warning "pix_fmt set but not used" - (void)pix_fmt; - title->hwd_support = 0; -#endif return title; } diff --git a/libhb/work.c b/libhb/work.c index 2ac218d27..3d158862b 100644 --- a/libhb/work.c +++ b/libhb/work.c @@ -301,6 +301,13 @@ void hb_display_job_info(hb_job_t *job) } else #endif +#ifdef USE_HWD + if (hb_hwd_enabled(job->h)) + { + hb_log(" + decoder: %s (dxva2)", title->video_codec_name); + } + else +#endif { hb_log(" + decoder: %s", title->video_codec_name); } @@ -909,6 +916,23 @@ static void do_job(hb_job_t *job) } #endif +#ifdef USE_HWD + /* + * Check support for and enable DXVA2-accelerated when applicable; we need: + * - a compatible input bitstream (HB_DECODE_SUPPORT_DXVA2) + * - DXVA2-accelerated decoding enabled (job->use_hwd) + * - an AVFormatContext (title->opaque_priv) for now + */ + if (title->video_decode_support & HB_DECODE_SUPPORT_DXVA2) + { + hb_hwd_set_enable(job->h, job->use_hwd && title->opaque_priv != NULL); + } + else +#endif + { + hb_hwd_set_enable(job->h, 0); + } + // Filters have an effect on settings. // So initialize the filters and update the job. if( job->list_filter && hb_list_count( job->list_filter ) ) @@ -920,9 +944,6 @@ static void do_job(hb_job_t *job) init.geometry.width = title->geometry.width; init.geometry.height = title->geometry.height; - /* DXVA2 */ - init.use_dxva = hb_use_dxva(title); - init.geometry.par = job->par; memcpy(init.crop, title->crop, sizeof(int[4])); init.vrate = title->vrate; diff --git a/test/test.c b/test/test.c index 4d72283b9..049be4d99 100644 --- a/test/test.c +++ b/test/test.c @@ -542,11 +542,6 @@ static void PrintTitleInfo( hb_title_t * title, int feature ) title->crop[1], title->crop[2], title->crop[3] ); fprintf(stderr, " + support opencl: %s\n", title->opencl_support ? "yes" : "no"); -#ifdef USE_HWD - fprintf(stderr, " + support hwd: %s\n", title->hwd_support ? "yes" : "no"); -#else - fprintf(stderr, " + support hwd: not built-in\n"); -#endif fprintf( stderr, " + chapters:\n" ); for( i = 0; i < hb_list_count( title->list_chapter ); i++ ) |