mirror of
https://github.com/HChaZZY/Stockfish.git
synced 2025-12-20 09:06:45 +08:00
Terminate threads before to exit main()
It is very difficult and risky to assure that a running thread doesn't access a global variable. This is currently true, but could change in the future and we don't want to rely on code that works 'by accident'. The threads are still running when ThreadPool destructor is called (after main() returns) and this could lead to crashes if a thread accesses a global that has been already freed. The solution is to use an exit() function and call it while we are still in main(), ensuring global variables are still alive at threads termination time. No functional change. Signed-off-by: Marco Costalba <mcostalba@gmail.com>
This commit is contained in:
@@ -37,8 +37,8 @@ int main(int argc, char* argv[]) {
|
||||
Zobrist::init();
|
||||
Bitbases::init_kpk();
|
||||
Search::init();
|
||||
Threads.init();
|
||||
Eval::init();
|
||||
Threads.init();
|
||||
TT.set_size(Options["Hash"]);
|
||||
|
||||
std::string args;
|
||||
@@ -47,4 +47,6 @@ int main(int argc, char* argv[]) {
|
||||
args += std::string(argv[i]) + " ";
|
||||
|
||||
UCI::loop(args);
|
||||
|
||||
Threads.exit();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user