diff options
author | fireice-uk <fireice-uk@users.noreply.github.com> | 2018-01-16 13:22:42 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-16 13:22:42 +0000 |
commit | 05dcbf6fee37e12309ec5c48951c4bf829cc14d0 (patch) | |
tree | 25842fb56268a616bfd77dbaeb08b5410dc812db | |
parent | 815246741c9e918b37231166f3a1d5e2d034c8e8 (diff) | |
parent | 6e59483f82edd09a8f90751d832e7c2794e42c67 (diff) | |
download | xmr-stak-05dcbf6fee37e12309ec5c48951c4bf829cc14d0.zip xmr-stak-05dcbf6fee37e12309ec5c48951c4bf829cc14d0.tar.gz |
Merge pull request #882 from psychocrypt/fix-windowsAffinity
fix set affinity for windows
-rw-r--r-- | xmrstak/backend/cpu/minethd.cpp | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/xmrstak/backend/cpu/minethd.cpp b/xmrstak/backend/cpu/minethd.cpp index 48425e5..f30d1fe 100644 --- a/xmrstak/backend/cpu/minethd.cpp +++ b/xmrstak/backend/cpu/minethd.cpp @@ -73,7 +73,16 @@ namespace cpu bool minethd::thd_setaffinity(std::thread::native_handle_type h, uint64_t cpu_id) { #if defined(_WIN32) - return SetThreadAffinityMask(h, 1ULL << cpu_id) != 0; + // we can only pin up to 64 threads + if(cpu_id < 64) + { + return SetThreadAffinityMask(h, 1ULL << cpu_id) != 0; + } + else + { + printer::inst()->print_msg(L0, "WARNING: Windows supports only affinity up to 63."); + return false; + } #elif defined(__APPLE__) thread_port_t mach_thread; thread_affinity_policy_data_t policy = { static_cast<integer_t>(cpu_id) }; |