]> git.sesse.net Git - vlc/commitdiff
Zero tab entries when you allocate them
authorRémi Denis-Courmont <rdenis@simphalempin.com>
Mon, 15 Sep 2008 19:27:08 +0000 (22:27 +0300)
committerRémi Denis-Courmont <rdenis@simphalempin.com>
Mon, 15 Sep 2008 19:28:03 +0000 (22:28 +0300)
Fix unitialized pointer usages (possibly exploitable).

modules/demux/playlist/xspf.c

index 3a7a4c3e117c8c52819d7e4726cd1ec7fa0a17c3..fb4570a11e7c6b76dd4f9f6a7016221191963b69 100644 (file)
@@ -498,25 +498,22 @@ static bool parse_track_node COMPLEX_INTERFACE
                 if( !strcmp( psz_name, psz_element ) )
                 {
                     FREE_ATT();
-                    if( p_demux->p_sys->i_identifier <
-                        p_demux->p_sys->i_tracklist_entries )
+                    if( p_demux->p_sys->i_identifier >=
+                           p_demux->p_sys->i_tracklist_entries )
                     {
-                        p_demux->p_sys->pp_tracklist[
-                            p_demux->p_sys->i_identifier ] = p_new_input;
-                    }
-                    else
-                    {
-                        if( p_demux->p_sys->i_identifier >
-                            p_demux->p_sys->i_tracklist_entries )
-                        {
-                            p_demux->p_sys->i_tracklist_entries =
-                                p_demux->p_sys->i_identifier;
-                        }
-                        INSERT_ELEM( p_demux->p_sys->pp_tracklist,
-                                     p_demux->p_sys->i_tracklist_entries,
-                                     p_demux->p_sys->i_tracklist_entries,
-                                     p_new_input );
+                        input_item_t **pp;
+                        pp = realloc( p_demux->p_sys->pp_tracklist,
+                            (p_demux->p_sys->i_identifier + 1) * sizeof(*pp) );
+                        if( !pp )
+                            return false;
+                        p_demux->p_sys->pp_tracklist = pp;
+                        while( p_demux->p_sys->i_identifier >=
+                               p_demux->p_sys->i_tracklist_entries )
+                            pp[p_demux->p_sys->i_tracklist_entries++] = NULL;
                     }
+
+                    p_demux->p_sys->pp_tracklist[
+                            p_demux->p_sys->i_identifier ] = p_new_input;
                     return true;
                 }
                 /* there MUST have been a start tag for that element name */