daemon: fix reading past stack on exit

This commit is contained in:
moneromooo-monero 2018-10-15 22:10:49 +00:00
parent 1afc1d0d26
commit 6f28667aa3
No known key found for this signature in database
GPG Key ID: 686F07454D6CEFC3
1 changed files with 10 additions and 5 deletions

View File

@ -137,13 +137,18 @@ bool t_daemon::run(bool interactive)
throw std::runtime_error{"Can't run stopped daemon"}; throw std::runtime_error{"Can't run stopped daemon"};
} }
std::atomic<bool> stop(false); std::atomic<bool> stop(false), shutdown(false);
boost::thread([&stop, this] { boost::thread stop_thread = boost::thread([&stop, &shutdown, this] {
while (!stop) while (!stop)
epee::misc_utils::sleep_no_w(100); epee::misc_utils::sleep_no_w(100);
this->stop_p2p(); if (shutdown)
}).detach(); this->stop_p2p();
tools::signal_handler::install([&stop](int){ stop = true; }); });
epee::misc_utils::auto_scope_leave_caller scope_exit_handler = epee::misc_utils::create_scope_leave_handler([&](){
stop = true;
stop_thread.join();
});
tools::signal_handler::install([&stop, &shutdown](int){ stop = shutdown = true; });
try try
{ {