Re: [libav-devel] [PATCH] qsv: enforcing continuous memory layout
Hi Diego! On Sat, Jul 28, 2018 at 12:20 PM Diego Biurrun wrote: > On Sat, Jul 28, 2018 at 10:53:54AM +0200, maxim_d33 wrote: > > --- > > libavcodec/qsvenc.c | 34 -- > > 1 file changed, 24 insertions(+), 10 deletions(-) > > Looks like your Git is not set up properly. > > what do you mean exactly, Diego? I was squashing it before sending - may be because of this. > Diego > ___ > libav-devel mailing list > libav-devel@libav.org > https://lists.libav.org/mailman/listinfo/libav-devel regards Max ___ libav-devel mailing list libav-devel@libav.org https://lists.libav.org/mailman/listinfo/libav-devel
Re: [libav-devel] [PATCH] qsv: enforcing continuous memory layout
On Sat, Jul 28, 2018 at 10:53:54AM +0200, maxim_d33 wrote: > --- > libavcodec/qsvenc.c | 34 -- > 1 file changed, 24 insertions(+), 10 deletions(-) Looks like your Git is not set up properly. Diego ___ libav-devel mailing list libav-devel@libav.org https://lists.libav.org/mailman/listinfo/libav-devel
Re: [libav-devel] [PATCH] qsv: enforcing continuous memory layout
On 28/07/2018 10:53, maxim_d33 wrote: > --- > libavcodec/qsvenc.c | 34 -- > 1 file changed, 24 insertions(+), 10 deletions(-) > > diff --git a/libavcodec/qsvenc.c b/libavcodec/qsvenc.c > index e349a075f..9fb1ae01b 100644 > --- a/libavcodec/qsvenc.c > +++ b/libavcodec/qsvenc.c > @@ -1061,6 +1061,7 @@ static int submit_frame(QSVEncContext *q, const AVFrame > *frame, > { > QSVFrame *qf; > int ret; > +AVFrame* aligned_frame; > > ret = get_free_frame(q, ); > if (ret < 0) > @@ -1081,22 +1082,35 @@ static int submit_frame(QSVEncContext *q, const > AVFrame *frame, > qf->surface.Data.MemId = >frames_ctx.mids[ret]; > } > } else { > -/* make a copy if the input is not padded as libmfx requires */ > -if (frame->height & 31 || frame->linesize[0] & (q->width_align - 1)) > { This can be kept > -qf->frame->height = FFALIGN(frame->height, q->height_align); > -qf->frame->width = FFALIGN(frame->width, q->width_align); I think > -ret = ff_get_buffer(q->avctx, qf->frame, AV_GET_BUFFER_FLAG_REF); > +/* make a copy if > + - the input is not padded > + - allocations are not continious for data[0]/data[1] > + required by libmfx */ > + if ((frame->data[1] - frame->data[0] != frame->linesize[0] * > FFALIGN(frame->height, q->height_align)) || > +(frame->height & 31 || frame->linesize[0] & (q->width_align - > 1))) { > +aligned_frame = av_frame_alloc(); > +if (!aligned_frame) > +return AVERROR(ENOMEM); I think you can use qf->frame instead of creating another all the time. > +aligned_frame->format = frame->format; > +aligned_frame->height = FFALIGN(frame->height, q->height_align); > +aligned_frame->width = FFALIGN(frame->width, q->width_align); > + > +ret = av_frame_get_buffer(aligned_frame,q->width_align); > if (ret < 0) > return ret; > > -qf->frame->height = frame->height; > -qf->frame->width = frame->width; > -ret = av_frame_copy(qf->frame, frame); > +aligned_frame->height = frame->height; > +aligned_frame->width = frame->width; > + > +ret = av_frame_copy(aligned_frame, frame); > if (ret < 0) { > -av_frame_unref(qf->frame); > +av_frame_unref(aligned_frame); > return ret; > } > + > +av_frame_free(>frame); > +qf->frame = aligned_frame; > } else { > ret = av_frame_ref(qf->frame, frame); > if (ret < 0) > lu ___ libav-devel mailing list libav-devel@libav.org https://lists.libav.org/mailman/listinfo/libav-devel
[libav-devel] [PATCH] qsv: enforcing continuous memory layout
--- libavcodec/qsvenc.c | 34 -- 1 file changed, 24 insertions(+), 10 deletions(-) diff --git a/libavcodec/qsvenc.c b/libavcodec/qsvenc.c index e349a075f..9fb1ae01b 100644 --- a/libavcodec/qsvenc.c +++ b/libavcodec/qsvenc.c @@ -1061,6 +1061,7 @@ static int submit_frame(QSVEncContext *q, const AVFrame *frame, { QSVFrame *qf; int ret; +AVFrame* aligned_frame; ret = get_free_frame(q, ); if (ret < 0) @@ -1081,22 +1082,35 @@ static int submit_frame(QSVEncContext *q, const AVFrame *frame, qf->surface.Data.MemId = >frames_ctx.mids[ret]; } } else { -/* make a copy if the input is not padded as libmfx requires */ -if (frame->height & 31 || frame->linesize[0] & (q->width_align - 1)) { -qf->frame->height = FFALIGN(frame->height, q->height_align); -qf->frame->width = FFALIGN(frame->width, q->width_align); - -ret = ff_get_buffer(q->avctx, qf->frame, AV_GET_BUFFER_FLAG_REF); +/* make a copy if + - the input is not padded + - allocations are not continious for data[0]/data[1] + required by libmfx */ + if ((frame->data[1] - frame->data[0] != frame->linesize[0] * FFALIGN(frame->height, q->height_align)) || +(frame->height & 31 || frame->linesize[0] & (q->width_align - 1))) { +aligned_frame = av_frame_alloc(); +if (!aligned_frame) +return AVERROR(ENOMEM); + +aligned_frame->format = frame->format; +aligned_frame->height = FFALIGN(frame->height, q->height_align); +aligned_frame->width = FFALIGN(frame->width, q->width_align); + +ret = av_frame_get_buffer(aligned_frame,q->width_align); if (ret < 0) return ret; -qf->frame->height = frame->height; -qf->frame->width = frame->width; -ret = av_frame_copy(qf->frame, frame); +aligned_frame->height = frame->height; +aligned_frame->width = frame->width; + +ret = av_frame_copy(aligned_frame, frame); if (ret < 0) { -av_frame_unref(qf->frame); +av_frame_unref(aligned_frame); return ret; } + +av_frame_free(>frame); +qf->frame = aligned_frame; } else { ret = av_frame_ref(qf->frame, frame); if (ret < 0) -- 2.14.2 ___ libav-devel mailing list libav-devel@libav.org https://lists.libav.org/mailman/listinfo/libav-devel