Commit 67197656 authored by Ronald S. Bultje's avatar Ronald S. Bultje

Remove use of MAX_STREAMS in MMSContext->streams[] array. Instead, dynamically

allocate the array.

Originally committed as revision 24794 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent c46000c1
...@@ -99,6 +99,9 @@ int ff_mms_asf_header_parser(MMSContext *mms) ...@@ -99,6 +99,9 @@ int ff_mms_asf_header_parser(MMSContext *mms)
//Please see function send_stream_selection_request(). //Please see function send_stream_selection_request().
if (mms->stream_num < MAX_STREAMS && if (mms->stream_num < MAX_STREAMS &&
46 + mms->stream_num * 6 < sizeof(mms->out_buffer)) { 46 + mms->stream_num * 6 < sizeof(mms->out_buffer)) {
mms->streams = av_fast_realloc(mms->streams,
&mms->nb_streams_allocated,
(mms->stream_num + 1) * sizeof(MMSStream));
mms->streams[mms->stream_num].id = stream_id; mms->streams[mms->stream_num].id = stream_id;
mms->stream_num++; mms->stream_num++;
} else { } else {
......
...@@ -29,7 +29,7 @@ typedef struct { ...@@ -29,7 +29,7 @@ typedef struct {
typedef struct { typedef struct {
URLContext *mms_hd; ///< TCP connection handle URLContext *mms_hd; ///< TCP connection handle
MMSStream streams[MAX_STREAMS]; MMSStream *streams;
/** Buffer for outgoing packets. */ /** Buffer for outgoing packets. */
/*@{*/ /*@{*/
...@@ -54,6 +54,7 @@ typedef struct { ...@@ -54,6 +54,7 @@ typedef struct {
/*@}*/ /*@}*/
int stream_num; ///< stream numbers. int stream_num; ///< stream numbers.
unsigned int nb_streams_allocated; ///< allocated size of streams
} MMSContext; } MMSContext;
int ff_mms_asf_header_parser(MMSContext * mms); int ff_mms_asf_header_parser(MMSContext * mms);
......
...@@ -468,6 +468,7 @@ static int mms_close(URLContext *h) ...@@ -468,6 +468,7 @@ static int mms_close(URLContext *h)
} }
/* free all separately allocated pointers in mms */ /* free all separately allocated pointers in mms */
av_free(mms->streams);
av_free(mms->asf_header); av_free(mms->asf_header);
av_freep(&h->priv_data); av_freep(&h->priv_data);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment