/*
Stockfish, a UCI chess playing engine derived from Glaurung 2.1
Copyright (C) 2004-2008 Tord Romstad (Glaurung author)
- Copyright (C) 2008-2012 Marco Costalba, Joona Kiiski, Tord Romstad
+ Copyright (C) 2008-2013 Marco Costalba, Joona Kiiski, Tord Romstad
Stockfish is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
if (hashMask == size - ClusterSize)
return;
- hashMask = size - ClusterSize;
- delete [] table;
- table = new (std::nothrow) TTEntry[size];
-
- if (!table)
+ free(mem);
+ mem = malloc(size * sizeof(TTEntry) + (CACHE_LINE_SIZE - 1));
+ if (!mem)
{
std::cerr << "Failed to allocate " << mbSize
<< "MB for transposition table." << std::endl;
exit(EXIT_FAILURE);
}
- clear(); // Operator new is not guaranteed to initialize memory to zero
+ table = (TTEntry*)((size_t(mem) + CACHE_LINE_SIZE - 1) & ~(CACHE_LINE_SIZE - 1));
+ hashMask = size - ClusterSize;
+ clear(); // Newly allocated block of memory is not initialized
}