mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-04-01 22:49:21 +00:00
avfilter/vf_uspp: use av_packet_alloc() to allocate packets
Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
parent
79c6e040f8
commit
b76ff693f6
@ -51,6 +51,7 @@ typedef struct USPPContext {
|
|||||||
int outbuf_size;
|
int outbuf_size;
|
||||||
uint8_t *outbuf;
|
uint8_t *outbuf;
|
||||||
AVCodecContext *avctx_enc[BLOCK*BLOCK];
|
AVCodecContext *avctx_enc[BLOCK*BLOCK];
|
||||||
|
AVPacket *pkt;
|
||||||
AVFrame *frame;
|
AVFrame *frame;
|
||||||
AVFrame *frame_dec;
|
AVFrame *frame_dec;
|
||||||
int8_t *non_b_qp_table;
|
int8_t *non_b_qp_table;
|
||||||
@ -240,24 +241,24 @@ static void filter(USPPContext *p, uint8_t *dst[3], uint8_t *src[3],
|
|||||||
const int y1c = y1 >> p->vsub;
|
const int y1c = y1 >> p->vsub;
|
||||||
const int BLOCKc = BLOCK >> p->hsub;
|
const int BLOCKc = BLOCK >> p->hsub;
|
||||||
int offset;
|
int offset;
|
||||||
AVPacket pkt = {0};
|
AVPacket *pkt = p->pkt;
|
||||||
int got_pkt_ptr;
|
int got_pkt_ptr;
|
||||||
|
|
||||||
av_init_packet(&pkt);
|
av_packet_unref(pkt);
|
||||||
pkt.data = p->outbuf;
|
pkt->data = p->outbuf;
|
||||||
pkt.size = p->outbuf_size;
|
pkt->size = p->outbuf_size;
|
||||||
|
|
||||||
p->frame->data[0] = p->src[0] + x1 + y1 * p->frame->linesize[0];
|
p->frame->data[0] = p->src[0] + x1 + y1 * p->frame->linesize[0];
|
||||||
p->frame->data[1] = p->src[1] + x1c + y1c * p->frame->linesize[1];
|
p->frame->data[1] = p->src[1] + x1c + y1c * p->frame->linesize[1];
|
||||||
p->frame->data[2] = p->src[2] + x1c + y1c * p->frame->linesize[2];
|
p->frame->data[2] = p->src[2] + x1c + y1c * p->frame->linesize[2];
|
||||||
p->frame->format = p->avctx_enc[i]->pix_fmt;
|
p->frame->format = p->avctx_enc[i]->pix_fmt;
|
||||||
|
|
||||||
ret = avcodec_encode_video2(p->avctx_enc[i], &pkt, p->frame, &got_pkt_ptr);
|
ret = avcodec_encode_video2(p->avctx_enc[i], pkt, p->frame, &got_pkt_ptr);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
av_log(p->avctx_enc[i], AV_LOG_ERROR, "Encoding failed\n");
|
av_log(p->avctx_enc[i], AV_LOG_ERROR, "Encoding failed\n");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
av_packet_unref(&pkt);
|
av_packet_unref(pkt);
|
||||||
|
|
||||||
p->frame_dec = p->avctx_enc[i]->coded_frame;
|
p->frame_dec = p->avctx_enc[i]->coded_frame;
|
||||||
|
|
||||||
@ -374,6 +375,8 @@ static int config_input(AVFilterLink *inlink)
|
|||||||
uspp->outbuf_size = (width + BLOCK) * (height + BLOCK) * 10;
|
uspp->outbuf_size = (width + BLOCK) * (height + BLOCK) * 10;
|
||||||
if (!(uspp->frame = av_frame_alloc()))
|
if (!(uspp->frame = av_frame_alloc()))
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
if (!(uspp->pkt = av_packet_alloc()))
|
||||||
|
return AVERROR(ENOMEM);
|
||||||
if (!(uspp->outbuf = av_malloc(uspp->outbuf_size)))
|
if (!(uspp->outbuf = av_malloc(uspp->outbuf_size)))
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
@ -468,6 +471,7 @@ static av_cold void uninit(AVFilterContext *ctx)
|
|||||||
|
|
||||||
av_freep(&uspp->non_b_qp_table);
|
av_freep(&uspp->non_b_qp_table);
|
||||||
av_freep(&uspp->outbuf);
|
av_freep(&uspp->outbuf);
|
||||||
|
av_packet_free(&uspp->pkt);
|
||||||
av_frame_free(&uspp->frame);
|
av_frame_free(&uspp->frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user