diff --git a/modules/demux/asf/asf.c b/modules/demux/asf/asf.c index 3111c614dc4e1df67dcef62536feb1bebad02d7b..a2c2f052ecb0204aa94e0abbfc5dc1f00c7585b8 100644 --- a/modules/demux/asf/asf.c +++ b/modules/demux/asf/asf.c @@ -1222,9 +1222,6 @@ static int DemuxInit( demux_t *p_demux ) es_format_Clean( &fmt ); } - free( fmt_priorities_ex.pi_stream_numbers ); - free( fmt_priorities_bitrate_ex.pi_stream_numbers ); - p_sys->i_data_begin = p_sys->p_root->p_data->i_object_pos + 50; if( p_sys->p_root->p_data->i_object_size > 50 ) /* see libasf ASF_OBJECT_DATA <= 50 handling */ { /* local file */ @@ -1357,6 +1354,8 @@ static int DemuxInit( demux_t *p_demux ) } } #endif + free( fmt_priorities_ex.pi_stream_numbers ); + free( fmt_priorities_bitrate_ex.pi_stream_numbers ); p_sys->packet_sys.pi_preroll = &p_sys->p_fp->i_preroll; p_sys->packet_sys.pi_preroll_start = &p_sys->i_preroll_start; @@ -1364,6 +1363,8 @@ static int DemuxInit( demux_t *p_demux ) return VLC_SUCCESS; error: + free( fmt_priorities_ex.pi_stream_numbers ); + free( fmt_priorities_bitrate_ex.pi_stream_numbers ); DemuxEnd( p_demux ); return VLC_EGENERIC; }