Commit 0fc9002d authored by Hugo Beauzée-Luyssen's avatar Hugo Beauzée-Luyssen Committed by Jean-Baptiste Kempf

bluray: Hack to avoid crashing when changing title.

Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
(cherry picked from commit 694f1911)
Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
parent 55a68bb2
...@@ -310,8 +310,29 @@ static int blurayInitTitles(demux_t *p_demux ) ...@@ -310,8 +310,29 @@ static int blurayInitTitles(demux_t *p_demux )
return VLC_SUCCESS; return VLC_SUCCESS;
} }
static void blurayResetParser( demux_t *p_demux )
{
/*
* This is a hack and will have to be removed.
* The parser should be flushed, and not destroy/created each time
* we are changing title.
*/
demux_sys_t *p_sys = p_demux->p_sys;
if (!p_sys->p_parser)
return;
stream_Delete(p_sys->p_parser);
p_sys->p_parser = stream_DemuxNew(p_demux, "ts", p_demux->out);
if (!p_sys->p_parser) {
msg_Err(p_demux, "Failed to create TS demuxer");
}
}
static void blurayUpdateTitle( demux_t *p_demux, int i_title ) static void blurayUpdateTitle( demux_t *p_demux, int i_title )
{ {
blurayResetParser(p_demux);
if (i_title >= p_demux->p_sys->i_title)
return;
/* read title info and init some values */ /* read title info and init some values */
p_demux->info.i_title = i_title; p_demux->info.i_title = i_title;
p_demux->info.i_seekpoint = 0; p_demux->info.i_seekpoint = 0;
...@@ -483,8 +504,7 @@ static void blurayHandleEvent( demux_t *p_demux, const BD_EVENT *e ) ...@@ -483,8 +504,7 @@ static void blurayHandleEvent( demux_t *p_demux, const BD_EVENT *e )
switch (e->event) switch (e->event)
{ {
case BD_EVENT_TITLE: case BD_EVENT_TITLE:
if (e->param < p_sys->i_title) blurayUpdateTitle( p_demux, e->param );
blurayUpdateTitle( p_demux, e->param );
break; break;
case BD_EVENT_PLAYITEM: case BD_EVENT_PLAYITEM:
break; break;
......
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