2015-03-13 11:20:31 +02:00
/*
* Intel MediaSDK QSV encoder utility functions
*
* copyright ( c ) 2013 Yukinori Yamazoe
*
* This file is part of Libav .
*
* Libav is free software ; you can redistribute it and / or
* 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 .
*
* Libav is distributed in the hope that it will be useful ,
* 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
* License along with Libav ; if not , write to the Free Software
* 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"
# 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)
# 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)
2017-12-12 16:27:52 +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)
2017-12-07 08:44:26 +02:00
# if defined(_WIN32)
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)
2017-12-07 08:44:26 +02:00
# else
# define QSV_HAVE_ICQ 0
# define QSV_HAVE_VCM 0
# define QSV_HAVE_QVBR 0
# endif
2015-11-06 14:18:56 +02:00
2017-12-12 16:27:52 +02:00
# if !QSV_HAVE_LA_DS
# 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 \
{ " async_depth " , " Maximum processing parallelism " , OFFSET ( qsv . async_depth ) , AV_OPT_TYPE_INT , { . i64 = ASYNC_DEPTH_DEFAULT } , 0 , INT_MAX , VE } , \
{ " 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 } , 0 , 7 , VE , " preset " } , \
{ " fast " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_TARGETUSAGE_BEST_SPEED } , 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_BEST_QUALITY } , INT_MIN , INT_MAX , VE , " preset " } , \
2016-12-14 12:58:18 +02:00
{ " la_depth " , " Number of frames to analyze before encoding. " , OFFSET ( qsv . la_depth ) , AV_OPT_TYPE_INT , { . i64 = 9 } , 9 , 100 , VE , " la_depth " } , \
{ " unset " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = 9 } , INT_MIN , INT_MAX , VE , " la_depth " } , \
2017-12-12 16:27:52 +02:00
{ " la_ds " , " Downscaling factor for the frames saved for the lookahead analysis " , OFFSET ( qsv . la_ds ) , AV_OPT_TYPE_INT , { . i64 = - 1 } , - 1 , MFX_LOOKAHEAD_DS_4x , VE , " la_ds " } , \
{ " auto " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = - 1 } , INT_MIN , INT_MAX , VE , " la_ds " } , \
{ " off " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_LOOKAHEAD_DS_OFF } , INT_MIN , INT_MAX , VE , " la_ds " } , \
{ " 2x " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_LOOKAHEAD_DS_2x } , INT_MIN , INT_MAX , VE , " la_ds " } , \
{ " 4x " , NULL , 0 , AV_OPT_TYPE_CONST , { . i64 = MFX_LOOKAHEAD_DS_4x } , INT_MIN , INT_MAX , VE , " la_ds " } , \
2015-11-08 07:44:17 +02:00
{ " vcm " , " Use the video conferencing mode ratecontrol " , OFFSET ( qsv . vcm ) , AV_OPT_TYPE_INT , { . i64 = 0 } , 0 , 1 , VE } , \
2015-11-08 08:58:49 +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 } , \
2017-11-27 18:19:57 +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 } ,
2015-11-07 21:50:41 +02:00
2015-03-13 11:20:31 +02:00
typedef struct QSVEncContext {
AVCodecContext * avctx ;
QSVFrame * work_frames ;
mfxSession session ;
mfxSession internal_session ;
int packet_size ;
2015-06-16 18:22:11 +02:00
int width_align ;
2017-04-17 03:06:37 +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
mfxExtCodingOption2 extco2 ;
# endif
2015-10-11 22:02:26 +02:00
mfxExtOpaqueSurfaceAlloc opaque_alloc ;
mfxFrameSurface1 * * opaque_surfaces ;
AVBufferRef * opaque_alloc_buf ;
2015-11-08 07:44:17 +02:00
mfxExtBuffer * extparam_internal [ 2 + QSV_HAVE_CO2 ] ;
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-06-12 20:45:02 +02:00
QSVFramesContext frames_ctx ;
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-11-08 07:44:17 +02:00
int la_depth ;
2017-12-12 16:27:52 +02:00
int la_ds ;
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 ;
int single_sei_nal_unit ;
int max_dec_frame_buffering ;
int trellis ;
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
char * load_plugins ;
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 */