aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/movenc.c
diff options
context:
space:
mode:
authorJames Almer <jamrial@gmail.com>2024-06-15 15:35:52 -0300
committerJames Almer <jamrial@gmail.com>2024-07-07 12:38:57 -0300
commitd4e2af414437cb5250fb73524c4139b45a4b421b (patch)
tree56d06174ff6d319e7589dfd39259031102322bcd /libavformat/movenc.c
parentc4ebdd8d2d7b9b8302f3a15aa1b81199553d4ee6 (diff)
downloadffmpeg-d4e2af414437cb5250fb73524c4139b45a4b421b.tar.gz
avformat/movenc: add support for writing lhvC boxes
Signed-off-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'libavformat/movenc.c')
-rw-r--r--libavformat/movenc.c29
1 files changed, 27 insertions, 2 deletions
diff --git a/libavformat/movenc.c b/libavformat/movenc.c
index 3991be0ad4..4bd9d32b15 100644
--- a/libavformat/movenc.c
+++ b/libavformat/movenc.c
@@ -1557,6 +1557,26 @@ static int mov_write_hvcc_tag(AVIOContext *pb, MOVTrack *track)
return update_size(pb, pos);
}
+static int mov_write_lhvc_tag(AVIOContext *pb, MOVTrack *track)
+{
+ int64_t pos = avio_tell(pb);
+ int ret;
+
+ avio_wb32(pb, 0);
+ ffio_wfourcc(pb, "lhvC");
+ if (track->tag == MKTAG('h','v','c','1'))
+ ret = ff_isom_write_lhvc(pb, track->vos_data, track->vos_len, 1);
+ else
+ ret = ff_isom_write_lhvc(pb, track->vos_data, track->vos_len, 0);
+
+ if (ret < 0) {
+ avio_seek(pb, pos, SEEK_SET);
+ return ret;
+ }
+
+ return update_size(pb, pos);
+}
+
static int mov_write_evcc_tag(AVIOContext *pb, MOVTrack *track)
{
int64_t pos = avio_tell(pb);
@@ -2523,9 +2543,14 @@ static int mov_write_video_tag(AVFormatContext *s, AVIOContext *pb, MOVMuxContex
} else if (track->par->codec_id == AV_CODEC_ID_DNXHD) {
mov_write_avid_tag(pb, track);
avid = 1;
- } else if (track->par->codec_id == AV_CODEC_ID_HEVC)
+ } else if (track->par->codec_id == AV_CODEC_ID_HEVC) {
mov_write_hvcc_tag(pb, track);
- else if (track->par->codec_id == AV_CODEC_ID_VVC)
+ if (track->st->disposition & AV_DISPOSITION_MULTILAYER) {
+ ret = mov_write_lhvc_tag(pb, track);
+ if (ret < 0)
+ av_log(mov->fc, AV_LOG_WARNING, "Not writing 'lhvC' atom for multilayer stream.\n");
+ }
+ } else if (track->par->codec_id == AV_CODEC_ID_VVC)
mov_write_vvcc_tag(pb, track);
else if (track->par->codec_id == AV_CODEC_ID_H264 && !TAG_IS_AVCI(track->tag)) {
mov_write_avcc_tag(pb, track);