X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Ftt.cpp;h=6121b3ad771b24bd40410e8e5f6bff6004fdccc7;hp=aa57efb600d062b4d772ef3cc20e661f38bb9c92;hb=d4dca9187e83dde29be8d76ca50ff53d14199ce9;hpb=d07e782e22ca2ed0ec748ac38c33673baec28cc5 diff --git a/src/tt.cpp b/src/tt.cpp index aa57efb6..6121b3ad 100644 --- a/src/tt.cpp +++ b/src/tt.cpp @@ -30,8 +30,10 @@ TranspositionTable TT; // Our global transposition table -/// TTEntry::save saves a TTEntry -void TTEntry::save(Key k, Value v, bool PvNode, Bound b, Depth d, Move m, Value ev) { +/// TTEntry::save populates the TTEntry with a new node's data, possibly +/// overwriting an old position. Update is not atomic and can be racy. + +void TTEntry::save(Key k, Value v, bool pv, Bound b, Depth d, Move m, Value ev) { assert(d / ONE_PLY * ONE_PLY == d); @@ -41,14 +43,16 @@ void TTEntry::save(Key k, Value v, bool PvNode, Bound b, Depth d, Move m, Value // Overwrite less valuable entries if ( (k >> 48) != key16 - || d / ONE_PLY > depth8 - 4 + ||(d - DEPTH_OFFSET) / ONE_PLY > depth8 - 4 || b == BOUND_EXACT) { + assert((d - DEPTH_OFFSET) / ONE_PLY >= 0); + key16 = (uint16_t)(k >> 48); value16 = (int16_t)v; eval16 = (int16_t)ev; - genBound8 = (uint8_t)(TT.generation8 | PvNode << 2 | b); - depth8 = (int8_t)(d / ONE_PLY); + genBound8 = (uint8_t)(TT.generation8 | uint8_t(pv) << 2 | b); + depth8 = (uint8_t)((d - DEPTH_OFFSET) / ONE_PLY); } }