From 9ecdfd24018722dc70fb0a448c1c9d731d6e30a2 Mon Sep 17 00:00:00 2001 From: Marco Costalba Date: Tue, 23 Nov 2010 07:00:30 +0100 Subject: [PATCH] Revert "Allow split point master to sleep (take 2)" Signed-off-by: Marco Costalba --- src/search.cpp | 41 +++++++++++++++-------------------------- src/thread.h | 1 - src/ucioption.cpp | 1 - 3 files changed, 15 insertions(+), 28 deletions(-) diff --git a/src/search.cpp b/src/search.cpp index 121575f5..2c91d778 100644 --- a/src/search.cpp +++ b/src/search.cpp @@ -263,7 +263,6 @@ namespace { // Multi-threads related variables Depth MinimumSplitDepth; int MaxThreadsPerSplitPoint; - bool UseSleepingMaster; ThreadsManager ThreadsMgr; // Node counters, used only by thread[0] but try to keep in different cache @@ -456,7 +455,6 @@ bool think(Position& pos, bool infinite, bool ponder, int time[], int increment[ MaxThreadsPerSplitPoint = Options["Maximum Number of Threads per Split Point"].value(); MultiPV = Options["MultiPV"].value(); UseLogFile = Options["Use Search Log"].value(); - UseSleepingMaster = Options["Use Sleeping Master"].value(); if (UseLogFile) LogFile.open(Options["Search Log Filename"].value().c_str(), std::ios::out | std::ios::app); @@ -2184,9 +2182,6 @@ split_point_start: // At split points actual search starts from here assert(threadID >= 0 && threadID < MAX_THREADS); - int i; - bool allFinished = false; - while (true) { // Slave threads can exit as soon as AllThreadsShouldExit raises, @@ -2202,23 +2197,23 @@ split_point_start: // At split points actual search starts from here // instead of wasting CPU time polling for work. while ( threadID >= ActiveThreads || threads[threadID].state == THREAD_INITIALIZING - || (threads[threadID].state == THREAD_AVAILABLE && (!sp || UseSleepingMaster))) + || (!sp && threads[threadID].state == THREAD_AVAILABLE)) { - lock_grab(&MPLock); + assert(!sp); + assert(threadID != 0); + + if (AllThreadsShouldExit) + break; - // Test with lock held to avoid races with wake_sleeping_thread() - for (i = 0; sp && i < ActiveThreads && !sp->slaves[i]; i++) {} - allFinished = (i == ActiveThreads); + lock_grab(&MPLock); - // Retest sleep conditions under lock protection - if ( AllThreadsShouldExit - || allFinished - || !( threadID >= ActiveThreads - || threads[threadID].state == THREAD_INITIALIZING - || (threads[threadID].state == THREAD_AVAILABLE && (!sp || UseSleepingMaster)))) + // Retest condition under lock protection + if (!( threadID >= ActiveThreads + || threads[threadID].state == THREAD_INITIALIZING + || (!sp && threads[threadID].state == THREAD_AVAILABLE))) { lock_release(&MPLock); - break; + continue; } // Put thread to sleep @@ -2248,19 +2243,14 @@ split_point_start: // At split points actual search starts from here assert(threads[threadID].state == THREAD_SEARCHING); threads[threadID].state = THREAD_AVAILABLE; - - // Wake up master thread so to allow it to return from the idle loop in - // case we are the last slave of the split point. - if (UseSleepingMaster && threadID != tsp->master && threads[tsp->master].state == THREAD_AVAILABLE) - wake_sleeping_thread(tsp->master); } // If this thread is the master of a split point and all slaves have // finished their work at this split point, return from the idle loop. - for (i = 0; sp && i < ActiveThreads && !sp->slaves[i]; i++) {} - allFinished = (i == ActiveThreads); + int i = 0; + for ( ; sp && i < ActiveThreads && !sp->slaves[i]; i++) {} - if (allFinished) + if (i == ActiveThreads) { // Because sp->slaves[] is reset under lock protection, // be sure sp->lock has been released before to return. @@ -2468,7 +2458,6 @@ split_point_start: // At split points actual search starts from here // Initialize the split point object splitPoint.parent = masterThread.splitPoint; - splitPoint.master = master; splitPoint.stopRequest = false; splitPoint.ply = ply; splitPoint.depth = depth; diff --git a/src/thread.h b/src/thread.h index 98576cce..44b70e1e 100644 --- a/src/thread.h +++ b/src/thread.h @@ -55,7 +55,6 @@ struct SplitPoint { bool pvNode, mateThreat; Value beta; int ply; - int master; Move threatMove; SearchStack sstack[MAX_THREADS][PLY_MAX_PLUS_2]; diff --git a/src/ucioption.cpp b/src/ucioption.cpp index 4194f839..81dd0ca0 100644 --- a/src/ucioption.cpp +++ b/src/ucioption.cpp @@ -94,7 +94,6 @@ void init_uci_options() { Options["Minimum Split Depth"] = Option(4, 4, 7); Options["Maximum Number of Threads per Split Point"] = Option(5, 4, 8); Options["Threads"] = Option(1, 1, MAX_THREADS); - Options["Use Sleeping Master"] = Option(false); Options["Hash"] = Option(32, 4, 8192); Options["Clear Hash"] = Option(false, "button"); Options["Ponder"] = Option(true); -- 2.39.2