X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmisc.cpp;h=e03a0e2fa7302fbe4c1b4fa418a4b3be2fc8adbb;hp=bf8143a33462780ac15e61fb3b9ddd4b6b8bc420;hb=14f059072af34bc21b71ae7fc550f03b4a075b3b;hpb=cb08413dc4e51ac246887613184b51b46bf11226 diff --git a/src/misc.cpp b/src/misc.cpp index bf8143a3..e03a0e2f 100644 --- a/src/misc.cpp +++ b/src/misc.cpp @@ -1,7 +1,7 @@ /* Stockfish, a UCI chess playing engine derived from Glaurung 2.1 Copyright (C) 2004-2008 Tord Romstad (Glaurung author) - Copyright (C) 2008-2009 Marco Costalba + Copyright (C) 2008-2010 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 @@ -39,6 +39,10 @@ #endif +#if !defined(NO_PREFETCH) +# include +#endif + #include #include #include @@ -47,6 +51,7 @@ #include "bitcount.h" #include "misc.h" +#include "thread.h" using namespace std; @@ -146,7 +151,7 @@ const string engine_name() { const string cpu64(CpuHas64BitPath ? " 64bit" : ""); if (!EngineVersion.empty()) - return AppName+ " " + EngineVersion + cpu64; + return AppName + " " + EngineVersion + cpu64; string date(__DATE__); // From compiler, format is "Sep 21 2008" string months("Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec"); @@ -188,7 +193,7 @@ int get_system_time() { # if defined(_SC_NPROCESSORS_ONLN) int cpu_count() { - return Min(sysconf(_SC_NPROCESSORS_ONLN), 8); + return Min(sysconf(_SC_NPROCESSORS_ONLN), MAX_THREADS); } # elif defined(__hpux) int cpu_count() { @@ -196,7 +201,7 @@ int cpu_count() { if (pstat_getdynamic(&psd, sizeof(psd), (size_t)1, 0) == -1) return 1; - return Min(psd.psd_proc_cnt, 8); + return Min(psd.psd_proc_cnt, MAX_THREADS); } # else int cpu_count() { @@ -209,7 +214,7 @@ int cpu_count() { int cpu_count() { SYSTEM_INFO s; GetSystemInfo(&s); - return Min(s.dwNumberOfProcessors, 8); + return Min(s.dwNumberOfProcessors, MAX_THREADS); } #endif @@ -286,4 +291,27 @@ int Bioskey() return 0; } } + #endif + +/// prefetch() preloads the given address in L1/L2 cache. This is a non +/// blocking function and do not stalls the CPU waiting for data to be +/// loaded from RAM, that can be very slow. +#if defined(NO_PREFETCH) +void prefetch(char*) {} +#else + +void prefetch(char* addr) { + +#if defined(__INTEL_COMPILER) || defined(__ICL) + // This hack prevents prefetches to be optimized away by + // Intel compiler. Both MSVC and gcc seems not affected. + __asm__ (""); +#endif + + _mm_prefetch(addr, _MM_HINT_T2); + _mm_prefetch(addr+64, _MM_HINT_T2); // 64 bytes ahead +} + +#endif +