1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-19 05:49:09 +02:00

avformat/matroskaenc: Redo reformatting AV1

This avoids allocations+copies in all cases, not only those
in which the desired OBUs are contiguous in the input buffer.

Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
This commit is contained in:
Andreas Rheinhardt 2022-01-16 00:12:29 +01:00
parent 5f973193e5
commit 8318627558

View File

@ -2389,6 +2389,16 @@ static int mkv_reformat_wavpack(MatroskaMuxContext *mkv, AVIOContext *pb,
} }
#endif #endif
static int mkv_reformat_av1(MatroskaMuxContext *mkv, AVIOContext *pb,
const AVPacket *pkt, int *size)
{
int ret = ff_av1_filter_obus(pb, pkt->data, pkt->size);
if (ret < 0)
return ret;
*size = ret;
return 0;
}
static int mkv_write_block(AVFormatContext *s, AVIOContext *pb, static int mkv_write_block(AVFormatContext *s, AVIOContext *pb,
uint32_t blockid, const AVPacket *pkt, int keyframe) uint32_t blockid, const AVPacket *pkt, int keyframe)
{ {
@ -2426,9 +2436,7 @@ static int mkv_write_block(AVFormatContext *s, AVIOContext *pb,
err = ff_hevc_annexb2mp4_buf(pkt->data, &data, &size, 0, NULL); err = ff_hevc_annexb2mp4_buf(pkt->data, &data, &size, 0, NULL);
} else } else
#endif #endif
if (par->codec_id == AV_CODEC_ID_AV1) { if (track->reformat) {
err = ff_av1_filter_obus_buf(pkt->data, &data, &size, &offset);
} else if (track->reformat) {
err = track->reformat(mkv, NULL, pkt, &size); err = track->reformat(mkv, NULL, pkt, &size);
} else } else
data = pkt->data; data = pkt->data;
@ -3106,6 +3114,9 @@ static int mkv_init(struct AVFormatContext *s)
track->reformat = mkv_reformat_wavpack; track->reformat = mkv_reformat_wavpack;
break; break;
#endif #endif
case AV_CODEC_ID_AV1:
track->reformat = mkv_reformat_av1;
break;
} }
if (s->flags & AVFMT_FLAG_BITEXACT) { if (s->flags & AVFMT_FLAG_BITEXACT) {