summaryrefslogtreecommitdiff
path: root/libavformat/hls.c
diff options
context:
space:
mode:
authorMichael Schenk <michael.schenk@albistechnologies.com>2014-04-11 08:14:40 +0200
committerAnssi Hannula <anssi.hannula@iki.fi>2014-04-12 03:14:52 +0300
commit513a431e073ab725eb85fe7021591da9ad27a55f (patch)
tree46caf2bf0127c779a58e0f1b3880e341c650cff4 /libavformat/hls.c
parent66e959682c49e0686667cd3cbde87d725bb3c7e3 (diff)
avformat/hls: reduce memory usage by using dynamically allocated url/key
Signed-off-by: Anssi Hannula <anssi.hannula@iki.fi>
Diffstat (limited to 'libavformat/hls.c')
-rw-r--r--libavformat/hls.c34
1 files changed, 29 insertions, 5 deletions
diff --git a/libavformat/hls.c b/libavformat/hls.c
index fbdd3cafd4..3897723b7d 100644
--- a/libavformat/hls.c
+++ b/libavformat/hls.c
@@ -68,8 +68,8 @@ struct segment {
int64_t duration;
int64_t url_offset;
int64_t size;
- char url[MAX_URL_SIZE];
- char key[MAX_URL_SIZE];
+ char *url;
+ char *key;
enum KeyType key_type;
uint8_t iv[16];
};
@@ -192,8 +192,11 @@ static int read_chomp_line(AVIOContext *s, char *buf, int maxlen)
static void free_segment_list(struct playlist *pls)
{
int i;
- for (i = 0; i < pls->n_segments; i++)
+ for (i = 0; i < pls->n_segments; i++) {
+ av_free(pls->segments[i]->key);
+ av_free(pls->segments[i]->url);
av_free(pls->segments[i]);
+ }
av_freep(&pls->segments);
pls->n_segments = 0;
}
@@ -504,6 +507,7 @@ static int parse_playlist(HLSContext *c, const char *url,
int64_t seg_size = -1;
uint8_t *new_url = NULL;
struct variant_info variant_info;
+ char tmp_str[MAX_URL_SIZE];
if (!in) {
AVDictionary *opts = NULL;
@@ -624,8 +628,28 @@ static int parse_playlist(HLSContext *c, const char *url,
memset(seg->iv, 0, sizeof(seg->iv));
AV_WB32(seg->iv + 12, seq);
}
- ff_make_absolute_url(seg->key, sizeof(seg->key), url, key);
- ff_make_absolute_url(seg->url, sizeof(seg->url), url, line);
+
+ if (key_type != KEY_NONE) {
+ ff_make_absolute_url(tmp_str, sizeof(tmp_str), url, key);
+ seg->key = av_strdup(tmp_str);
+ if (!seg->key) {
+ av_free(seg);
+ ret = AVERROR(ENOMEM);
+ goto fail;
+ }
+ } else {
+ seg->key = NULL;
+ }
+
+ ff_make_absolute_url(tmp_str, sizeof(tmp_str), url, line);
+ seg->url = av_strdup(tmp_str);
+ if (!seg->url) {
+ av_free(seg->key);
+ av_free(seg);
+ ret = AVERROR(ENOMEM);
+ goto fail;
+ }
+
dynarray_add(&pls->segments, &pls->n_segments, seg);
is_segment = 0;