aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteven Liu <lq@chinaffmpeg.org>2017-10-29 12:30:44 +0800
committerAman Gupta <aman@tmm1.net>2017-11-15 17:53:14 -0800
commitd55794fafc9efb9ce3fe9f78362e6539d9fe7d94 (patch)
treec23766a7cf28d8cd4bf056a3e21459a1e62fc96f
parent88a6fca74d247de5055bbbfbdbcc0a858170a882 (diff)
downloadffmpeg-d55794fafc9efb9ce3fe9f78362e6539d9fe7d94.tar.gz
avformat/hlsenc: fix base_output_dirname is null when basename_size is 0 bug
fix ticket id: #6777 when use argument hls_segment_filename, the basename_size will be 0 Signed-off-by: Steven Liu <lq@onvideo.cn>
-rw-r--r--libavformat/hlsenc.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/libavformat/hlsenc.c b/libavformat/hlsenc.c
index 418f153c6f..55ce800c5a 100644
--- a/libavformat/hlsenc.c
+++ b/libavformat/hlsenc.c
@@ -1335,6 +1335,7 @@ static int hls_write_header(AVFormatContext *s)
AVDictionary *options = NULL;
int basename_size = 0;
int vtt_basename_size = 0;
+ int fmp4_init_filename_len = strlen(hls->fmp4_init_filename) + 1;
if (hls->segment_type == SEGMENT_TYPE_FMP4) {
pattern = "%d.m4s";
@@ -1445,7 +1446,6 @@ static int hls_write_header(AVFormatContext *s)
}
if (av_strcasecmp(hls->fmp4_init_filename, "init.mp4")) {
- int fmp4_init_filename_len = strlen(hls->fmp4_init_filename) + 1;
hls->base_output_dirname = av_malloc(fmp4_init_filename_len);
if (!hls->base_output_dirname) {
ret = AVERROR(ENOMEM);
@@ -1453,19 +1453,25 @@ static int hls_write_header(AVFormatContext *s)
}
av_strlcpy(hls->base_output_dirname, hls->fmp4_init_filename, fmp4_init_filename_len);
} else {
- hls->base_output_dirname = av_malloc(basename_size);
+ if (basename_size > 0) {
+ hls->base_output_dirname = av_malloc(basename_size);
+ } else {
+ hls->base_output_dirname = av_malloc(strlen(hls->fmp4_init_filename));
+ }
if (!hls->base_output_dirname) {
ret = AVERROR(ENOMEM);
goto fail;
}
- av_strlcpy(hls->base_output_dirname, s->filename, basename_size);
- p = strrchr(hls->base_output_dirname, '/');
+ if (basename_size > 0) {
+ av_strlcpy(hls->base_output_dirname, s->filename, basename_size);
+ p = strrchr(hls->base_output_dirname, '/');
+ }
if (p) {
*(p + 1) = '\0';
av_strlcat(hls->base_output_dirname, hls->fmp4_init_filename, basename_size);
} else {
- av_strlcpy(hls->base_output_dirname, hls->fmp4_init_filename, basename_size);
+ av_strlcpy(hls->base_output_dirname, hls->fmp4_init_filename, fmp4_init_filename_len);
}
}