From 72a41e9145232a66f17f178901f2c7000f92c507 Mon Sep 17 00:00:00 2001 From: Jacek Jendrzej Date: Thu, 15 Feb 2018 18:57:59 +0100 Subject: [PATCH] second try to fix segfault on TDT time sync --- src/eitd/sectionsd.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/eitd/sectionsd.cpp b/src/eitd/sectionsd.cpp index 673957401..525d5667b 100644 --- a/src/eitd/sectionsd.cpp +++ b/src/eitd/sectionsd.cpp @@ -1487,11 +1487,11 @@ void CTimeThread::run() rc = dmx->Read(static_buf, MAX_SECTION_LENGTH, timeoutInMSeconds); #else int64_t start = time_monotonic_ms(); + int timeouts = 0; /* speed up shutdown by looping around Read() */ do { - rc = dmx->Read(static_buf, MAX_SECTION_LENGTH, timeoutInMSeconds / 12); - } while (running && rc == 0 - && (time_monotonic_ms() - start) < (int64_t)timeoutInMSeconds); + rc = getSection(static_buf, timeoutInMSeconds /6,timeouts); + } while (running && rc < 1 && (time_monotonic_ms() - start) < (int64_t)timeoutInMSeconds*2); #endif xprintf("%s: get DVB time ch 0x%012" PRIx64 " rc: %d neutrino_sets_time %d\n", name.c_str(), current_service, rc, messaging_neutrino_sets_time);