/* XMRig * Copyright 2010 Jeff Garzik * Copyright 2012-2014 pooler * Copyright 2014 Lucas Jones * Copyright 2014-2016 Wolf9466 * Copyright 2016 Jay D Dee * Copyright 2017-2018 XMR-Stak , * Copyright 2016-2018 XMRig , * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifdef __FreeBSD__ # include # include # include # include #endif #include #include #include #include #include #include #include #include #include "Platform.h" #include "version.h" #ifdef XMRIG_NVIDIA_PROJECT # include "nvidia/cryptonight.h" #endif #ifdef __FreeBSD__ typedef cpuset_t cpu_set_t; #endif char *Platform::createUserAgent() { constexpr const size_t max = 256; char *buf = new char[max](); int length = snprintf(buf, max, "%s/%s (Linux ", APP_NAME, APP_VERSION); # if defined(__x86_64__) length += snprintf(buf + length, max - length, "x86_64) libuv/%s", uv_version_string()); # elif defined(__aarch64__) length += snprintf(buf + length, max - length, "aarch64) libuv/%s", uv_version_string()); # elif defined(__arm__) length += snprintf(buf + length, max - length, "arm) libuv/%s", uv_version_string()); # else length += snprintf(buf + length, max - length, "i686) libuv/%s", uv_version_string()); # endif # ifdef XMRIG_NVIDIA_PROJECT const int cudaVersion = cuda_get_runtime_version(); length += snprintf(buf + length, max - length, " CUDA/%d.%d", cudaVersion / 1000, cudaVersion % 100); # endif # ifdef __clang__ length += snprintf(buf + length, max - length, " clang/%d.%d.%d", __clang_major__, __clang_minor__, __clang_patchlevel__); # elif defined(__GNUC__) length += snprintf(buf + length, max - length, " gcc/%d.%d.%d", __GNUC__, __GNUC_MINOR__, __GNUC_PATCHLEVEL__); # endif return buf; } bool Platform::setThreadAffinity(uint64_t cpu_id) { cpu_set_t mn; CPU_ZERO(&mn); CPU_SET(cpu_id, &mn); # ifndef __ANDROID__ return pthread_setaffinity_np(pthread_self(), sizeof(cpu_set_t), &mn) == 0; # else return sched_setaffinity(gettid(), sizeof(cpu_set_t), &mn) == 0; # endif } uint32_t Platform::setTimerResolution(uint32_t resolution) { return resolution; } void Platform::restoreTimerResolution() { } void Platform::setProcessPriority(int priority) { } void Platform::setThreadPriority(int priority) { if (priority == -1) { return; } int prio = 19; switch (priority) { case 1: prio = 5; break; case 2: prio = 0; break; case 3: prio = -5; break; case 4: prio = -10; break; case 5: prio = -15; break; default: break; } setpriority(PRIO_PROCESS, 0, prio); # ifdef SCHED_IDLE if (priority == 0) { sched_param param; param.sched_priority = 0; if (sched_setscheduler(0, SCHED_IDLE, ¶m) != 0) { sched_setscheduler(0, SCHED_BATCH, ¶m); } } # endif }