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:
parent
5f973193e5
commit
8318627558
@ -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) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user