aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndreas Rheinhardt <andreas.rheinhardt@gmail.com>2020-01-23 04:10:48 +0100
committerAndreas Rheinhardt <andreas.rheinhardt@gmail.com>2020-07-02 02:09:59 +0200
commit1884d887bae30d702ac4d059fe80646e8d2f294b (patch)
tree292600cccf35fa3d241824b41a7978b3e1f88a13
parent297d5a110b846977d7c1f17e53ab2ddffd17f464 (diff)
downloadffmpeg-1884d887bae30d702ac4d059fe80646e8d2f294b.tar.gz
avformat/hevc: Defer initializations in ff_isom_write_hvcc()
Saves initialization of an HEVCDecoderConfigurationRecord when the data is already in ISOBMFF-format or if it is plainly invalid. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com>
-rw-r--r--libavformat/hevc.c18
1 files changed, 8 insertions, 10 deletions
diff --git a/libavformat/hevc.c b/libavformat/hevc.c
index f621cb2f19..94eb3a9cb1 100644
--- a/libavformat/hevc.c
+++ b/libavformat/hevc.c
@@ -1068,29 +1068,27 @@ int ff_hevc_annexb2mp4_buf(const uint8_t *buf_in, uint8_t **buf_out,
int ff_isom_write_hvcc(AVIOContext *pb, const uint8_t *data,
int size, int ps_array_completeness)
{
- int ret = 0;
- uint8_t *buf, *end, *start = NULL;
HEVCDecoderConfigurationRecord hvcc;
-
- hvcc_init(&hvcc);
+ uint8_t *buf, *end, *start;
+ int ret;
if (size < 6) {
/* We can't write a valid hvcC from the provided data */
- ret = AVERROR_INVALIDDATA;
- goto end;
+ return AVERROR_INVALIDDATA;
} else if (*data == 1) {
/* Data is already hvcC-formatted */
avio_write(pb, data, size);
- goto end;
+ return 0;
} else if (!(AV_RB24(data) == 1 || AV_RB32(data) == 1)) {
/* Not a valid Annex B start code prefix */
- ret = AVERROR_INVALIDDATA;
- goto end;
+ return AVERROR_INVALIDDATA;
}
ret = ff_avc_parse_nal_units_buf(data, &start, &size);
if (ret < 0)
- goto end;
+ return ret;
+
+ hvcc_init(&hvcc);
buf = start;
end = start + size;