26 #define OFFSET(x) offsetof(NvencContext, x)
27 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
71 {
"rc",
"Override the preset rate-control",
OFFSET(rc),
AV_OPT_TYPE_INT, { .i64 = -1 }, -1, INT_MAX,
VE,
"rc" },
76 {
"ll_2pass_quality",
"Multi-pass optimized for image quality (deprecated)",
78 {
"ll_2pass_size",
"Multi-pass optimized for constant frame size (deprecated)",
84 {
"rc-lookahead",
"Number of frames to look ahead for rate-control",
89 {
"gpu",
"Selects which NVENC capable GPU to use. First GPU is 0, second is 1, and so on.",
93 {
"delay",
"Delay frame output by the given amount of frames",
95 {
"no-scenecut",
"When lookahead is enabled, set this to 1 to disable adaptive I-frame insertion at scene cuts",
97 {
"forced-idr",
"If forcing keyframes, force them as IDR frames.",
99 {
"b_adapt",
"When lookahead is enabled, set this to 0 to disable adaptive B-frame decision",
103 {
"zerolatency",
"Set 1 to indicate zero latency operation (no reordering delay)",
105 {
"nonref_p",
"Set this to 1 to enable automatic insertion of non-reference P-frames",
107 {
"strict_gop",
"Set 1 to minimize GOP-to-GOP rate fluctuations",
109 {
"aq-strength",
"When Spatial AQ is enabled, this field is used to specify AQ strength. AQ strength scale is from 1 (low) - 15 (aggressive)",
111 {
"cq",
"Set target quality level (0 to 51, 0 means automatic) for constant quality mode in VBR rate control",
114 {
"bluray-compat",
"Bluray compatibility workarounds",
OFFSET(bluray_compat),
AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1,
VE },
118 {
"qp",
"Constant quantization parameter rate control method",
120 {
"weighted_pred",
"Set 1 to enable weighted prediction",
145 #if FF_API_NVENC_OLD_NAME
153 #if CONFIG_NVENC_ENCODER
154 static const AVClass nvenc_class = {
172 .priv_class = &nvenc_class,
173 .defaults = defaults,
181 #if CONFIG_NVENC_H264_ENCODER
182 static const AVClass nvenc_h264_class = {
189 AVCodec ff_nvenc_h264_encoder = {
190 .
name =
"nvenc_h264",
200 .priv_class = &nvenc_h264_class,
201 .defaults = defaults,
218 .
name =
"h264_nvenc",
228 .priv_class = &h264_nvenc_class,
229 .defaults = defaults,
#define FF_CODEC_CAP_INIT_CLEANUP
The codec allows calling the close function for deallocation even if the init function returned a fai...
Entropy coding mode is CAVLC.
#define NV_ENC_PARAMS_RC_2_PASS_VBR
Deprecated.
av_cold int ff_nvenc_encode_close(AVCodecContext *avctx)
static av_cold int nvenc_old_init(AVCodecContext *avctx)
#define NV_ENC_PARAMS_RC_2_PASS_QUALITY
Deprecated.
#define AV_LOG_WARNING
Something somehow does not look correct.
#define LIBAVUTIL_VERSION_INT
static const AVClass h264_nvenc_class
VBR, high quality (slower)
int ff_nvenc_receive_packet(AVCodecContext *avctx, AVPacket *pkt)
static const AVCodecDefault defaults[]
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
#define AV_CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
enum AVPixelFormat ff_nvenc_pix_fmts[]
#define MAX_REGISTERED_FRAMES
AVCodec ff_h264_nvenc_encoder
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
const char * name
Name of the codec implementation.
int ff_nvenc_send_frame(AVCodecContext *avctx, const AVFrame *frame)
common internal API header
Entropy coding mode is auto selected by the encoder driver.
av_cold int ff_nvenc_encode_init(AVCodecContext *avctx)
int ff_nvenc_encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *frame, int *got_packet)
Entropy coding mode is CABAC.
Libavcodec external API header.
main external API structure.
Describe the class of an AVClass context structure.
static enum AVPixelFormat pix_fmts[]
common internal api header.
#define NV_ENC_PARAMS_RC_VBR_MINQP
Deprecated.
static const AVOption options[]
low-delay CBR, high quality
#define NV_ENC_PARAMS_RC_2_PASS_FRAMESIZE_CAP
Deprecated.
CBR, high quality (slower)