2015-03-13 11:20:31 +02:00
/*
* Intel MediaSDK QSV encoder utility functions
*
* copyright ( c ) 2013 Yukinori Yamazoe
*
2015-03-28 02:33:27 +02:00
* This file is part of FFmpeg .
2015-03-13 11:20:31 +02:00
*
2015-03-28 02:33:27 +02:00
* FFmpeg is free software ; you can redistribute it and / or
2015-03-13 11:20:31 +02:00
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
2015-03-28 02:33:27 +02:00
* FFmpeg is distributed in the hope that it will be useful ,
2015-03-13 11:20:31 +02:00
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
2015-03-28 02:33:27 +02:00
* License along with FFmpeg ; if not , write to the Free Software
2015-03-13 11:20:31 +02:00
* Foundation , Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
*/
# ifndef AVCODEC_QSVENC_H
# define AVCODEC_QSVENC_H
# include <stdint.h>
# include <sys/types.h>
# include <mfx/mfxvideo.h>
# include "libavutil/avutil.h"
2015-07-14 18:16:26 +02:00
# include "libavutil/fifo.h"
2015-03-13 11:20:31 +02:00
# include "avcodec.h"
2020-04-13 17:33:16 +02:00
# include "hwconfig.h"
2015-03-13 11:20:31 +02:00
# include "qsv_internal.h"
2015-11-06 14:18:56 +02:00
# define QSV_HAVE_CO2 QSV_VERSION_ATLEAST(1, 6)
# define QSV_HAVE_CO3 QSV_VERSION_ATLEAST(1, 11)
2019-03-26 20:56:24 +02:00
# define QSV_HAVE_CO_VPS QSV_VERSION_ATLEAST(1, 17)
2015-11-06 14:18:56 +02:00
2019-11-26 05:56:18 +02:00
# define QSV_HAVE_EXT_HEVC_TILES QSV_VERSION_ATLEAST(1, 13)
2019-10-26 16:18:31 +02:00
# define QSV_HAVE_EXT_VP9_PARAM QSV_VERSION_ATLEAST(1, 26)
2015-11-06 14:18:56 +02:00
# define QSV_HAVE_TRELLIS QSV_VERSION_ATLEAST(1, 8)
2015-11-08 08:58:49 +02:00
# define QSV_HAVE_MAX_SLICE_SIZE QSV_VERSION_ATLEAST(1, 9)
# define QSV_HAVE_BREF_TYPE QSV_VERSION_ATLEAST(1, 8)
2015-11-06 14:18:56 +02:00
# define QSV_HAVE_LA QSV_VERSION_ATLEAST(1, 7)
2016-10-21 19:57:12 +02:00
# define QSV_HAVE_LA_DS QSV_VERSION_ATLEAST(1, 8)
2015-11-06 14:18:56 +02:00
# define QSV_HAVE_LA_HRD QSV_VERSION_ATLEAST(1, 11)
2018-11-29 08:14:22 +02:00
# define QSV_HAVE_VDENC QSV_VERSION_ATLEAST(1, 15)
2017-12-07 08:44:26 +02:00
2019-01-11 09:09:07 +02:00
# define QSV_HAVE_GPB QSV_VERSION_ATLEAST(1, 18)
2018-06-15 16:52:28 +02:00
# if defined(_WIN32) || defined(__CYGWIN__)
2018-01-30 12:07:23 +02:00
# define QSV_HAVE_AVBR QSV_VERSION_ATLEAST(1, 3)
2015-11-06 14:18:56 +02:00
# define QSV_HAVE_ICQ QSV_VERSION_ATLEAST(1, 8)
# define QSV_HAVE_VCM QSV_VERSION_ATLEAST(1, 8)
# define QSV_HAVE_QVBR QSV_VERSION_ATLEAST(1, 11)
2018-04-02 15:17:23 +02:00
# define QSV_HAVE_MF 0
2017-12-07 08:44:26 +02:00
# else
2018-01-30 12:07:23 +02:00
# define QSV_HAVE_AVBR 0
2018-11-29 10:28:59 +02:00
# define QSV_HAVE_ICQ QSV_VERSION_ATLEAST(1, 28)
2017-12-07 08:44:26 +02:00
# define QSV_HAVE_VCM 0
2019-01-23 13:16:17 +02:00
# define QSV_HAVE_QVBR QSV_VERSION_ATLEAST(1, 28)
2018-04-02 15:17:23 +02:00
# define QSV_HAVE_MF QSV_VERSION_ATLEAST(1, 25)
2017-12-07 08:44:26 +02:00
# endif
2015-11-06 14:18:56 +02:00
2017-12-12 16:27:52 +02:00
# if !QSV_HAVE_LA_DS
2017-12-15 00:04:37 +02:00
# define MFX_LOOKAHEAD_DS_UNKNOWN 0
2017-12-12 16:27:52 +02:00
# define MFX_LOOKAHEAD_DS_OFF 0
# define MFX_LOOKAHEAD_DS_2x 0
# define MFX_LOOKAHEAD_DS_4x 0
# endif
2015-11-07 21:50:41 +02:00
# define QSV_COMMON_OPTS \
2018-09-03 00:23:26 +02:00
{ " async_depth " , " Maximum processing parallelism " , OFFSET ( qsv . async_depth ) , AV_OPT_TYPE_INT , { . i64 = ASYNC_DEPTH_DEFAULT } , 1 , INT_MAX , VE } , \
2015-11-24 15:48:28 +02:00
{ " avbr_accuracy " , " Accuracy of the AVBR ratecontrol " , OFFSET ( qsv . avbr_accuracy ) , AV_OPT_TYPE_INT , { . i64 = 0 } , 0 , INT_MAX , VE } , \
{ " avbr_convergence " , " Convergence of the AVBR ratecontrol " , OFFSET ( qsv . avbr_convergence ) , AV_OPT_TYPE_INT , { . i64 = 0 } , 0 , INT_MAX , VE } , \
{ " preset " , NULL , OFFSET ( qsv . preset ) , AV_OPT_TYPE_INT , { . i64 = MFX_TARGETUSAGE_BALANCED } , MFX_TARGETUSAGE_BEST_QUALITY , MFX_TARGETUSAGE_BEST_SPEED , VE , " preset " } , \
{ " veryfast " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_BEST_SPEED } , INT_MIN , INT_MAX , VE , " preset " } , \
{ " faster " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_6 } , INT_MIN , INT_MAX , VE , " preset " } , \
{ " fast " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_5 } , INT_MIN , INT_MAX , VE , " preset " } , \
{ " medium " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_BALANCED } , INT_MIN , INT_MAX , VE , " preset " } , \
{ " slow " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_3 } , INT_MIN , INT_MAX , VE , " preset " } , \
{ " slower " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_2 } , INT_MIN , INT_MAX , VE , " preset " } , \
{ " veryslow " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_BEST_QUALITY } , INT_MIN , INT_MAX , VE , " preset " } , \
2015-11-29 16:22:53 +02:00
{ " rdo " , " Enable rate distortion optimization " , OFFSET ( qsv . rdo ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , 1 , VE } , \
{ " max_frame_size " , " Maximum encoded frame size in bytes " , OFFSET ( qsv . max_frame_size ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , UINT16_MAX , VE } , \
{ " max_slice_size " , " Maximum encoded slice size in bytes " , OFFSET ( qsv . max_slice_size ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , UINT16_MAX , VE } , \
{ " bitrate_limit " , " Toggle bitrate limitations " , OFFSET ( qsv . bitrate_limit ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , 1 , VE } , \
{ " mbbrc " , " MB level bitrate control " , OFFSET ( qsv . mbbrc ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , 1 , VE } , \
{ " extbrc " , " Extended bitrate control " , OFFSET ( qsv . extbrc ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , 1 , VE } , \
{ " adaptive_i " , " Adaptive I-frame placement " , OFFSET ( qsv . adaptive_i ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , 1 , VE } , \
{ " adaptive_b " , " Adaptive B-frame placement " , OFFSET ( qsv . adaptive_b ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , 1 , VE } , \
2016-01-27 22:18:04 +02:00
{ " b_strategy " , " Strategy to choose between I/P/B-frames " , OFFSET ( qsv . b_strategy ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , 1 , VE } , \
2018-11-29 10:29:00 +02:00
{ " forced_idr " , " Forcing I frames as IDR frames " , OFFSET ( qsv . forced_idr ) , AV_OPT_TYPE_BOOL , { . i64 = 0 } , 0 , 1 , VE } , \
2019-03-29 07:19:06 +02:00
{ " low_power " , " enable low power mode(experimental: many limitations by mfx version, BRC modes, etc.) " , OFFSET ( qsv . low_power ) , AV_OPT_TYPE_BOOL , { . i64 = 0 } , 0 , 1 , VE } , \
2015-11-07 21:50:41 +02:00
2020-11-08 20:51:15 +02:00
extern const AVCodecHWConfigInternal * const ff_qsv_enc_hw_configs [ ] ;
2020-04-13 17:33:16 +02:00
2015-10-27 19:08:45 +02:00
typedef int SetEncodeCtrlCB ( AVCodecContext * avctx ,
const AVFrame * frame , mfxEncodeCtrl * enc_ctrl ) ;
2015-03-13 11:20:31 +02:00
typedef struct QSVEncContext {
AVCodecContext * avctx ;
QSVFrame * work_frames ;
mfxSession session ;
2019-09-19 22:45:26 +02:00
QSVSession internal_qs ;
2015-03-13 11:20:31 +02:00
int packet_size ;
2015-06-16 18:22:11 +02:00
int width_align ;
2017-05-06 06:31:30 +02:00
int height_align ;
2015-03-13 11:20:31 +02:00
mfxVideoParam param ;
mfxFrameAllocRequest req ;
mfxExtCodingOption extco ;
2015-11-08 07:44:17 +02:00
# if QSV_HAVE_CO2
2015-08-21 10:17:35 +02:00
mfxExtCodingOption2 extco2 ;
# endif
2019-01-23 13:16:17 +02:00
# if QSV_HAVE_CO3
mfxExtCodingOption3 extco3 ;
# endif
2018-04-02 15:17:23 +02:00
# if QSV_HAVE_MF
mfxExtMultiFrameParam extmfp ;
mfxExtMultiFrameControl extmfc ;
# endif
2019-11-26 05:56:18 +02:00
# if QSV_HAVE_EXT_HEVC_TILES
mfxExtHEVCTiles exthevctiles ;
# endif
2019-10-26 16:18:31 +02:00
# if QSV_HAVE_EXT_VP9_PARAM
2019-11-26 05:53:16 +02:00
mfxExtVP9Param extvp9param ;
2019-10-26 16:18:31 +02:00
# endif
2015-10-11 22:02:26 +02:00
mfxExtOpaqueSurfaceAlloc opaque_alloc ;
mfxFrameSurface1 * * opaque_surfaces ;
AVBufferRef * opaque_alloc_buf ;
2019-01-23 13:16:17 +02:00
mfxExtBuffer * extparam_internal [ 2 + QSV_HAVE_CO2 + QSV_HAVE_CO3 + ( QSV_HAVE_MF * 2 ) ] ;
2015-10-11 22:02:26 +02:00
int nb_extparam_internal ;
2015-08-05 15:22:34 +02:00
mfxExtBuffer * * extparam ;
2015-03-13 11:20:31 +02:00
2015-07-14 18:16:26 +02:00
AVFifoBuffer * async_fifo ;
2016-10-21 19:57:12 +02:00
QSVFramesContext frames_ctx ;
2019-03-26 01:40:54 +02:00
mfxVersion ver ;
2019-03-26 20:56:24 +02:00
int hevc_vps ;
2015-03-13 11:20:31 +02:00
// options set by the caller
int async_depth ;
int idr_interval ;
int profile ;
int preset ;
int avbr_accuracy ;
int avbr_convergence ;
2015-08-19 10:17:40 +02:00
int pic_timing_sei ;
2015-08-21 10:17:35 +02:00
int look_ahead ;
int look_ahead_depth ;
int look_ahead_downsampling ;
2015-11-08 07:44:17 +02:00
int vcm ;
2015-11-08 08:58:49 +02:00
int rdo ;
int max_frame_size ;
int max_slice_size ;
2019-11-26 05:56:18 +02:00
int tile_cols ;
int tile_rows ;
2018-03-15 12:02:12 +02:00
int aud ;
2015-11-08 08:58:49 +02:00
int single_sei_nal_unit ;
int max_dec_frame_buffering ;
int bitrate_limit ;
int mbbrc ;
int extbrc ;
int adaptive_i ;
int adaptive_b ;
2015-09-09 04:18:26 +02:00
int b_strategy ;
2016-01-13 22:27:00 +02:00
int cavlc ;
2015-11-08 08:58:49 +02:00
int int_ref_type ;
int int_ref_cycle_size ;
int int_ref_qp_delta ;
int recovery_point_sei ;
2015-06-16 18:22:11 +02:00
2018-10-25 13:14:16 +02:00
int repeat_pps ;
2018-11-29 08:14:22 +02:00
int low_power ;
2019-01-11 09:09:07 +02:00
int gpb ;
2018-10-25 13:14:16 +02:00
2015-10-27 19:08:45 +02:00
int a53_cc ;
2018-04-14 01:34:23 +02:00
2018-04-02 15:17:23 +02:00
# if QSV_HAVE_MF
int mfmode ;
# endif
2015-06-16 18:22:11 +02:00
char * load_plugins ;
2015-10-27 19:08:45 +02:00
SetEncodeCtrlCB * set_encode_ctrl_cb ;
2018-11-29 10:29:00 +02:00
int forced_idr ;
2015-03-13 11:20:31 +02:00
} QSVEncContext ;
int ff_qsv_enc_init ( AVCodecContext * avctx , QSVEncContext * q ) ;
int ff_qsv_encode ( AVCodecContext * avctx , QSVEncContext * q ,
AVPacket * pkt , const AVFrame * frame , int * got_packet ) ;
int ff_qsv_enc_close ( AVCodecContext * avctx , QSVEncContext * q ) ;
# endif /* AVCODEC_QSVENC_H */