[FFmpeg-devel] [PATCH] lavc/qsvenc: add quality status to side_data
Zhong Li
zhong.li at intel.com
Wed Aug 8 17:51:57 EEST 2018
Add fix a memory leak issue as James's comments.
Signed-off-by: Zhong Li <zhong.li at intel.com>
---
libavcodec/qsvenc.c | 18 ++++++++++++++----
libavcodec/qsvenc_h264.c | 5 -----
2 files changed, 14 insertions(+), 9 deletions(-)
diff --git a/libavcodec/qsvenc.c b/libavcodec/qsvenc.c
index 65dae31..2107c5b 100644
--- a/libavcodec/qsvenc.c
+++ b/libavcodec/qsvenc.c
@@ -1200,8 +1200,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
if (!sync) {
av_freep(&bs);
#if QSV_VERSION_ATLEAST(1, 26)
- if (avctx->codec_id == AV_CODEC_ID_H264)
+ if (avctx->codec_id == AV_CODEC_ID_H264) {
av_freep(&enc_info);
+ av_freep(&enc_buf);
+ }
#endif
av_packet_unref(&new_pkt);
return AVERROR(ENOMEM);
@@ -1220,8 +1222,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
av_packet_unref(&new_pkt);
av_freep(&bs);
#if QSV_VERSION_ATLEAST(1, 26)
- if (avctx->codec_id == AV_CODEC_ID_H264)
+ if (avctx->codec_id == AV_CODEC_ID_H264) {
av_freep(&enc_info);
+ av_freep(&enc_buf);
+ }
#endif
av_freep(&sync);
return (ret == MFX_ERR_MORE_DATA) ?
@@ -1240,8 +1244,10 @@ static int encode_frame(AVCodecContext *avctx, QSVEncContext *q,
av_packet_unref(&new_pkt);
av_freep(&bs);
#if QSV_VERSION_ATLEAST(1, 26)
- if (avctx->codec_id == AV_CODEC_ID_H264)
+ if (avctx->codec_id == AV_CODEC_ID_H264) {
av_freep(&enc_info);
+ av_freep(&enc_buf);
+ }
#endif
}
@@ -1264,6 +1270,7 @@ int ff_qsv_encode(AVCodecContext *avctx, QSVEncContext *q,
mfxSyncPoint *sync;
#if QSV_VERSION_ATLEAST(1, 26)
mfxExtAVCEncodedFrameInfo *enc_info;
+ mfxExtBuffer **enc_buf;
#endif
av_fifo_generic_read(q->async_fifo, &new_pkt, sizeof(new_pkt), NULL);
@@ -1295,10 +1302,13 @@ FF_ENABLE_DEPRECATION_WARNINGS
#if QSV_VERSION_ATLEAST(1, 26)
if (avctx->codec_id == AV_CODEC_ID_H264) {
+ enc_buf = bs->ExtParam;
enc_info = (mfxExtAVCEncodedFrameInfo *)(*bs->ExtParam);
- av_log(avctx, AV_LOG_DEBUG, "QP is %d\n", enc_info->QP);
+ ff_side_data_set_encoder_stats(&new_pkt,
+ enc_info->QP * FF_QP2LAMBDA, NULL, 0, avctx->coded_frame->pict_type);
q->sum_frame_qp += enc_info->QP;
av_freep(&enc_info);
+ av_freep(&enc_buf);
}
#endif
av_freep(&bs);
diff --git a/libavcodec/qsvenc_h264.c b/libavcodec/qsvenc_h264.c
index b87bef6..5c262e5 100644
--- a/libavcodec/qsvenc_h264.c
+++ b/libavcodec/qsvenc_h264.c
@@ -95,11 +95,6 @@ static av_cold int qsv_enc_close(AVCodecContext *avctx)
{
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);
}
--
2.7.4
More information about the ffmpeg-devel
mailing list