mirror of
https://github.com/tuxbox-neutrino/neutrino.git
synced 2025-08-31 17:31:20 +02:00
neutrino: stop display and shutdowncount threads before exit
this should help to avoid crashes during shutdown
This commit is contained in:
@@ -4,15 +4,15 @@
|
|||||||
Copyright (C) 2001 Steffen Hehn 'McClean'
|
Copyright (C) 2001 Steffen Hehn 'McClean'
|
||||||
and some other guys
|
and some other guys
|
||||||
|
|
||||||
Copyright (C) 2006-2011 Stefan Seyfried
|
Copyright (C) 2006-2012 Stefan Seyfried
|
||||||
my contributions are GPL3+ only
|
|
||||||
Copyright (C) 2011 CoolStream International Ltd
|
Copyright (C) 2011 CoolStream International Ltd
|
||||||
|
|
||||||
License: GPL
|
License: GPL
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU General Public License as published by
|
it under the terms of the GNU General Public License as published by
|
||||||
the Free Software Foundation; either version 3 of the License, or
|
the Free Software Foundation; either version 2 of the License, or
|
||||||
(at your option) any later version.
|
(at your option) any later version.
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
This program is distributed in the hope that it will be useful,
|
||||||
@@ -3183,6 +3183,8 @@ void CNeutrinoApp::ExitRun(const bool /*write_si*/, int retcode)
|
|||||||
funNotifier.changeNotify(NONEXISTANT_LOCALE, (void *) &fspeed);
|
funNotifier.changeNotify(NONEXISTANT_LOCALE, (void *) &fspeed);
|
||||||
}
|
}
|
||||||
//CVFD::getInstance()->ShowText(g_Locale->getText(LOCALE_MAINMENU_REBOOT));
|
//CVFD::getInstance()->ShowText(g_Locale->getText(LOCALE_MAINMENU_REBOOT));
|
||||||
|
delete CVFD::getInstance();
|
||||||
|
delete SHTDCNT::getInstance();
|
||||||
stop_video();
|
stop_video();
|
||||||
|
|
||||||
printf("[neutrino] This is the end. exiting with code %d\n", retcode);
|
printf("[neutrino] This is the end. exiting with code %d\n", retcode);
|
||||||
@@ -3617,11 +3619,12 @@ int CNeutrinoApp::exec(CMenuTarget* parent, const std::string & actionKey)
|
|||||||
delete hintBox;
|
delete hintBox;
|
||||||
|
|
||||||
stop_daemons(true);
|
stop_daemons(true);
|
||||||
|
delete CVFD::getInstance();
|
||||||
|
delete SHTDCNT::getInstance();
|
||||||
stop_video();
|
stop_video();
|
||||||
/* g_Timerd, g_Zapit and CVFD are used in stop_daemons */
|
/* g_Timerd, g_Zapit and CVFD are used in stop_daemons */
|
||||||
delete g_Timerd;
|
delete g_Timerd;
|
||||||
delete g_Zapit; //do we really need this?
|
delete g_Zapit; //do we really need this?
|
||||||
delete CVFD::getInstance();
|
|
||||||
|
|
||||||
for(int i = 3; i < 256; i++)
|
for(int i = 3; i < 256; i++)
|
||||||
close(i);
|
close(i);
|
||||||
@@ -3753,6 +3756,8 @@ void sighandler (int signum)
|
|||||||
delete CRecordManager::getInstance();
|
delete CRecordManager::getInstance();
|
||||||
CNeutrinoApp::getInstance()->saveSetup(NEUTRINO_SETTINGS_FILE);
|
CNeutrinoApp::getInstance()->saveSetup(NEUTRINO_SETTINGS_FILE);
|
||||||
stop_daemons();
|
stop_daemons();
|
||||||
|
delete CVFD::getInstance();
|
||||||
|
delete SHTDCNT::getInstance();
|
||||||
stop_video();
|
stop_video();
|
||||||
//_exit(0);
|
//_exit(0);
|
||||||
exit(0);
|
exit(0);
|
||||||
@@ -4059,7 +4064,7 @@ void CNeutrinoApp::Cleanup()
|
|||||||
printf("cleanup 5\n");fflush(stdout);
|
printf("cleanup 5\n");fflush(stdout);
|
||||||
delete CEitManager::getInstance();
|
delete CEitManager::getInstance();
|
||||||
printf("cleanup 6\n");fflush(stdout);
|
printf("cleanup 6\n");fflush(stdout);
|
||||||
delete CVFD::getInstance();
|
//delete CVFD::getInstance();
|
||||||
malloc_stats();
|
malloc_stats();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user