Commit 6088b7b0 authored by Zhong Li's avatar Zhong Li

lavc/qsvenc: expose qp of encoded frames

Requirement from ticket #7254.
Currently only H264 supported by MSDK.
Signed-off-by: 's avatarZhong Li <zhong.li@intel.com>
parent aa8e5eec
...@@ -1128,6 +1128,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q, ...@@ -1128,6 +1128,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
{ {
AVPacket new_pkt = { 0 }; AVPacket new_pkt = { 0 };
mfxBitstream *bs; mfxBitstream *bs;
#if QSV_VERSION_ATLEAST(1, 26)
mfxExtAVCEncodedFrameInfo *enc_info;
mfxExtBuffer **enc_buf;
#endif
mfxFrameSurface1 *surf = NULL; mfxFrameSurface1 *surf = NULL;
mfxSyncPoint *sync = NULL; mfxSyncPoint *sync = NULL;
...@@ -1161,6 +1165,22 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q, ...@@ -1161,6 +1165,22 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
bs->Data = new_pkt.data; bs->Data = new_pkt.data;
bs->MaxLength = new_pkt.size; bs->MaxLength = new_pkt.size;
#if QSV_VERSION_ATLEAST(1, 26)
if (avctx->codec_id == AV_CODEC_ID_H264) {
enc_info = av_mallocz(sizeof(*enc_info));
if (!enc_info)
return AVERROR(ENOMEM);
enc_info->Header.BufferId = MFX_EXTBUFF_ENCODED_FRAME_INFO;
enc_info->Header.BufferSz = sizeof (*enc_info);
bs->NumExtParam = 1;
enc_buf = av_mallocz(sizeof(mfxExtBuffer *));
enc_buf[0] = (mfxExtBuffer *)enc_info;
bs->ExtParam = enc_buf;
}
#endif
if (q->set_encode_ctrl_cb) { if (q->set_encode_ctrl_cb) {
q->set_encode_ctrl_cb(avctx, frame, &qsv_frame->enc_ctrl); q->set_encode_ctrl_cb(avctx, frame, &qsv_frame->enc_ctrl);
} }
...@@ -1168,6 +1188,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q, ...@@ -1168,6 +1188,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
sync = av_mallocz(sizeof(*sync)); sync = av_mallocz(sizeof(*sync));
if (!sync) { if (!sync) {
av_freep(&bs); av_freep(&bs);
#if QSV_VERSION_ATLEAST(1, 26)
if (avctx->codec_id == AV_CODEC_ID_H264)
av_freep(&enc_info);
#endif
av_packet_unref(&new_pkt); av_packet_unref(&new_pkt);
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
} }
...@@ -1184,6 +1208,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q, ...@@ -1184,6 +1208,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
if (ret < 0) { if (ret < 0) {
av_packet_unref(&new_pkt); av_packet_unref(&new_pkt);
av_freep(&bs); av_freep(&bs);
#if QSV_VERSION_ATLEAST(1, 26)
if (avctx->codec_id == AV_CODEC_ID_H264)
av_freep(&enc_info);
#endif
av_freep(&sync); av_freep(&sync);
return (ret == MFX_ERR_MORE_DATA) ? return (ret == MFX_ERR_MORE_DATA) ?
0 : ff_qsv_print_error(avctx, ret, "Error during encoding"); 0 : ff_qsv_print_error(avctx, ret, "Error during encoding");
...@@ -1200,6 +1228,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q, ...@@ -1200,6 +1228,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
av_freep(&sync); av_freep(&sync);
av_packet_unref(&new_pkt); av_packet_unref(&new_pkt);
av_freep(&bs); av_freep(&bs);
#if QSV_VERSION_ATLEAST(1, 26)
if (avctx->codec_id == AV_CODEC_ID_H264)
av_freep(&enc_info);
#endif
} }
return 0; return 0;
...@@ -1219,6 +1251,9 @@ int ff_qsv_encode(AVCodecContext *avctx, QSVEncContext *q, ...@@ -1219,6 +1251,9 @@ int ff_qsv_encode(AVCodecContext *avctx, QSVEncContext *q,
AVPacket new_pkt; AVPacket new_pkt;
mfxBitstream *bs; mfxBitstream *bs;
mfxSyncPoint *sync; mfxSyncPoint *sync;
#if QSV_VERSION_ATLEAST(1, 26)
mfxExtAVCEncodedFrameInfo *enc_info;
#endif
av_fifo_generic_read(q->async_fifo, &new_pkt, sizeof(new_pkt), NULL); av_fifo_generic_read(q->async_fifo, &new_pkt, sizeof(new_pkt), NULL);
av_fifo_generic_read(q->async_fifo, &sync, sizeof(sync), NULL); av_fifo_generic_read(q->async_fifo, &sync, sizeof(sync), NULL);
...@@ -1247,6 +1282,14 @@ FF_DISABLE_DEPRECATION_WARNINGS ...@@ -1247,6 +1282,14 @@ FF_DISABLE_DEPRECATION_WARNINGS
FF_ENABLE_DEPRECATION_WARNINGS FF_ENABLE_DEPRECATION_WARNINGS
#endif #endif
#if QSV_VERSION_ATLEAST(1, 26)
if (avctx->codec_id == AV_CODEC_ID_H264) {
enc_info = (mfxExtAVCEncodedFrameInfo *)(*bs->ExtParam);
av_log(avctx, AV_LOG_DEBUG, "QP is %d\n", enc_info->QP);
q->sum_frame_qp += enc_info->QP;
av_freep(&enc_info);
}
#endif
av_freep(&bs); av_freep(&bs);
av_freep(&sync); av_freep(&sync);
......
...@@ -103,6 +103,8 @@ typedef struct QSVEncContext { ...@@ -103,6 +103,8 @@ typedef struct QSVEncContext {
int width_align; int width_align;
int height_align; int height_align;
int sum_frame_qp;
mfxVideoParam param; mfxVideoParam param;
mfxFrameAllocRequest req; mfxFrameAllocRequest req;
......
...@@ -94,6 +94,11 @@ static av_cold int qsv_enc_close(AVCodecContext *avctx) ...@@ -94,6 +94,11 @@ static av_cold int qsv_enc_close(AVCodecContext *avctx)
{ {
QSVH264EncContext *q = avctx->priv_data; QSVH264EncContext *q = avctx->priv_data;
#if QSV_VERSION_ATLEAST(1, 26)
av_log(avctx, AV_LOG_VERBOSE, "encoded %d frames, avarge qp is %.2f\n",
avctx->frame_number,(double)q->qsv.sum_frame_qp / avctx->frame_number);
#endif
return ff_qsv_enc_close(avctx, &q->qsv); return ff_qsv_enc_close(avctx, &q->qsv);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment