From: Andreas Monzner Date: Wed, 14 Nov 2007 14:56:16 +0000 (+0000) Subject: fix frequently segfault on clean shutdown X-Git-Tag: 2.6.0~1722 X-Git-Url: https://git.cweiske.de/enigma2.git/commitdiff_plain/d4969fafffd49c4791f56141d57281a83007a29b fix frequently segfault on clean shutdown --- diff --git a/lib/base/ebase.cpp b/lib/base/ebase.cpp index 08c15610..effd7250 100644 --- a/lib/base/ebase.cpp +++ b/lib/base/ebase.cpp @@ -116,6 +116,16 @@ void eTimer::addTimeOffset( int offset ) // mainloop ePtrList eMainloop::existing_loops; +eMainloop::~eMainloop() +{ + existing_loops.remove(this); + pthread_mutex_destroy(&recalcLock); + for (std::map::iterator it(notifiers.begin());it != notifiers.end();++it) + it->second->stop(); + while(m_timer_list.begin() != m_timer_list.end()) + m_timer_list.begin()->stop(); +} + void eMainloop::addSocketNotifier(eSocketNotifier *sn) { int fd = sn->getFD(); diff --git a/lib/base/ebase.h b/lib/base/ebase.h index bab1b5f3..4378711a 100644 --- a/lib/base/ebase.h +++ b/lib/base/ebase.h @@ -217,13 +217,7 @@ public: existing_loops.push_back(this); pthread_mutex_init(&recalcLock, 0); } - virtual ~eMainloop() - { - existing_loops.remove(this); - pthread_mutex_destroy(&recalcLock); - for (std::map::iterator it(notifiers.begin());it != notifiers.end();++it) - it->second->stop(); - } + virtual ~eMainloop(); int looplevel() { return loop_level; } diff --git a/lib/dvb/dvb.h b/lib/dvb/dvb.h index b23d047f..e09f0fae 100644 --- a/lib/dvb/dvb.h +++ b/lib/dvb/dvb.h @@ -33,9 +33,12 @@ public: eDVBRegisteredFrontend(eDVBFrontend *fe, iDVBAdapter *adap) :disable(new eTimer(eApp)), m_adapter(adap), m_frontend(fe), m_inuse(0) { - disable = new eTimer(eApp); CONNECT(disable->timeout, eDVBRegisteredFrontend::closeFrontend); } + ~eDVBRegisteredFrontend() + { + delete disable; + } void dec_use() { if (!--m_inuse)