summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libhb/enc_qsv.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/libhb/enc_qsv.c b/libhb/enc_qsv.c
index a29833123..2009edc63 100644
--- a/libhb/enc_qsv.c
+++ b/libhb/enc_qsv.c
@@ -309,8 +309,8 @@ static int qsv_hevc_make_header(hb_work_object_t *w, mfxSession session)
mfxU16 Height = pv->param.videoParam->mfx.FrameInfo.Height;
mfxU16 Width = pv->param.videoParam->mfx.FrameInfo.Width;
frameSurface1.Info = pv->param.videoParam->mfx.FrameInfo;
- frameSurface1.Data.VU = av_mallocz(Width * Height / 2);
- frameSurface1.Data.Y = av_mallocz(Width * Height);
+ frameSurface1.Data.Y = av_mallocz(Width * Height * 3 / 2);
+ frameSurface1.Data.VU = frameSurface1.Data.Y + Width * Height;
frameSurface1.Data.Pitch = Width;
/* Encode a single blank frame */
@@ -437,7 +437,6 @@ static int qsv_hevc_make_header(hb_work_object_t *w, mfxSession session)
end:
hb_buffer_close(&bitstream_buf);
- av_free(frameSurface1.Data.VU);
av_free(frameSurface1.Data.Y);
return ret;
}
@@ -596,8 +595,8 @@ int qsv_enc_init(hb_work_private_t *pv)
mfxFrameInfo info = pv->param.videoParam->mfx.FrameInfo;
surface->Info = info;
surface->Data.Pitch = info.Width;
- surface->Data.Y = av_mallocz(info.Width * info.Height);
- surface->Data.VU = av_mallocz(info.Width * info.Height / 2);
+ surface->Data.Y = av_mallocz(info.Width * info.Height * 3 / 2);
+ surface->Data.VU = surface->Data.Y + info.Width * info.Height;
qsv_encode->p_surfaces[i] = surface;
}
}
@@ -1458,7 +1457,6 @@ void encqsvClose(hb_work_object_t *w)
{
if (pv->is_sys_mem)
{
- av_freep(&qsv_enc_space->p_surfaces[i]->Data.VU);
av_freep(&qsv_enc_space->p_surfaces[i]->Data.Y);
}
av_freep(&qsv_enc_space->p_surfaces[i]);