Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
dvb_psi: improve check for dead muxes, fixes #2682
  • Loading branch information
perexg committed Feb 16, 2015
1 parent 51e9aec commit 496e4b1
Showing 1 changed file with 12 additions and 4 deletions.
16 changes: 12 additions & 4 deletions src/input/mpegts/dvb_psi.c
Expand Up @@ -117,6 +117,15 @@ dvb_servicetype_lookup ( int t )
return -1;
}

static inline int
mpegts_mux_alive(mpegts_mux_t *mm)
{
/*
* Return, if mux seems to be alive for updating.
*/
return !LIST_EMPTY(&mm->mm_services) && mm->mm_scan_result != MM_SCAN_FAIL;
}

static void
dvb_bouquet_comment ( bouquet_t *bq, mpegts_mux_t *mm )
{
Expand Down Expand Up @@ -1568,7 +1577,7 @@ dvb_nit_callback
/* Find existing mux */
LIST_FOREACH(mux, &mn->mn_muxes, mm_network_link)
if (mux->mm_onid == onid && mux->mm_tsid == tsid &&
(mm == mux || !LIST_EMPTY(&mux->mm_services))) {
(mm == mux || mpegts_mux_alive(mux))) {
r = dvb_nit_mux(mt, mux, mm, mn, onid, tsid, lptr, llen, tableid, bi, 0);
if (r < 0)
return r;
Expand Down Expand Up @@ -1761,7 +1770,7 @@ dvb_sdt_callback
} else {
LIST_FOREACH(mm, &mn->mn_muxes, mm_network_link)
if (mm->mm_onid == onid && mm->mm_tsid == tsid &&
(mm == mm_orig || !LIST_EMPTY(&mm->mm_services))) {
(mm == mm_orig || mpegts_mux_alive(mm))) {
r = dvb_sdt_mux(mt, mm, mm_orig, ptr, len, tableid);
if (r)
return r;
Expand Down Expand Up @@ -1830,8 +1839,7 @@ atsc_vct_callback

/* Find mux */
LIST_FOREACH(mm, &mn->mn_muxes, mm_network_link)
if (mm->mm_tsid == tsid &&
(mm == mm_orig || !LIST_EMPTY(&mm->mm_services))) {
if (mm->mm_tsid == tsid && (mm == mm_orig || mpegts_mux_alive(mm))) {
/* Find the service */
if (!(s = mpegts_service_find(mm, sid, 0, 1, &save)))
continue;
Expand Down

0 comments on commit 496e4b1

Please sign in to comment.