You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

136 lines
5.8KB

  1. /*
  2. * Intel MediaSDK QSV based H.264 enccoder
  3. *
  4. * copyright (c) 2013 Yukinori Yamazoe
  5. *
  6. * This file is part of Libav.
  7. *
  8. * Libav is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU Lesser General Public
  10. * License as published by the Free Software Foundation; either
  11. * version 2.1 of the License, or (at your option) any later version.
  12. *
  13. * Libav is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * Lesser General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public
  19. * License along with Libav; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  21. */
  22. #include <stdint.h>
  23. #include <sys/types.h>
  24. #include <mfx/mfxvideo.h>
  25. #include "libavutil/common.h"
  26. #include "libavutil/opt.h"
  27. #include "avcodec.h"
  28. #include "internal.h"
  29. #include "qsv.h"
  30. #include "qsv_internal.h"
  31. #include "qsvenc.h"
  32. typedef struct QSVH264EncContext {
  33. AVClass *class;
  34. QSVEncContext qsv;
  35. } QSVH264EncContext;
  36. static av_cold int qsv_enc_init(AVCodecContext *avctx)
  37. {
  38. QSVH264EncContext *q = avctx->priv_data;
  39. return ff_qsv_enc_init(avctx, &q->qsv);
  40. }
  41. static int qsv_enc_frame(AVCodecContext *avctx, AVPacket *pkt,
  42. const AVFrame *frame, int *got_packet)
  43. {
  44. QSVH264EncContext *q = avctx->priv_data;
  45. return ff_qsv_encode(avctx, &q->qsv, pkt, frame, got_packet);
  46. }
  47. static av_cold int qsv_enc_close(AVCodecContext *avctx)
  48. {
  49. QSVH264EncContext *q = avctx->priv_data;
  50. return ff_qsv_enc_close(avctx, &q->qsv);
  51. }
  52. #define OFFSET(x) offsetof(QSVH264EncContext, x)
  53. #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
  54. static const AVOption options[] = {
  55. QSV_COMMON_OPTS
  56. { "idr_interval", "Distance (in I-frames) between IDR frames", OFFSET(qsv.idr_interval), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, INT_MAX, VE },
  57. { "single_sei_nal_unit", "Put all the SEI messages into one NALU", OFFSET(qsv.single_sei_nal_unit), AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 1, VE },
  58. { "max_dec_frame_buffering", "Maximum number of frames buffered in the DPB", OFFSET(qsv.max_dec_frame_buffering), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, UINT16_MAX, VE },
  59. { "int_ref_type", "Intra refresh type", OFFSET(qsv.int_ref_type), AV_OPT_TYPE_INT, { .i64 = -1 }, -1, UINT16_MAX, VE, "int_ref_type" },
  60. { "none", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 0 }, .flags = VE, "int_ref_type" },
  61. { "vertical", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 1 }, .flags = VE, "int_ref_type" },
  62. { "int_ref_cycle_size", "Number of frames in the intra refresh cycle", OFFSET(qsv.int_ref_cycle_size), AV_OPT_TYPE_INT, { .i64 = -1 }, -1, UINT16_MAX, VE },
  63. { "int_ref_qp_delta", "QP difference for the refresh MBs", OFFSET(qsv.int_ref_qp_delta), AV_OPT_TYPE_INT, { .i64 = INT16_MIN }, INT16_MIN, INT16_MAX, VE },
  64. { "recovery_point_sei", "Insert recovery point SEI messages", OFFSET(qsv.recovery_point_sei), AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 1, VE },
  65. { "trellis", "Trellis quantization", OFFSET(qsv.trellis), AV_OPT_TYPE_FLAGS, { .i64 = 0 }, 0, UINT_MAX, VE, "trellis" },
  66. { "off", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_TRELLIS_OFF }, .flags = VE, "trellis" },
  67. { "I", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_TRELLIS_I }, .flags = VE, "trellis" },
  68. { "P", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_TRELLIS_P }, .flags = VE, "trellis" },
  69. { "B", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_TRELLIS_B }, .flags = VE, "trellis" },
  70. { "profile", NULL, OFFSET(qsv.profile), AV_OPT_TYPE_INT, { .i64 = MFX_PROFILE_UNKNOWN }, 0, INT_MAX, VE, "profile" },
  71. { "unknown" , NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_PROFILE_UNKNOWN }, INT_MIN, INT_MAX, VE, "profile" },
  72. { "baseline", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_PROFILE_AVC_BASELINE }, INT_MIN, INT_MAX, VE, "profile" },
  73. { "main" , NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_PROFILE_AVC_MAIN }, INT_MIN, INT_MAX, VE, "profile" },
  74. { "high" , NULL, 0, AV_OPT_TYPE_CONST, { .i64 = MFX_PROFILE_AVC_HIGH }, INT_MIN, INT_MAX, VE, "profile" },
  75. { NULL },
  76. };
  77. static const AVClass class = {
  78. .class_name = "h264_qsv encoder",
  79. .item_name = av_default_item_name,
  80. .option = options,
  81. .version = LIBAVUTIL_VERSION_INT,
  82. };
  83. static const AVCodecDefault qsv_enc_defaults[] = {
  84. { "b", "1M" },
  85. { "refs", "0" },
  86. // same as the x264 default
  87. { "g", "250" },
  88. { "bf", "3" },
  89. { "coder", "ac" },
  90. { "flags", "+cgop" },
  91. #if FF_API_PRIVATE_OPT
  92. { "b_strategy", "-1" },
  93. #endif
  94. { NULL },
  95. };
  96. AVCodec ff_h264_qsv_encoder = {
  97. .name = "h264_qsv",
  98. .long_name = NULL_IF_CONFIG_SMALL("H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10 (Intel Quick Sync Video acceleration)"),
  99. .priv_data_size = sizeof(QSVH264EncContext),
  100. .type = AVMEDIA_TYPE_VIDEO,
  101. .id = AV_CODEC_ID_H264,
  102. .init = qsv_enc_init,
  103. .encode2 = qsv_enc_frame,
  104. .close = qsv_enc_close,
  105. .capabilities = AV_CODEC_CAP_DELAY,
  106. .pix_fmts = (const enum AVPixelFormat[]){ AV_PIX_FMT_NV12,
  107. AV_PIX_FMT_P010,
  108. AV_PIX_FMT_QSV,
  109. AV_PIX_FMT_NONE },
  110. .priv_class = &class,
  111. .defaults = qsv_enc_defaults,
  112. .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
  113. };