mirror of
https://github.com/sockspls/badfish
synced 2025-04-30 16:53:09 +00:00
Check for thread creation successful completion
It is a good programming practice to verify a system call has indeed succeed. No functional change. Signed-off-by: Marco Costalba <mcostalba@gmail.com>
This commit is contained in:
parent
3975a2b94f
commit
5894c759cd
1 changed files with 11 additions and 2 deletions
|
@ -555,6 +555,7 @@ bool think(const Position& pos, bool infinite, bool ponder, int side_to_move,
|
|||
void init_threads() {
|
||||
|
||||
volatile int i;
|
||||
bool ok;
|
||||
|
||||
#if !defined(_MSC_VER)
|
||||
pthread_t pthread[1];
|
||||
|
@ -594,12 +595,18 @@ void init_threads() {
|
|||
for (i = 1; i < THREAD_MAX; i++)
|
||||
{
|
||||
#if !defined(_MSC_VER)
|
||||
pthread_create(pthread, NULL, init_thread, (void*)(&i));
|
||||
ok = (pthread_create(pthread, NULL, init_thread, (void*)(&i)) == 0);
|
||||
#else
|
||||
DWORD iID[1];
|
||||
CreateThread(NULL, 0, init_thread, (LPVOID)(&i), 0, iID);
|
||||
ok = (CreateThread(NULL, 0, init_thread, (LPVOID)(&i), 0, iID) != NULL);
|
||||
#endif
|
||||
|
||||
if (!ok)
|
||||
{
|
||||
cout << "Failed to create thread number " << i << endl;
|
||||
Application::exit_with_failure();
|
||||
}
|
||||
|
||||
// Wait until the thread has finished launching
|
||||
while (!Threads[i].running);
|
||||
}
|
||||
|
@ -2792,6 +2799,8 @@ namespace {
|
|||
// If this thread has been assigned work, launch a search
|
||||
if (Threads[threadID].workIsWaiting)
|
||||
{
|
||||
assert(!Threads[threadID].idle);
|
||||
|
||||
Threads[threadID].workIsWaiting = false;
|
||||
if (Threads[threadID].splitPoint->pvNode)
|
||||
sp_search_pv(Threads[threadID].splitPoint, threadID);
|
||||
|
|
Loading…
Add table
Reference in a new issue