]> git.sesse.net Git - stockfish/commitdiff
Fix undefined behavior in search.
authorStefan Geschwentner <stgeschwentner@gmail.com>
Thu, 16 Nov 2023 07:40:25 +0000 (08:40 +0100)
committerJoost VandeVondele <Joost.VandeVondele@gmail.com>
Thu, 16 Nov 2023 08:10:20 +0000 (09:10 +0100)
We use following line to clamp the search depth in some range:
Depth d = std::clamp(newDepth - r, 1, newDepth + 1);

Through negative extension its possible that the maximum value becomes smaller than the minimum value but then the behavior is undefined (see https://en.cppreference.com/w/cpp/algorithm/clamp). So replace this line with a safe implementation.

Remark:
We have in recent master already one line where up to 3 negative extensions are possible which could trigger this undefined behavior but this can only be happen for completed depth > 24 so its not discovered by our default bench. Recent negative extension tests by @fauzi shows then this undefined behavior with wrong bench numbers.

closes https://github.com/official-stockfish/Stockfish/pull/4877

No functional change

src/search.cpp

index 5bea5945c244deb7ace3e5ad073dd8ef26847631..fa479c4b8272b9896081c0f07c7da86e06a15797 100644 (file)
@@ -1178,7 +1178,9 @@ moves_loop:  // When in check, search starts here
             // In general we want to cap the LMR depth search at newDepth, but when
             // reduction is negative, we allow this move a limited search extension
             // beyond the first move depth. This may lead to hidden double extensions.
-            Depth d = std::clamp(newDepth - r, 1, newDepth + 1);
+            // To prevent problems when the max value is less than the min value,
+            // std::clamp has been replaced by a more robust implementation.
+            Depth d = std::max(1, std::min(newDepth - r, newDepth + 1));
 
             value = -search<NonPV>(pos, ss + 1, -(alpha + 1), -alpha, d, true);